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