diff options
author | Christophe Gisquet | 2014-02-14 16:00:47 +0000 |
---|---|---|
committer | Michael Niedermayer | 2014-02-15 20:08:08 +0100 |
commit | 9ae8e23188fc2e533eea74757c9060557941d3d9 (patch) | |
tree | 3cccacfa434bed22ee3d38f05014e3839fcd03c8 /libavcodec/dcadsp.c | |
parent | 5a48caa34b0c2a2641ea3bd522802fa1df2c8866 (diff) |
dcadsp: scan coefficients linearly instead.
This change is inspired by x86 asm, where this frees a register.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/dcadsp.c')
-rw-r--r-- | libavcodec/dcadsp.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/libavcodec/dcadsp.c b/libavcodec/dcadsp.c index b14c4350ef..65df2798ed 100644 --- a/libavcodec/dcadsp.c +++ b/libavcodec/dcadsp.c @@ -36,22 +36,22 @@ static inline void dca_lfe_fir(float *out, const float *in, const float *coefs, int decifactor, float scale) { - float *out2 = out + decifactor; + float *out2 = out + 2*decifactor-1; const float *cf0 = coefs; - const float *cf1 = coefs + 256; + int num_coeffs = 256 / decifactor; int j, k; /* One decimated sample generates 2*decifactor interpolated ones */ for (k = 0; k < decifactor; k++) { float v0 = 0.0; float v1 = 0.0; - for (j = 0; j < 256 / decifactor; j++) { - float s = in[-j]; - v0 += s * *cf0++; - v1 += s * *--cf1; + for (j = 0; j < num_coeffs; j++, cf0++) { + v0 += in[-j] * *cf0; + v1 += in[1+j-num_coeffs] * *cf0; + } *out++ = v0 * scale; - *out2++ = v1 * scale; + *out2-- = v1 * scale; } } |