blob: 31d7d78f2fd3c5cfb9b3e22d6a4f879f38c92704 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
/***************************************************************************
* Copyright (C) 2003-2004 by David Saxton *
* david@bluehaze.org *
* *
* 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 2 of the License, or *
* (at your option) any later version. *
***************************************************************************/
#include "elementsignal.h"
#include <cmath>
ElementSignal::ElementSignal()
{
m_type = ElementSignal::st_sinusoidal;
m_time = 0.;
m_frequency = 0.;
}
ElementSignal::~ElementSignal()
{
}
void ElementSignal::setStep( double delta, Type type, double frequency )
{
m_type = type;
m_delta = delta;
m_frequency = frequency;
m_omega = 6.283185307179586*m_frequency;
m_time = 1./(4.*m_frequency);
}
double ElementSignal::advance()
{
m_time += m_delta;
if ( m_time >= 1./m_frequency ) m_time -= 1./m_frequency;
switch (m_type)
{
case ElementSignal::st_sawtooth:
{
// TODO Sawtooth signal
return 0.;
}
case ElementSignal::st_square:
{
return (sin(m_time*m_omega)>=0)?1:-1;
}
case ElementSignal::st_triangular:
{
// TODO Triangular signal
return 0.;
}
case ElementSignal::st_sinusoidal:
default:
{
return sin(m_time*m_omega);
}
}
}
|