File: FilterByCoefExample.hxx

package info (click to toggle)
clam 1.4.0-6
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 17,836 kB
  • ctags: 20,981
  • sloc: cpp: 92,504; python: 9,721; ansic: 1,602; xml: 444; sh: 239; makefile: 153; perl: 54; asm: 15
file content (92 lines) | stat: -rw-r--r-- 2,254 bytes parent folder | download | duplicates (2)
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
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
/*
 * 
 *
 *
 * 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
 *
 */

#ifndef _FilterByCoefExample_
#define _FilterByCoefExample_

#include <CLAM/Processing.hxx>
#include <CLAM/AudioInPort.hxx>
#include <CLAM/AudioOutPort.hxx>

#include "../Filter/Filter.hxx"

namespace CLAM {

	/**	\brief Band pass filter defined by direct form coefficients
	*
	*	Example
	*/
	class FilterByCoefExample: public Processing
	{	
		/** This method returns the name of the object
		*	@return Char pointer with the name of object
		*/
		const char *GetClassName() const { return "FilterByCoefExample"; }

		/** Ports **/
		AudioInPort mInput;
		AudioOutPort mOutput;

		/** Controls **/

	public:
		FilterByCoefExample(const Config & config=Config())
			:
			mInput("Input", this),
			mOutput("Output", this)
		{
			Configure( config );

			unsigned N = 11; //filter order + 1
			FilterConfig cfg;
			cfg.SetAmountOfInputCoefficients(N);
			mFilter.Configure( cfg );

			//FIR band pass filter coefficients. Order 10. 11 coefficients.
			TData b_k[] = {
					0.0555,    0.0933,   -0.1187,   -0.2476,    0.0628,    0.3265,    0.0628,   -0.2476,   -0.1187,\
					0.0933,    0.0555\
			};
			char bkstr[5];
			for(unsigned i=0;i<N;i++)
			{ 
				sprintf(bkstr, "b_%i", i);
				SendFloatToInControl(mFilter, bkstr, b_k[i]);
			}
		}

		~FilterByCoefExample() {}

		bool Do()
		{
			mFilter.Do( mInput.GetAudio(), mOutput.GetAudio() );
			mInput.Consume(); 
			mOutput.Produce();
			return true;
		}
	
	private:
		/** Child processings **/
		Filter mFilter;
	};

};//namespace CLAM

#endif // _FilterByCoefExample_