[FFmpeg-cvslog] r26042 - trunk/libavcodec/ac3enc.c
jbr
subversion
Fri Dec 17 15:16:13 CET 2010
Author: jbr
Date: Fri Dec 17 15:16:13 2010
New Revision: 26042
Log:
Do not calculate psd and masking curve if exponents are being reused.
Approx. 20% faster in function bit_alloc_masking().
Modified:
trunk/libavcodec/ac3enc.c
Modified: trunk/libavcodec/ac3enc.c
==============================================================================
--- trunk/libavcodec/ac3enc.c Thu Dec 16 23:47:11 2010 (r26041)
+++ trunk/libavcodec/ac3enc.c Fri Dec 17 15:16:13 2010 (r26042)
@@ -964,11 +964,10 @@ static void bit_alloc_masking(AC3EncodeC
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
AC3Block *block = &s->blocks[blk];
for (ch = 0; ch < s->channels; ch++) {
- if (block->exp_strategy[ch] == EXP_REUSE) {
- AC3Block *block1 = &s->blocks[blk-1];
- memcpy(block->psd[ch], block1->psd[ch], AC3_MAX_COEFS*sizeof(block->psd[0][0]));
- memcpy(block->mask[ch], block1->mask[ch], AC3_CRITICAL_BANDS*sizeof(block->mask[0][0]));
- } else {
+ /* We only need psd and mask for calculating bap.
+ Since we currently do not calculate bap when exponent
+ strategy is EXP_REUSE we do not need to calculate psd or mask. */
+ if (block->exp_strategy[ch] != EXP_REUSE) {
ff_ac3_bit_alloc_calc_psd(block->exp[ch], 0,
s->nb_coefs[ch],
block->psd[ch], block->band_psd[ch]);
More information about the ffmpeg-cvslog
mailing list