summaryrefslogtreecommitdiffstats
path: root/src/electronics/simulation/elementsignal.cpp
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                               *
 *   [email protected]                                                    *
 *                                                                         *
 *   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);
		}
	}
}