FFmpeg
Data Structures | Macros | Functions | Variables
af_aiir.c File Reference
#include <float.h>
#include "libavutil/avassert.h"
#include "libavutil/avstring.h"
#include "libavutil/intreadwrite.h"
#include "libavutil/opt.h"
#include "libavutil/xga_font_data.h"
#include "audio.h"
#include "avfilter.h"
#include "internal.h"

Go to the source code of this file.

Data Structures

struct  ThreadData
 Used for passing data between threads. More...
 
struct  Pair
 
struct  BiquadContext
 
struct  IIRChannel
 
struct  AudioIIRContext
 

Macros

#define IIR_CH(name, type, min, max, need_clipping)
 
#define SERIAL_IIR_CH(name, type, min, max, need_clipping)
 
#define PARALLEL_IIR_CH(name, type, min, max, need_clipping)
 
#define OFFSET(x)   offsetof(AudioIIRContext, x)
 
#define AF   AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
 
#define VF   AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
 

Functions

static int query_formats (AVFilterContext *ctx)
 
static void count_coefficients (char *item_str, int *nb_items)
 
static int read_gains (AVFilterContext *ctx, char *item_str, int nb_items)
 
static int read_tf_coefficients (AVFilterContext *ctx, char *item_str, int nb_items, double *dst)
 
static int read_zp_coefficients (AVFilterContext *ctx, char *item_str, int nb_items, double *dst, const char *format)
 
static int read_channels (AVFilterContext *ctx, int channels, uint8_t *item_str, int ab)
 
static void cmul (double re, double im, double re2, double im2, double *RE, double *IM)
 
static int expand (AVFilterContext *ctx, double *pz, int n, double *coefs)
 
static void normalize_coeffs (AVFilterContext *ctx, int ch)
 
static int convert_zp2tf (AVFilterContext *ctx, int channels)
 
static int decompose_zp2biquads (AVFilterContext *ctx, int channels)
 
static void biquad_process (double *x, double *y, int length, double b0, double b1, double b2, double a1, double a2)
 
static void solve (double *matrix, double *vector, int n, double *y, double *x, double *lu)
 
static int convert_serial2parallel (AVFilterContext *ctx, int channels)
 
static void convert_pr2zp (AVFilterContext *ctx, int channels)
 
static void convert_sp2zp (AVFilterContext *ctx, int channels)
 
static double fact (double i)
 
static double coef_sf2zf (double *a, int N, int n)
 
static void convert_sf2tf (AVFilterContext *ctx, int channels)
 
static void convert_pd2zp (AVFilterContext *ctx, int channels)
 
static void check_stability (AVFilterContext *ctx, int channels)
 
static void drawtext (AVFrame *pic, int x, int y, const char *txt, uint32_t color)
 
static void draw_line (AVFrame *out, int x0, int y0, int x1, int y1, uint32_t color)
 
static double distance (double x0, double x1, double y0, double y1)
 
static void get_response (int channel, int format, double w, const double *b, const double *a, int nb_b, int nb_a, double *magnitude, double *phase)
 
static void draw_response (AVFilterContext *ctx, AVFrame *out, int sample_rate)
 
static int config_output (AVFilterLink *outlink)
 
static int filter_frame (AVFilterLink *inlink, AVFrame *in)
 
static int config_video (AVFilterLink *outlink)
 
static av_cold int init (AVFilterContext *ctx)
 
static av_cold void uninit (AVFilterContext *ctx)
 
 AVFILTER_DEFINE_CLASS (aiir)
 

Variables

static const char * format [] = { "%lf", "%lf %lfi", "%lf %lfr", "%lf %lfd", "%lf %lfi" }
 
static const AVFilterPad inputs []
 
static const AVOption aiir_options []
 
AVFilter ff_af_aiir
 

Macro Definition Documentation

#define IIR_CH (   name,
  type,
  min,
  max,
  need_clipping 
)

Definition at line 123 of file af_aiir.c.

#define SERIAL_IIR_CH (   name,
  type,
  min,
  max,
  need_clipping 
)

Definition at line 179 of file af_aiir.c.

#define PARALLEL_IIR_CH (   name,
  type,
  min,
  max,
  need_clipping 
)

Definition at line 238 of file af_aiir.c.

#define OFFSET (   x)    offsetof(AudioIIRContext, x)

Definition at line 1457 of file af_aiir.c.

Definition at line 1458 of file af_aiir.c.

Definition at line 1459 of file af_aiir.c.

Function Documentation

static int query_formats ( AVFilterContext ctx)
static

Definition at line 79 of file af_aiir.c.

static void count_coefficients ( char *  item_str,
int nb_items 
)
static

Definition at line 302 of file af_aiir.c.

Referenced by read_channels().

static int read_gains ( AVFilterContext ctx,
char *  item_str,
int  nb_items 
)
static

Definition at line 316 of file af_aiir.c.

Referenced by config_output().

static int read_tf_coefficients ( AVFilterContext ctx,
char *  item_str,
int  nb_items,
double *  dst 
)
static

Definition at line 349 of file af_aiir.c.

Referenced by read_channels().

static int read_zp_coefficients ( AVFilterContext ctx,
char *  item_str,
int  nb_items,
double *  dst,
const char *  format 
)
static

Definition at line 374 of file af_aiir.c.

Referenced by read_channels().

static int read_channels ( AVFilterContext ctx,
int  channels,
uint8_t item_str,
int  ab 
)
static

Definition at line 401 of file af_aiir.c.

Referenced by config_output().

static void cmul ( double  re,
double  im,
double  re2,
double  im2,
double *  RE,
double *  IM 
)
static

