/** Node-type for signal generation. * * @file * @author Steffen Vogel * @copyright 2017, Institute for Automation of Complex Power Systems, EONERC * @license GNU General Public License (version 3) * * VILLASnode * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . *********************************************************************************/ /** * @ingroup node * @addtogroup signal Signal generation node-type- * @{ */ #pragma once #include #include "timing.h" /* Forward declarations */ struct node; struct sample; /** Node-type for signal generation. * @see node_type */ struct signal { int tfd; /**< timerfd file descriptor. */ enum { TYPE_RANDOM, TYPE_SINE, TYPE_SQUARE, TYPE_TRIANGLE, TYPE_RAMP, TYPE_MIXED } type; /**< Signal type */ double rate; /**< Sampling rate. */ double frequency; /**< Frequency of the generated signals. */ double amplitude; /**< Amplitude of the generated signals. */ double stddev; /**< Standard deviation of random signals (normal distributed). */ int values; /**< The number of values which will be emitted by this node. */ int limit; /**< The number of values which should be generated by this node. <0 for infinitve. */ struct timespec started; /**< Point in time when this node was started. */ int counter; /**< The number of packets already emitted. */ }; /** @see node_type::print */ char * signal_print(struct node *n); /** @see node_type::parse */ int signal_parse(struct node *n, config_setting_t *cfg); /** @see node_type::open */ int signal_open(struct node *n); /** @see node_type::close */ int signal_close(struct node *n); /** @see node_type::read */ int signal_read(struct node *n, struct sample *smps[], unsigned cnt); /** @} */