| 12
 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
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 
 | /*
	dsp/Sine.h
	
	Copyright 2003-4 Tim Goetze <tim@quitte.de>
	
	http://quitte.de/dsp/
	direct form I recursive sin() generator.
*/
/*
	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.
	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, write to the Free Software
	Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
	02111-1307, USA or point your web browser to http://www.gnu.org.
*/
#ifndef _DSP_SINE_H_
#define _DSP_SINE_H_
namespace DSP {
	
class Sine
{
	protected:
		int z;
		d_float y[2];
		d_float b;
	public:
		Sine()
			{ 
				b = 0;
				y[0] = y[1] = 0;
				z = 0;
			}
		Sine (double f, double fs, double phase)
			{
				set_f (f, fs, phase);
			}
		Sine (double omega, double phase = 0.)
			{
				set_f (omega, phase);
			}
		inline void set_f (double f, double fs, double phase)
			{
				set_f (f * M_PI / fs, phase);
			}
		inline void set_f (double w, double phase)
			{
				b = 2 * cos (w);
				y[0] = sin (phase - w);
				y[1] = sin (phase - w * 2);
				z = 0;
			}
		/* advance and return 1 sample */
		inline double get()
			{
				register double s = b * y[z]; 
				z ^= 1;
				s -= y[z];
				return y[z] = s;
			}
		double get_phase()
			{
				double x0 = y[z], x1 = b * y[z] - y[z^1];
				double phi = asin (x0);
				
				/* slope is falling, we're into the 2nd half. */
				if (x1 < x0)
					return M_PI - phi;
				return phi;
			}
};
} /* namespace DSP */
#endif /* _DSP_SINE_H_ */
 |