[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