2012-03-23 17:42:17 -04:00
/*
* Copyright ( c ) 2012 Justin Ruggles < justin . ruggles @ gmail . com >
*
2013-08-15 23:12:51 +02:00
* This file is part of FFmpeg .
2012-03-23 17:42:17 -04:00
*
2013-08-15 23:12:51 +02:00
* FFmpeg is free software ; you can redistribute it and / or
2012-03-23 17:42:17 -04:00
* 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 .
*
2013-08-15 23:12:51 +02:00
* FFmpeg is distributed in the hope that it will be useful ,
2012-03-23 17:42:17 -04:00
* 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
2013-08-15 23:12:51 +02:00
* License along with FFmpeg ; if not , write to the Free Software
2012-03-23 17:42:17 -04:00
* Foundation , Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 USA
*/
# include "libavutil/mathematics.h"
2012-08-06 16:49:32 +03:00
# include "libavutil/mem.h"
2012-03-23 17:42:17 -04:00
# include "libavutil/opt.h"
# include "avresample.h"
# include "internal.h"
# include "audio_mix.h"
/**
* @ file
* Options definition for AVAudioResampleContext .
*/
# define OFFSET(x) offsetof(AVAudioResampleContext, x)
# define PARAM AV_OPT_FLAG_AUDIO_PARAM
2013-08-01 14:35:01 +02:00
static const AVOption avresample_options [ ] = {
2012-08-22 10:07:54 +02:00
{ " in_channel_layout " , " Input Channel Layout " , OFFSET ( in_channel_layout ) , AV_OPT_TYPE_INT64 , { . i64 = 0 } , INT64_MIN , INT64_MAX , PARAM } ,
2012-08-31 13:22:31 +03:00
{ " in_sample_fmt " , " Input Sample Format " , OFFSET ( in_sample_fmt ) , AV_OPT_TYPE_INT , { . i64 = AV_SAMPLE_FMT_S16 } , AV_SAMPLE_FMT_U8 , AV_SAMPLE_FMT_NB - 1 , PARAM } ,
{ " in_sample_rate " , " Input Sample Rate " , OFFSET ( in_sample_rate ) , AV_OPT_TYPE_INT , { . i64 = 48000 } , 1 , INT_MAX , PARAM } ,
2012-08-22 10:07:54 +02:00
{ " out_channel_layout " , " Output Channel Layout " , OFFSET ( out_channel_layout ) , AV_OPT_TYPE_INT64 , { . i64 = 0 } , INT64_MIN , INT64_MAX , PARAM } ,
2012-08-31 13:22:31 +03:00
{ " out_sample_fmt " , " Output Sample Format " , OFFSET ( out_sample_fmt ) , AV_OPT_TYPE_INT , { . i64 = AV_SAMPLE_FMT_S16 } , AV_SAMPLE_FMT_U8 , AV_SAMPLE_FMT_NB - 1 , PARAM } ,
{ " out_sample_rate " , " Output Sample Rate " , OFFSET ( out_sample_rate ) , AV_OPT_TYPE_INT , { . i64 = 48000 } , 1 , INT_MAX , PARAM } ,
2013-01-02 16:47:28 -05:00
{ " internal_sample_fmt " , " Internal Sample Format " , OFFSET ( internal_sample_fmt ) , AV_OPT_TYPE_INT , { . i64 = AV_SAMPLE_FMT_NONE } , AV_SAMPLE_FMT_NONE , AV_SAMPLE_FMT_NB - 1 , PARAM , " internal_sample_fmt " } ,
{ " u8 " , " 8-bit unsigned integer " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_U8 } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " s16 " , " 16-bit signed integer " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_S16 } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " s32 " , " 32-bit signed integer " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_S32 } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " flt " , " 32-bit float " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_FLT } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " dbl " , " 64-bit double " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_DBL } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " u8p " , " 8-bit unsigned integer planar " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_U8P } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " s16p " , " 16-bit signed integer planar " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_S16P } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " s32p " , " 32-bit signed integer planar " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_S32P } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " fltp " , " 32-bit float planar " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_FLTP } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
{ " dblp " , " 64-bit double planar " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_SAMPLE_FMT_DBLP } , INT_MIN , INT_MAX , PARAM , " internal_sample_fmt " } ,
2012-08-31 13:22:31 +03:00
{ " mix_coeff_type " , " Mixing Coefficient Type " , OFFSET ( mix_coeff_type ) , AV_OPT_TYPE_INT , { . i64 = AV_MIX_COEFF_TYPE_FLT } , AV_MIX_COEFF_TYPE_Q8 , AV_MIX_COEFF_TYPE_NB - 1 , PARAM , " mix_coeff_type " } ,
2012-08-31 12:45:52 +03:00
{ " q8 " , " 16-bit 8.8 Fixed-Point " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_MIX_COEFF_TYPE_Q8 } , INT_MIN , INT_MAX , PARAM , " mix_coeff_type " } ,
{ " q15 " , " 32-bit 17.15 Fixed-Point " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_MIX_COEFF_TYPE_Q15 } , INT_MIN , INT_MAX , PARAM , " mix_coeff_type " } ,
{ " flt " , " Floating-Point " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_MIX_COEFF_TYPE_FLT } , INT_MIN , INT_MAX , PARAM , " mix_coeff_type " } ,
2012-08-31 13:34:23 +03:00
{ " center_mix_level " , " Center Mix Level " , OFFSET ( center_mix_level ) , AV_OPT_TYPE_DOUBLE , { . dbl = M_SQRT1_2 } , - 32.0 , 32.0 , PARAM } ,
{ " surround_mix_level " , " Surround Mix Level " , OFFSET ( surround_mix_level ) , AV_OPT_TYPE_DOUBLE , { . dbl = M_SQRT1_2 } , - 32.0 , 32.0 , PARAM } ,
{ " lfe_mix_level " , " LFE Mix Level " , OFFSET ( lfe_mix_level ) , AV_OPT_TYPE_DOUBLE , { . dbl = 0.0 } , - 32.0 , 32.0 , PARAM } ,
2012-08-31 13:22:31 +03:00
{ " normalize_mix_level " , " Normalize Mix Level " , OFFSET ( normalize_mix_level ) , AV_OPT_TYPE_INT , { . i64 = 1 } , 0 , 1 , PARAM } ,
{ " force_resampling " , " Force Resampling " , OFFSET ( force_resampling ) , AV_OPT_TYPE_INT , { . i64 = 0 } , 0 , 1 , PARAM } ,
{ " filter_size " , " Resampling Filter Size " , OFFSET ( filter_size ) , AV_OPT_TYPE_INT , { . i64 = 16 } , 0 , 32 , /* ??? */ PARAM } ,
{ " phase_shift " , " Resampling Phase Shift " , OFFSET ( phase_shift ) , AV_OPT_TYPE_INT , { . i64 = 10 } , 0 , 30 , /* ??? */ PARAM } ,
{ " linear_interp " , " Use Linear Interpolation " , OFFSET ( linear_interp ) , AV_OPT_TYPE_INT , { . i64 = 0 } , 0 , 1 , PARAM } ,
2012-08-31 13:34:23 +03:00
{ " cutoff " , " Cutoff Frequency Ratio " , OFFSET ( cutoff ) , AV_OPT_TYPE_DOUBLE , { . dbl = 0.8 } , 0.0 , 1.0 , PARAM } ,
2012-12-18 21:52:58 -05:00
/* duplicate option in order to work with avconv */
{ " resample_cutoff " , " Cutoff Frequency Ratio " , OFFSET ( cutoff ) , AV_OPT_TYPE_DOUBLE , { . dbl = 0.8 } , 0.0 , 1.0 , PARAM } ,
2012-08-31 13:22:31 +03:00
{ " matrix_encoding " , " Matrixed Stereo Encoding " , OFFSET ( matrix_encoding ) , AV_OPT_TYPE_INT , { . i64 = AV_MATRIX_ENCODING_NONE } , AV_MATRIX_ENCODING_NONE , AV_MATRIX_ENCODING_NB - 1 , PARAM , " matrix_encoding " } ,
2012-08-31 12:45:52 +03:00
{ " none " , " None " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_MATRIX_ENCODING_NONE } , INT_MIN , INT_MAX , PARAM , " matrix_encoding " } ,
{ " dolby " , " Dolby " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_MATRIX_ENCODING_DOLBY } , INT_MIN , INT_MAX , PARAM , " matrix_encoding " } ,
{ " dplii " , " Dolby Pro Logic II " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_MATRIX_ENCODING_DPLII } , INT_MIN , INT_MAX , PARAM , " matrix_encoding " } ,
2012-08-31 13:22:31 +03:00
{ " filter_type " , " Filter Type " , OFFSET ( filter_type ) , AV_OPT_TYPE_INT , { . i64 = AV_RESAMPLE_FILTER_TYPE_KAISER } , AV_RESAMPLE_FILTER_TYPE_CUBIC , AV_RESAMPLE_FILTER_TYPE_KAISER , PARAM , " filter_type " } ,
2012-08-31 12:45:52 +03:00
{ " cubic " , " Cubic " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_FILTER_TYPE_CUBIC } , INT_MIN , INT_MAX , PARAM , " filter_type " } ,
{ " blackman_nuttall " , " Blackman Nuttall Windowed Sinc " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_FILTER_TYPE_BLACKMAN_NUTTALL } , INT_MIN , INT_MAX , PARAM , " filter_type " } ,
{ " kaiser " , " Kaiser Windowed Sinc " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_FILTER_TYPE_KAISER } , INT_MIN , INT_MAX , PARAM , " filter_type " } ,
2012-08-31 13:22:31 +03:00
{ " kaiser_beta " , " Kaiser Window Beta " , OFFSET ( kaiser_beta ) , AV_OPT_TYPE_INT , { . i64 = 9 } , 2 , 16 , PARAM } ,
2012-10-31 15:40:12 -04:00
{ " dither_method " , " Dither Method " , OFFSET ( dither_method ) , AV_OPT_TYPE_INT , { . i64 = AV_RESAMPLE_DITHER_NONE } , 0 , AV_RESAMPLE_DITHER_NB - 1 , PARAM , " dither_method " } ,
{ " none " , " No Dithering " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_DITHER_NONE } , INT_MIN , INT_MAX , PARAM , " dither_method " } ,
{ " rectangular " , " Rectangular Dither " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_DITHER_RECTANGULAR } , INT_MIN , INT_MAX , PARAM , " dither_method " } ,
{ " triangular " , " Triangular Dither " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_DITHER_TRIANGULAR } , INT_MIN , INT_MAX , PARAM , " dither_method " } ,
{ " triangular_hp " , " Triangular Dither With High Pass " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_DITHER_TRIANGULAR_HP } , INT_MIN , INT_MAX , PARAM , " dither_method " } ,
{ " triangular_ns " , " Triangular Dither With Noise Shaping " , 0 , AV_OPT_TYPE_CONST , { . i64 = AV_RESAMPLE_DITHER_TRIANGULAR_NS } , INT_MIN , INT_MAX , PARAM , " dither_method " } ,
2012-03-23 17:42:17 -04:00
{ NULL } ,
} ;
static const AVClass av_resample_context_class = {
. class_name = " AVAudioResampleContext " ,
. item_name = av_default_item_name ,
2013-08-01 14:35:01 +02:00
. option = avresample_options ,
2012-03-23 17:42:17 -04:00
. version = LIBAVUTIL_VERSION_INT ,
} ;
AVAudioResampleContext * avresample_alloc_context ( void )
{
AVAudioResampleContext * avr ;
avr = av_mallocz ( sizeof ( * avr ) ) ;
if ( ! avr )
return NULL ;
avr - > av_class = & av_resample_context_class ;
av_opt_set_defaults ( avr ) ;
return avr ;
}
const AVClass * avresample_get_class ( void )
{
return & av_resample_context_class ;
}