2014-06-05 09:34:29 +00:00
|
|
|
/**
|
|
|
|
* Message related functions
|
|
|
|
*
|
|
|
|
* @author Steffen Vogel <stvogel@eonerc.rwth-aachen.de>
|
|
|
|
* @copyright 2014, Institute for Automation of Complex Power Systems, EONERC
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "msg.h"
|
|
|
|
|
2014-06-05 09:34:53 +00:00
|
|
|
int msg_fprint(FILE *f, struct msg *msg)
|
2014-06-05 09:34:29 +00:00
|
|
|
{
|
2014-06-05 09:34:53 +00:00
|
|
|
fprintf(f, "%-8u %-8u", msg->device, msg->sequence);
|
2014-06-05 09:34:29 +00:00
|
|
|
|
2014-06-05 09:34:53 +00:00
|
|
|
for (int i = 0; i < msg->length / sizeof(double); i++) {
|
|
|
|
fprintf(f, "%-12.6f ", msg->data[i]);
|
|
|
|
}
|
2014-06-05 09:34:29 +00:00
|
|
|
|
|
|
|
fprintf(f, "\n");
|
2014-06-05 09:34:53 +00:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int msg_fscan(FILE *f, struct msg *msg)
|
|
|
|
{
|
|
|
|
fscanf(f, "%8u %8u ", &msg->device, &msg->sequence);
|
|
|
|
|
|
|
|
for (int i = 0; i < msg->length / sizeof(double); i++) {
|
|
|
|
fscanf(f, "%12lf ", &msg->data[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
fscanf(f, "\n");
|
|
|
|
|
|
|
|
return 0;
|
2014-06-05 09:34:29 +00:00
|
|
|
}
|
|
|
|
|
2014-06-05 09:34:53 +00:00
|
|
|
void msg_random(struct msg *m)
|
2014-06-05 09:34:29 +00:00
|
|
|
{
|
2014-06-05 09:34:53 +00:00
|
|
|
int values = m->length / sizeof(double);
|
2014-06-05 09:34:29 +00:00
|
|
|
|
2014-06-05 09:34:53 +00:00
|
|
|
for (int i = 0; i < values; i++) {
|
|
|
|
m->data[i] += (double) random() / RAND_MAX - .5;
|
|
|
|
}
|
2014-06-05 09:34:29 +00:00
|
|
|
|
2014-06-05 09:34:53 +00:00
|
|
|
m->sequence++;
|
2014-06-05 09:34:29 +00:00
|
|
|
}
|
|
|
|
|