26 lines
567 B
C
Raw Normal View History

2023-10-31 07:47:27 +01:00
#include "system/task_sine.h"
#include "system/data_channel.h"
#include "system/float_word.h"
2024-11-06 09:05:45 +01:00
#include <math.h>
#define PI 3.14
2023-10-31 07:47:27 +01:00
int task_sine_run( void * data ) {
2024-11-06 09:05:45 +01:00
sine_config *task = (sine_config*)data;
uint32_t data_channel_base = task->base.sink;
data_channel_clear(data_channel_base);
for (uint32_t i = 0; i < DATA_CHANNEL_DEPTH; ++i)
{
float_word res;
res.value = task->amplitude * sin( (2*PI*task->samples_per_periode) * i + task->phase);
data_channel_write(data_channel_base, res.word);
}
2023-10-31 07:47:27 +01:00
return 0;
}