| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |  * IIR filter | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  * Copyright (c) 2008 Konstantin Shishkov | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of FFmpeg. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * FFmpeg is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							|  |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * FFmpeg 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 | 
					
						
							|  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License along with FFmpeg; if not, write to the Free Software | 
					
						
							|  |  |  |  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-04-20 14:45:34 +00:00
										 |  |  |  * @file | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |  * IIR filter interface | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-31 07:39:47 +00:00
										 |  |  | #ifndef AVCODEC_IIRFILTER_H
 | 
					
						
							|  |  |  | #define AVCODEC_IIRFILTER_H
 | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "avcodec.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  | struct FFIIRFilterCoeffs; | 
					
						
							|  |  |  | struct FFIIRFilterState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum IIRFilterType{ | 
					
						
							|  |  |  |     FF_FILTER_TYPE_BESSEL, | 
					
						
							| 
									
										
										
										
											2011-01-20 21:26:47 +00:00
										 |  |  |     FF_FILTER_TYPE_BIQUAD, | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |     FF_FILTER_TYPE_BUTTERWORTH, | 
					
						
							|  |  |  |     FF_FILTER_TYPE_CHEBYSHEV, | 
					
						
							|  |  |  |     FF_FILTER_TYPE_ELLIPTIC, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum IIRFilterMode{ | 
					
						
							|  |  |  |     FF_FILTER_MODE_LOWPASS, | 
					
						
							|  |  |  |     FF_FILTER_MODE_HIGHPASS, | 
					
						
							|  |  |  |     FF_FILTER_MODE_BANDPASS, | 
					
						
							|  |  |  |     FF_FILTER_MODE_BANDSTOP, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Initialize filter coefficients. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-01-20 18:28:16 +00:00
										 |  |  |  * @param avc          a pointer to an arbitrary struct of which the first | 
					
						
							|  |  |  |  *                     field is a pointer to an AVClass struct | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |  * @param filt_type    filter type (e.g. Butterworth) | 
					
						
							|  |  |  |  * @param filt_mode    filter mode (e.g. lowpass) | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  * @param order        filter order | 
					
						
							|  |  |  |  * @param cutoff_ratio cutoff to input frequency ratio | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |  * @param stopband     stopband to input frequency ratio (used by bandpass and bandstop filter modes) | 
					
						
							|  |  |  |  * @param ripple       ripple factor (used only in Chebyshev filters) | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return pointer to filter coefficients structure or NULL if filter cannot be created | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-01-20 18:28:16 +00:00
										 |  |  | struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(void *avc, | 
					
						
							|  |  |  |                                                 enum IIRFilterType filt_type, | 
					
						
							| 
									
										
										
										
											2011-01-20 18:28:17 +00:00
										 |  |  |                                                 enum IIRFilterMode filt_mode, | 
					
						
							|  |  |  |                                                 int order, float cutoff_ratio, | 
					
						
							|  |  |  |                                                 float stopband, float ripple); | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Create new filter state. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param order filter order | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return pointer to new filter state or NULL if state creation fails | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  | struct FFIIRFilterState* ff_iir_filter_init_state(int order); | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free filter coefficients. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |  * @param coeffs pointer allocated with ff_iir_filter_init_coeffs() | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  | void ff_iir_filter_free_coeffs(struct FFIIRFilterCoeffs *coeffs); | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Free filter state. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  |  * @param state pointer allocated with ff_iir_filter_init_state() | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  | void ff_iir_filter_free_state(struct FFIIRFilterState *state); | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2011-01-20 17:24:06 +00:00
										 |  |  |  * Perform IIR filtering on signed 16-bit input samples. | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param coeffs pointer to filter coefficients | 
					
						
							|  |  |  |  * @param state  pointer to filter state | 
					
						
							|  |  |  |  * @param size   input length | 
					
						
							|  |  |  |  * @param src    source samples | 
					
						
							|  |  |  |  * @param sstep  source stride | 
					
						
							|  |  |  |  * @param dst    filtered samples (destination may be the same as input) | 
					
						
							|  |  |  |  * @param dstep  destination stride | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-08-28 04:53:57 +00:00
										 |  |  | void ff_iir_filter(const struct FFIIRFilterCoeffs *coeffs, struct FFIIRFilterState *state, | 
					
						
							|  |  |  |                    int size, const int16_t *src, int sstep, int16_t *dst, int dstep); | 
					
						
							| 
									
										
										
										
											2008-08-23 15:49:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-20 17:24:06 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Perform IIR filtering on floating-point input samples. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param coeffs pointer to filter coefficients | 
					
						
							|  |  |  |  * @param state  pointer to filter state | 
					
						
							|  |  |  |  * @param size   input length | 
					
						
							|  |  |  |  * @param src    source samples | 
					
						
							|  |  |  |  * @param sstep  source stride | 
					
						
							|  |  |  |  * @param dst    filtered samples (destination may be the same as input) | 
					
						
							|  |  |  |  * @param dstep  destination stride | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ff_iir_filter_flt(const struct FFIIRFilterCoeffs *coeffs, | 
					
						
							|  |  |  |                        struct FFIIRFilterState *state, int size, | 
					
						
							| 
									
										
										
										
											2011-01-21 21:59:19 +00:00
										 |  |  |                        const float *src, int sstep, float *dst, int dstep); | 
					
						
							| 
									
										
										
										
											2011-01-20 17:24:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-31 07:39:47 +00:00
										 |  |  | #endif /* AVCODEC_IIRFILTER_H */
 |