FFmpeg
iirfilter.h
Go to the documentation of this file.
1 /*
2  * IIR filter
3  * Copyright (c) 2008 Konstantin Shishkov
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
27 #ifndef AVCODEC_IIRFILTER_H
28 #define AVCODEC_IIRFILTER_H
29 
30 #include <stddef.h>
31 #include <stdint.h>
32 
33 struct FFIIRFilterCoeffs;
34 struct FFIIRFilterState;
35 
36 enum IIRFilterType{
37  FF_FILTER_TYPE_BESSEL,
38  FF_FILTER_TYPE_BIQUAD,
39  FF_FILTER_TYPE_BUTTERWORTH,
40  FF_FILTER_TYPE_CHEBYSHEV,
41  FF_FILTER_TYPE_ELLIPTIC,
42 };
43 
44 enum IIRFilterMode{
45  FF_FILTER_MODE_LOWPASS,
46  FF_FILTER_MODE_HIGHPASS,
47  FF_FILTER_MODE_BANDPASS,
48  FF_FILTER_MODE_BANDSTOP,
49 };
50 
51 typedef struct FFIIRFilterContext {
63  void (*filter_flt)(const struct FFIIRFilterCoeffs *coeffs,
64  struct FFIIRFilterState *state, int size,
65  const float *src, ptrdiff_t sstep, float *dst, ptrdiff_t dstep);
67 
72 void ff_iir_filter_init_mips(FFIIRFilterContext *f);
73 
89  enum IIRFilterType filt_type,
90  enum IIRFilterMode filt_mode,
91  int order, float cutoff_ratio,
92  float stopband, float ripple);
93 
101 struct FFIIRFilterState* ff_iir_filter_init_state(int order);
102 
108 void ff_iir_filter_free_coeffsp(struct FFIIRFilterCoeffs **coeffs);
109 
115 void ff_iir_filter_free_statep(struct FFIIRFilterState **state);
116 
128 void ff_iir_filter(const struct FFIIRFilterCoeffs *coeffs, struct FFIIRFilterState *state,
129  int size, const int16_t *src, ptrdiff_t sstep, int16_t *dst, ptrdiff_t dstep);
130 
142 void ff_iir_filter_flt(const struct FFIIRFilterCoeffs *coeffs,
143  struct FFIIRFilterState *state, int size,
144  const float *src, ptrdiff_t sstep,
145  float *dst, ptrdiff_t dstep);
146 
147 #endif /* AVCODEC_IIRFILTER_H */
struct FFIIRFilterState * ff_iir_filter_init_state(int order)
Create new filter state.
Definition: iirfilter.c:204
void ff_iir_filter_free_statep(struct FFIIRFilterState **state)
Free and zero filter state.
Definition: iirfilter.c:307
void(* filter_flt)(const struct FFIIRFilterCoeffs *coeffs, struct FFIIRFilterState *state, int size, const float *src, ptrdiff_t sstep, float *dst, ptrdiff_t dstep)
Perform IIR filtering on floating-point input samples.
Definition: iirfilter.h:63
void ff_iir_filter_flt(const struct FFIIRFilterCoeffs *coeffs, struct FFIIRFilterState *state, int size, const float *src, ptrdiff_t sstep, float *dst, ptrdiff_t dstep)
Perform IIR filtering on floating-point input samples.
Definition: iirfilter.c:293
Definition: iirfilter.h:51
struct FFIIRFilterCoeffs * ff_iir_filter_init_coeffs(void *avc, enum IIRFilterType filt_type, enum IIRFilterMode filt_mode, int order, float cutoff_ratio, float stopband, float ripple)
Initialize filter coefficients.
Definition: iirfilter.c:162
IIR filter state.
Definition: iirfilter.c:47
void ff_iir_filter_free_coeffsp(struct FFIIRFilterCoeffs **coeffs)
Free filter coefficients.
Definition: iirfilter.c:312
void ff_iir_filter(const struct FFIIRFilterCoeffs *coeffs, struct FFIIRFilterState *state, int size, const int16_t *src, ptrdiff_t sstep, int16_t *dst, ptrdiff_t dstep)
Perform IIR filtering on signed 16-bit input samples.
Definition: iirfilter.c:279
IIR filter global parameters.
Definition: iirfilter.c:37
void ff_iir_filter_init(FFIIRFilterContext *f)
Initialize FFIIRFilterContext.
Definition: iirfilter.c:322