mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-15 11:44:49 +00:00
b8c6e5a661
give high quality resampling as good as with linear_interp=on as fast as without linear_interp=on tested visually with ffplay ffplay -f lavfi "aevalsrc='sin(10000*t*t)', aresample=osr=48000, showcqt=gamma=5" ffplay -f lavfi "aevalsrc='sin(10000*t*t)', aresample=osr=48000:linear_interp=on, showcqt=gamma=5" ffplay -f lavfi "aevalsrc='sin(10000*t*t)', aresample=osr=48000:exact_rational=on, showcqt=gamma=5" slightly speed improvement for fair comparison with -cpuflags 0 audio.wav is ~ 1 hour 44100 stereo 16bit wav file ffmpeg -i audio.wav -af aresample=osr=48000 -f null - old new real 13.498s 13.121s user 13.364s 12.987s sys 0.131s 0.129s linear_interp=on old new real 23.035s 23.050s user 22.907s 22.917s sys 0.119s 0.125s exact_rational=on real 12.418s user 12.298s sys 0.114s possibility to decrease memory usage if soft compensation is ignored Signed-off-by: Muhammad Faiz <mfcc64@gmail.com>
68 lines
2.1 KiB
C
68 lines
2.1 KiB
C
/*
|
|
* audio resampling
|
|
* Copyright (c) 2004-2012 Michael Niedermayer <michaelni@gmx.at>
|
|
*
|
|
* 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 SWRESAMPLE_RESAMPLE_H
|
|
#define SWRESAMPLE_RESAMPLE_H
|
|
|
|
#include "libavutil/log.h"
|
|
#include "libavutil/samplefmt.h"
|
|
|
|
#include "swresample_internal.h"
|
|
|
|
typedef struct ResampleContext {
|
|
const AVClass *av_class;
|
|
uint8_t *filter_bank;
|
|
int filter_length;
|
|
int filter_alloc;
|
|
int ideal_dst_incr;
|
|
int dst_incr;
|
|
int dst_incr_div;
|
|
int dst_incr_mod;
|
|
int index;
|
|
int frac;
|
|
int src_incr;
|
|
int compensation_distance;
|
|
/* TODO remove phase_shift and phase_mask */
|
|
attribute_deprecated int phase_shift;
|
|
attribute_deprecated int phase_mask;
|
|
int phase_count;
|
|
int linear;
|
|
enum SwrFilterType filter_type;
|
|
double kaiser_beta;
|
|
double factor;
|
|
enum AVSampleFormat format;
|
|
int felem_size;
|
|
int filter_shift;
|
|
|
|
struct {
|
|
void (*resample_one)(void *dst, const void *src,
|
|
int n, int64_t index, int64_t incr);
|
|
int (*resample)(struct ResampleContext *c, void *dst,
|
|
const void *src, int n, int update_ctx);
|
|
} dsp;
|
|
} ResampleContext;
|
|
|
|
void swri_resample_dsp_init(ResampleContext *c);
|
|
void swri_resample_dsp_x86_init(ResampleContext *c);
|
|
void swri_resample_dsp_arm_init(ResampleContext *c);
|
|
|
|
#endif /* SWRESAMPLE_RESAMPLE_H */
|