Definition at line 448 of file af_aiir.c.

Referenced by expand().

static int expand ( AVFilterContext ctx,
double *  pz,
int  n,
double *  coefs 
)
static

Definition at line 454 of file af_aiir.c.

Referenced by convert_zp2tf(), and decompose_zp2biquads().

static void normalize_coeffs ( AVFilterContext ctx,
int  ch 
)
static

Definition at line 481 of file af_aiir.c.

Referenced by config_output(), and convert_zp2tf().

static int convert_zp2tf ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 509 of file af_aiir.c.

Referenced by config_output().

static int decompose_zp2biquads ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 557 of file af_aiir.c.

Referenced by config_output().

static void biquad_process ( double *  x,
double *  y,
int  length,
double  b0,
double  b1,
double  b2,
double  a1,
double  a2 
)
static

Definition at line 719 of file af_aiir.c.

Referenced by convert_serial2parallel().

static void solve ( double *  matrix,
double *  vector,
int  n,
double *  y,
double *  x,
double *  lu 
)
static

Definition at line 737 of file af_aiir.c.

Referenced by convert_serial2parallel().

static int convert_serial2parallel ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 771 of file af_aiir.c.

Referenced by config_output().

static void convert_pr2zp ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 841 of file af_aiir.c.

Referenced by config_output().

static void convert_sp2zp ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 868 of file af_aiir.c.

Referenced by config_output().

static double fact ( double  i)
static

Definition at line 895 of file af_aiir.c.

Referenced by apply_tilt_comp(), coef_sf2zf(), ftp_parse_entry_mlsd(), and pred_angular().

static double coef_sf2zf ( double *  a,
int  N,
int  n 
)
static

Definition at line 902 of file af_aiir.c.

Referenced by convert_sf2tf().

static void convert_sf2tf ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 921 of file af_aiir.c.

Referenced by config_output().

static void convert_pd2zp ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 949 of file af_aiir.c.

Referenced by config_output().

static void check_stability ( AVFilterContext ctx,
int  channels 
)
static

Definition at line 976 of file af_aiir.c.

Referenced by config_output().

static void drawtext ( AVFrame pic,
int  x,
int  y,
const char *  txt,
uint32_t  color 
)
static

Definition at line 995 of file af_aiir.c.

Referenced by draw_response().

static void draw_line ( AVFrame out,
int  x0,
int  y0,
int  x1,
int  y1,
uint32_t  color 
)
static

Definition at line 1018 of file af_aiir.c.

Referenced by draw_response().

static double distance ( double  x0,
double  x1,
double  y0,
double  y1 
)
static

Definition at line 1044 of file af_aiir.c.

Referenced by decompose_zp2biquads(), and get_response().

static void get_response ( int  channel,
int  format,
double  w,
const double *  b,
const double *  a,
int  nb_b,
int  nb_a,
double *  magnitude,
double *  phase 
)
static

Definition at line 1049 of file af_aiir.c.

Referenced by draw_response().

static void draw_response ( AVFilterContext ctx,
AVFrame out,
int  sample_rate 
)
static

Definition at line 1096 of file af_aiir.c.

Referenced by config_output().

static int config_output ( AVFilterLink outlink)
static

Definition at line 1213 of file af_aiir.c.

Referenced by init().

static int filter_frame ( AVFilterLink inlink,
AVFrame in 
)
static

Definition at line 1315 of file af_aiir.c.

static int config_video ( AVFilterLink outlink)
static

Definition at line 1370 of file af_aiir.c.

Referenced by init().

static av_cold int init ( AVFilterContext ctx)
static

Definition at line 1384 of file af_aiir.c.

static av_cold void uninit ( AVFilterContext ctx)
static

Definition at line 1428 of file af_aiir.c.

AVFILTER_DEFINE_CLASS ( aiir  )

Variable Documentation

const char* format[] = { "%lf", "%lf %lfi", "%lf %lfr", "%lf %lfd", "%lf %lfi" }
static

Definition at line 399 of file af_aiir.c.

const AVFilterPad inputs[]
static
Initial value:
= {
{
.name = "default",
.filter_frame = filter_frame,
},
{ NULL }
}
#define NULL
Definition: coverity.c:32
static int filter_frame(AVFilterLink *inlink, AVFrame *in)
Definition: af_aiir.c:1315

Definition at line 1448 of file af_aiir.c.

const AVOption aiir_options[]
static

Definition at line 1461 of file af_aiir.c.

AVFilter ff_af_aiir
Initial value:
= {
.name = "aiir",
.description = NULL_IF_CONFIG_SMALL("Apply Infinite Impulse Response filter with supplied coefficients."),
.priv_size = sizeof(AudioIIRContext),
.priv_class = &aiir_class,
.init = init,
}
static av_cold int init(AVFilterContext *ctx)
Definition: af_aiir.c:1384
#define AVFILTER_FLAG_DYNAMIC_OUTPUTS
The number of the filter outputs is not determined just by AVFilter.outputs.
Definition: avfilter.h:112
static int query_formats(AVFilterContext *ctx)
Definition: af_aiir.c:79
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
Definition: internal.h:153
#define AVFILTER_FLAG_SLICE_THREADS
The filter supports multithreading by splitting frames into multiple parts and processing them concur...
Definition: avfilter.h:117
static av_cold void uninit(AVFilterContext *ctx)
Definition: af_aiir.c:1428
static const AVFilterPad inputs[]
Definition: af_aiir.c:1448
#define flags(name, subs,...)
Definition: cbs_av1.c:560

Definition at line 1501 of file af_aiir.c.