2022-05-14 10:28:49 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2017 Paul B Mahol
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef AVFILTER_AFIR_H
|
|
|
|
#define AVFILTER_AFIR_H
|
|
|
|
|
|
|
|
#include "libavutil/float_dsp.h"
|
|
|
|
#include "libavutil/frame.h"
|
|
|
|
#include "libavutil/rational.h"
|
|
|
|
#include "libavutil/tx.h"
|
|
|
|
#include "avfilter.h"
|
|
|
|
#include "af_afirdsp.h"
|
|
|
|
|
2022-12-31 23:31:31 +01:00
|
|
|
#define MAX_IR_STREAMS 32
|
|
|
|
|
2022-05-14 10:28:49 +02:00
|
|
|
typedef struct AudioFIRSegment {
|
|
|
|
int nb_partitions;
|
|
|
|
int part_size;
|
|
|
|
int block_size;
|
|
|
|
int fft_length;
|
|
|
|
int coeff_size;
|
|
|
|
int input_size;
|
|
|
|
int input_offset;
|
|
|
|
|
|
|
|
int *output_offset;
|
|
|
|
int *part_index;
|
|
|
|
|
|
|
|
AVFrame *sumin;
|
|
|
|
AVFrame *sumout;
|
|
|
|
AVFrame *blockout;
|
2022-12-13 11:46:02 +01:00
|
|
|
AVFrame *tempin;
|
|
|
|
AVFrame *tempout;
|
2022-05-14 10:28:49 +02:00
|
|
|
AVFrame *buffer;
|
2023-04-23 23:30:42 +02:00
|
|
|
AVFrame *coeff;
|
2022-05-14 10:28:49 +02:00
|
|
|
AVFrame *input;
|
|
|
|
AVFrame *output;
|
|
|
|
|
2022-12-13 11:46:02 +01:00
|
|
|
AVTXContext **ctx, **tx, **itx;
|
2022-12-12 01:55:06 +01:00
|
|
|
av_tx_fn ctx_fn, tx_fn, itx_fn;
|
2022-05-14 10:28:49 +02:00
|
|
|
} AudioFIRSegment;
|
|
|
|
|
|
|
|
typedef struct AudioFIRContext {
|
|
|
|
const AVClass *class;
|
|
|
|
|
|
|
|
float wet_gain;
|
|
|
|
float dry_gain;
|
|
|
|
float length;
|
|
|
|
int gtype;
|
2023-11-18 00:36:18 +01:00
|
|
|
float ir_norm;
|
|
|
|
float ir_link;
|
2022-05-14 10:28:49 +02:00
|
|
|
float ir_gain;
|
|
|
|
int ir_format;
|
2023-04-25 15:42:44 +02:00
|
|
|
int ir_load;
|
2022-05-14 10:28:49 +02:00
|
|
|
float max_ir_len;
|
|
|
|
int response;
|
|
|
|
int w, h;
|
|
|
|
AVRational frame_rate;
|
|
|
|
int ir_channel;
|
|
|
|
int minp;
|
|
|
|
int maxp;
|
|
|
|
int nb_irs;
|
2022-12-13 11:46:02 +01:00
|
|
|
int prev_selir;
|
2022-05-14 10:28:49 +02:00
|
|
|
int selir;
|
|
|
|
int precision;
|
|
|
|
int format;
|
|
|
|
|
2022-12-13 11:46:02 +01:00
|
|
|
int eof_coeffs[MAX_IR_STREAMS];
|
|
|
|
int have_coeffs[MAX_IR_STREAMS];
|
|
|
|
int nb_taps[MAX_IR_STREAMS];
|
2023-04-23 23:30:42 +02:00
|
|
|
int nb_segments[MAX_IR_STREAMS];
|
|
|
|
int max_offset[MAX_IR_STREAMS];
|
2022-05-14 10:28:49 +02:00
|
|
|
int nb_channels;
|
|
|
|
int one2many;
|
2023-11-19 21:26:00 +01:00
|
|
|
int prev_is_disabled;
|
2023-04-23 23:30:42 +02:00
|
|
|
int *loading;
|
2023-11-18 00:36:18 +01:00
|
|
|
double *ch_gain;
|
2022-05-14 10:28:49 +02:00
|
|
|
|
2023-04-23 23:30:42 +02:00
|
|
|
AudioFIRSegment seg[MAX_IR_STREAMS][1024];
|
2022-05-14 10:28:49 +02:00
|
|
|
|
|
|
|
AVFrame *in;
|
2023-04-24 17:31:18 +02:00
|
|
|
AVFrame *xfade[2];
|
2023-04-25 15:21:51 +02:00
|
|
|
AVFrame *fadein[2];
|
2022-12-13 11:46:02 +01:00
|
|
|
AVFrame *ir[MAX_IR_STREAMS];
|
2022-12-31 23:31:31 +01:00
|
|
|
AVFrame *norm_ir[MAX_IR_STREAMS];
|
2022-05-14 10:28:49 +02:00
|
|
|
int min_part_size;
|
2023-04-25 15:21:51 +02:00
|
|
|
int max_part_size;
|
2022-05-14 10:28:49 +02:00
|
|
|
int64_t pts;
|
|
|
|
|
|
|
|
AudioFIRDSPContext afirdsp;
|
|
|
|
AVFloatDSPContext *fdsp;
|
|
|
|
} AudioFIRContext;
|
|
|
|
|
|
|
|
#endif /* AVFILTER_AFIR_H */
|