From f36628b8fe6e6c274f55b4de30ae8bb6b0dc4452 Mon Sep 17 00:00:00 2001 From: anders Date: Tue, 15 Jan 2002 13:21:45 +0000 Subject: [PATCH] Sync problem when using fractional resampling fixed + speed increased. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@4172 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libao2/fir.h | 2 +- libao2/pl_resample.c | 135 +++++++++++++++++++++++++++++-------------- 2 files changed, 93 insertions(+), 44 deletions(-) diff --git a/libao2/fir.h b/libao2/fir.h index 9046e3dc0f..17ccb9b343 100644 --- a/libao2/fir.h +++ b/libao2/fir.h @@ -111,7 +111,7 @@ #define SAVE_QUE(x) #define UPDATE_QUE(inm) \ xi=(--xi)&(L-1); \ - x[xi]=x[xi+L]=*inm; + x[xi]=x[xi+L]=*(inm); #ifdef L4 #define FIR(x,w,y) \ diff --git a/libao2/pl_resample.c b/libao2/pl_resample.c index e4f5bf7cc4..e7b2e21d21 100644 --- a/libao2/pl_resample.c +++ b/libao2/pl_resample.c @@ -24,7 +24,7 @@ #include "audio_plugin.h" #include "audio_plugin_internal.h" #include "afmt.h" -//#include "../config.h" +// #include "../config.h" static ao_info_t info = { @@ -46,15 +46,16 @@ LIBAO_PLUGIN_EXTERN(resample) memory usage. For now the filterlenght is choosen to 4 and without assembly optimization if no SSE is present. */ -#ifdef HAVE_SSE + +// #ifdef HAVE_SSE #define L8 1 // Filter bank type #define W W8 // Filter bank parameters #define L 8 // Filter length -#else -#define L4 1 -#define W W4 -#define L 4 -#endif +// #else +// #define L4 1 +// #define W W4 +// #define L 4 +// #endif #define CH 6 // Max number of channels #define UP 128 /* Up sampling factor. Increasing this value will @@ -73,12 +74,11 @@ typedef struct pl_resample_s uint16_t up; // Up sampling factor int channels; // Number of channels int len; // Lenght of buffer - int bypass; // Bypass this plugin int16_t ws[UP*L]; // List of all available filters int16_t xs[CH][L*2]; // Circular buffers } pl_resample_t; -static pl_resample_t pl_resample = {NULL,NULL,1,1,1,0,0,W}; +static pl_resample_t pl_resample = {NULL,NULL,1,1,1,0,W}; // to set/get/query special features/parameters static int control(int cmd,int arg){ @@ -117,11 +117,7 @@ static int init(){ return 0; } pl_resample.dn=(int)(0.5+((float)(fin*pl_resample.up))/((float)fout)); - if(pl_resample.dn == pl_resample.up){ - fprintf(stderr,"[pl_resample] Fin is too close to fout no conversion is needed.\n"); - pl_resample.bypass=1; - return 1; - } + pl_resample.channels=ao_plugin_data.channels; if(ao_plugin_data.channels>CH){ fprintf(stderr,"[pl_resample] Too many channels, max is 6.\n"); @@ -155,12 +151,79 @@ static void reset(){ // called for every block of data // FIXME: this routine needs to be optimized (it is probably possible to do a lot here) static int play(){ + if(pl_resample.up==pl_resample.dn){ + register int16_t* in = ((int16_t*)ao_plugin_data.data); + register int16_t* end = in+ao_plugin_data.len/2; + while(in < end) *in=(*in++)>>1; + return 1; + } + if(pl_resample.up>pl_resample.dn) + return upsample(); + if(pl_resample.up= end) goto L2; - if(i) goto L1; - L2: if(i) goto L5; - i=inc; + UPDATE_QUE(in); + in+=nch; + + if(!--i){ + // Run the FIR filter + FIR((&x[xi]),(&pl_resample.w[wi*L]),out); + len++; out+=nch; - /* Get the correct polyphase component and the correct startpoint - in the circular bufer and run the FIR filter */ - FIR((&x[xi]),(&pl_resample.w[wi*L]),out); - len++; - out+=nch; + // Update wi to point at the correct polyphase component + wi=(wi+dn)%up; + + // Insert i number of new samples in queue + i = inc; + if(wi