[FFmpeg-cvslog] ac3enc: use MUL64() to multiply fixed-point coefficients
Justin Ruggles
git
Tue Mar 8 20:01:40 CET 2011
ffmpeg | branch: master | Justin Ruggles <justin.ruggles at gmail.com> | Tue Mar 8 13:18:55 2011 -0500| [67fc32ac6197a7fe265795d0bf60bf704464394e] | committer: Michael Niedermayer
ac3enc: use MUL64() to multiply fixed-point coefficients
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=67fc32ac6197a7fe265795d0bf60bf704464394e
---
libavcodec/ac3enc.c | 8 ++++----
libavcodec/ac3enc_fixed.h | 2 ++
libavcodec/ac3enc_float.h | 2 ++
3 files changed, 8 insertions(+), 4 deletions(-)
diff --git a/libavcodec/ac3enc.c b/libavcodec/ac3enc.c
index baa9597..e792eaf 100644
--- a/libavcodec/ac3enc.c
+++ b/libavcodec/ac3enc.c
@@ -328,10 +328,10 @@ static void compute_rematrixing_strategy(AC3EncodeContext *s)
CoefType rt = block->mdct_coef[1][i];
CoefType md = lt + rt;
CoefType sd = lt - rt;
- sum[0] += lt * lt;
- sum[1] += rt * rt;
- sum[2] += md * md;
- sum[3] += sd * sd;
+ sum[0] += MUL_COEF(lt, lt);
+ sum[1] += MUL_COEF(rt, rt);
+ sum[2] += MUL_COEF(md, md);
+ sum[3] += MUL_COEF(sd, sd);
}
/* compare sums to determine if rematrixing will be used for this band */
diff --git a/libavcodec/ac3enc_fixed.h b/libavcodec/ac3enc_fixed.h
index 12c8ace..773caec 100644
--- a/libavcodec/ac3enc_fixed.h
+++ b/libavcodec/ac3enc_fixed.h
@@ -36,6 +36,8 @@ typedef int16_t SampleType;
typedef int32_t CoefType;
typedef int64_t CoefSumType;
+#define MUL_COEF(a,b) MUL64(a,b)
+
/**
* Compex number.
diff --git a/libavcodec/ac3enc_float.h b/libavcodec/ac3enc_float.h
index 1726ca0..6ad22ec 100644
--- a/libavcodec/ac3enc_float.h
+++ b/libavcodec/ac3enc_float.h
@@ -36,6 +36,8 @@ typedef float SampleType;
typedef float CoefType;
typedef float CoefSumType;
+#define MUL_COEF(a,b) ((a)*(b))
+
typedef struct AC3MDCTContext {
const float *window; ///< MDCT window function
More information about the ffmpeg-cvslog
mailing list