diff options
author | Justin Ruggles <justin.ruggles@gmail.com> | 2009-10-17 21:00:39 +0000 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2009-10-17 21:00:39 +0000 |
commit | fde82ca7e4e72226da99d86a9fa9689136461d14 (patch) | |
tree | 5060829d8c5971a2edae793e05d28895a06dbdcf /libavcodec/flacenc.c | |
parent | a4cb675124a906126ba4ab307f0c17716f6d9adb (diff) | |
download | ffmpeg-fde82ca7e4e72226da99d86a9fa9689136461d14.tar.gz |
Move autocorrelation function from flacenc.c to lpc.c. Also rename the
corresponding dsputil functions and remove their dependency on the FLAC
encoder.
Fixes Issue1486.
Originally committed as revision 20266 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/flacenc.c')
-rw-r--r-- | libavcodec/flacenc.c | 63 |
1 files changed, 0 insertions, 63 deletions
diff --git a/libavcodec/flacenc.c b/libavcodec/flacenc.c index 81a35a0d54..c1f862a684 100644 --- a/libavcodec/flacenc.c +++ b/libavcodec/flacenc.c @@ -552,69 +552,6 @@ static uint32_t calc_rice_params_lpc(RiceContext *rc, int pmin, int pmax, return bits; } -/** - * Apply Welch window function to audio block - */ -static void apply_welch_window(const int32_t *data, int len, double *w_data) -{ - int i, n2; - double w; - double c; - - assert(!(len&1)); //the optimization in r11881 does not support odd len - //if someone wants odd len extend the change in r11881 - - n2 = (len >> 1); - c = 2.0 / (len - 1.0); - - w_data+=n2; - data+=n2; - for(i=0; i<n2; i++) { - w = c - n2 + i; - w = 1.0 - (w * w); - w_data[-i-1] = data[-i-1] * w; - w_data[+i ] = data[+i ] * w; - } -} - -/** - * Calculates autocorrelation data from audio samples - * A Welch window function is applied before calculation. - */ -void ff_flac_compute_autocorr(const int32_t *data, int len, int lag, - double *autoc) -{ - int i, j; - double tmp[len + lag + 1]; - double *data1= tmp + lag; - - apply_welch_window(data, len, data1); - - for(j=0; j<lag; j++) - data1[j-lag]= 0.0; - data1[len] = 0.0; - - for(j=0; j<lag; j+=2){ - double sum0 = 1.0, sum1 = 1.0; - for(i=j; i<len; i++){ - sum0 += data1[i] * data1[i-j]; - sum1 += data1[i] * data1[i-j-1]; - } - autoc[j ] = sum0; - autoc[j+1] = sum1; - } - - if(j==lag){ - double sum = 1.0; - for(i=j-1; i<len; i+=2){ - sum += data1[i ] * data1[i-j ] - + data1[i+1] * data1[i-j+1]; - } - autoc[j] = sum; - } -} - - static void encode_residual_verbatim(int32_t *res, int32_t *smp, int n) { assert(n > 0); |