xref: /illumos-gate/usr/src/cmd/audio/include/Fir.h (revision 7c478bd9)
1*7c478bd9Sstevel@tonic-gate /*
2*7c478bd9Sstevel@tonic-gate  * CDDL HEADER START
3*7c478bd9Sstevel@tonic-gate  *
4*7c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5*7c478bd9Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
6*7c478bd9Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
7*7c478bd9Sstevel@tonic-gate  * with the License.
8*7c478bd9Sstevel@tonic-gate  *
9*7c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*7c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
11*7c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
12*7c478bd9Sstevel@tonic-gate  * and limitations under the License.
13*7c478bd9Sstevel@tonic-gate  *
14*7c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
15*7c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*7c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
17*7c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
18*7c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
19*7c478bd9Sstevel@tonic-gate  *
20*7c478bd9Sstevel@tonic-gate  * CDDL HEADER END
21*7c478bd9Sstevel@tonic-gate  */
22*7c478bd9Sstevel@tonic-gate /*
23*7c478bd9Sstevel@tonic-gate  * Copyright (c) 1992-2001 by Sun Microsystems, Inc.
24*7c478bd9Sstevel@tonic-gate  * All rights reserved.
25*7c478bd9Sstevel@tonic-gate  */
26*7c478bd9Sstevel@tonic-gate 
27*7c478bd9Sstevel@tonic-gate #ifndef _MULTIMEDIA_FIR_H
28*7c478bd9Sstevel@tonic-gate #define	_MULTIMEDIA_FIR_H
29*7c478bd9Sstevel@tonic-gate 
30*7c478bd9Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
31*7c478bd9Sstevel@tonic-gate 
32*7c478bd9Sstevel@tonic-gate #ifdef __cplusplus
33*7c478bd9Sstevel@tonic-gate extern "C" {
34*7c478bd9Sstevel@tonic-gate #endif
35*7c478bd9Sstevel@tonic-gate 
36*7c478bd9Sstevel@tonic-gate /*
37*7c478bd9Sstevel@tonic-gate  * Finite Impulse Response (FIR) filter object
38*7c478bd9Sstevel@tonic-gate  *
39*7c478bd9Sstevel@tonic-gate  * For every input sample, the FIR filter generates an output sample:
40*7c478bd9Sstevel@tonic-gate  * output =	coef[0] * input +
41*7c478bd9Sstevel@tonic-gate  *		coef[1] * state[order - 1] +
42*7c478bd9Sstevel@tonic-gate  *		coef[2] * state[order - 2] +
43*7c478bd9Sstevel@tonic-gate  *		...
44*7c478bd9Sstevel@tonic-gate  *		coef[order] * state[0]
45*7c478bd9Sstevel@tonic-gate  *
46*7c478bd9Sstevel@tonic-gate  * and the filter states are updated:
47*7c478bd9Sstevel@tonic-gate  *	state[0] = state[1]
48*7c478bd9Sstevel@tonic-gate  *	state[1] = state[2]
49*7c478bd9Sstevel@tonic-gate  *	...
50*7c478bd9Sstevel@tonic-gate  *	state[order - 2] = state[order - 1]
51*7c478bd9Sstevel@tonic-gate  *	state[order - 1] = input
52*7c478bd9Sstevel@tonic-gate  */
53*7c478bd9Sstevel@tonic-gate class Fir {
54*7c478bd9Sstevel@tonic-gate protected:
55*7c478bd9Sstevel@tonic-gate 	int		order;		// filter order, # taps = order + 1
56*7c478bd9Sstevel@tonic-gate 	double		*coef;		// (order + 1) filter coeffs.
57*7c478bd9Sstevel@tonic-gate 	double		*state;		// "order" filter states
58*7c478bd9Sstevel@tonic-gate 	int		delay;		// actual delay between output & input
59*7c478bd9Sstevel@tonic-gate 
60*7c478bd9Sstevel@tonic-gate 	virtual void	updateState(double *data, int size);
61*7c478bd9Sstevel@tonic-gate 	virtual void	update_short(short *data, int size);
62*7c478bd9Sstevel@tonic-gate 	virtual int	flush(short *out);
63*7c478bd9Sstevel@tonic-gate public:
64*7c478bd9Sstevel@tonic-gate 	virtual void	resetState(void);	// reset states to zero
65*7c478bd9Sstevel@tonic-gate 	Fir(void);
66*7c478bd9Sstevel@tonic-gate 	Fir(int order_in);
67*7c478bd9Sstevel@tonic-gate 	~Fir();
68*7c478bd9Sstevel@tonic-gate 	virtual int	getOrder(void);		// get filter order value
69*7c478bd9Sstevel@tonic-gate 	virtual int	getNumCoefs(void);	// get number of coefficients
70*7c478bd9Sstevel@tonic-gate 	virtual void	putCoef(double *coef_in); // put coef_in in filter coef
71*7c478bd9Sstevel@tonic-gate 	virtual void	getCoef(double *coef_out); // get filter coef
72*7c478bd9Sstevel@tonic-gate 	// filter "size" input samples for "size" output samples
73*7c478bd9Sstevel@tonic-gate 	virtual int	filter_noadjust(short *in, int size, short *out);
74*7c478bd9Sstevel@tonic-gate 	/*
75*7c478bd9Sstevel@tonic-gate 	 * filter "size" input samples. Output sample sequence is offset by
76*7c478bd9Sstevel@tonic-gate 	 * group delay samples to align with the input sample sequence.
77*7c478bd9Sstevel@tonic-gate 	 * the first call of this routine returns "size - group_delay"
78*7c478bd9Sstevel@tonic-gate 	 * output samples. Call this routine with size = 0
79*7c478bd9Sstevel@tonic-gate 	 * to fill the output buffer such that the total number of output
80*7c478bd9Sstevel@tonic-gate 	 * samples is equal to the number of input samples.
81*7c478bd9Sstevel@tonic-gate 	 */
82*7c478bd9Sstevel@tonic-gate 	virtual int	getFlushSize(void); // size of out[] for the last call
83*7c478bd9Sstevel@tonic-gate 	virtual int	filter(short *in, int size, short *out);
84*7c478bd9Sstevel@tonic-gate };
85*7c478bd9Sstevel@tonic-gate 
86*7c478bd9Sstevel@tonic-gate #ifdef __cplusplus
87*7c478bd9Sstevel@tonic-gate }
88*7c478bd9Sstevel@tonic-gate #endif
89*7c478bd9Sstevel@tonic-gate 
90*7c478bd9Sstevel@tonic-gate #endif /* !_MULTIMEDIA_FIR_H */
91