00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 
00021 
00027 #ifndef AVCODEC_IIRFILTER_H
00028 #define AVCODEC_IIRFILTER_H
00029 
00030 #include "avcodec.h"
00031 
00032 struct FFIIRFilterCoeffs;
00033 struct FFIIRFilterState;
00034 
00035 enum IIRFilterType{
00036     FF_FILTER_TYPE_BESSEL,
00037     FF_FILTER_TYPE_BIQUAD,
00038     FF_FILTER_TYPE_BUTTERWORTH,
00039     FF_FILTER_TYPE_CHEBYSHEV,
00040     FF_FILTER_TYPE_ELLIPTIC,
00041 };
00042 
00043 enum IIRFilterMode{
00044     FF_FILTER_MODE_LOWPASS,
00045     FF_FILTER_MODE_HIGHPASS,
00046     FF_FILTER_MODE_BANDPASS,
00047     FF_FILTER_MODE_BANDSTOP,
00048 };
00049 
00064 struct FFIIRFilterCoeffs* ff_iir_filter_init_coeffs(void *avc,
00065                                                 enum IIRFilterType filt_type,
00066                                                 enum IIRFilterMode filt_mode,
00067                                                 int order, float cutoff_ratio,
00068                                                 float stopband, float ripple);
00069 
00077 struct FFIIRFilterState* ff_iir_filter_init_state(int order);
00078 
00084 void ff_iir_filter_free_coeffs(struct FFIIRFilterCoeffs *coeffs);
00085 
00091 void ff_iir_filter_free_state(struct FFIIRFilterState *state);
00092 
00104 void ff_iir_filter(const struct FFIIRFilterCoeffs *coeffs, struct FFIIRFilterState *state,
00105                    int size, const int16_t *src, int sstep, int16_t *dst, int dstep);
00106 
00118 void ff_iir_filter_flt(const struct FFIIRFilterCoeffs *coeffs,
00119                        struct FFIIRFilterState *state, int size,
00120                        const float *src, int sstep, float *dst, int dstep);
00121 
00122 #endif