OSDN Git Service

Add av_clipf() function to common.h and use it in ra288.c
authorVitor Sessak <vitor1001@gmail.com>
Sun, 13 Jul 2008 19:59:44 +0000 (19:59 +0000)
committerVitor Sessak <vitor1001@gmail.com>
Sun, 13 Jul 2008 19:59:44 +0000 (19:59 +0000)
Originally committed as revision 14213 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/ra288.c
libavutil/common.h

index 72ed810..57ee6c2 100644 (file)
@@ -88,14 +88,8 @@ static void decode(Real288_internal *glob, float gain, int cb_coef)
 
     /* output */
     for (x=0; x < 5; x++) {
-        float f = glob->sb[4-x] + buffer[x];
-
-        if (f > 4095)
-            f = 4095;
-        else if (f < -4095)
-            f = -4095;
-
-        glob->output[glob->phase*5+x] = glob->sb[4-x] = f;
+        glob->output[glob->phase*5+x] = glob->sb[4-x] =
+            av_clipf(glob->sb[4-x] + buffer[x], -4095, 4095);
     }
 }
 
index 5a56832..696b03e 100644 (file)
@@ -225,6 +225,20 @@ static inline av_const int16_t av_clip_int16(int a)
     else                    return a;
 }
 
+/**
+ * clip a float value into the amin-amax range
+ * @param a value to clip
+ * @param amin minimum value of the clip range
+ * @param amax maximum value of the clip range
+ * @return clipped value
+ */
+static inline av_const float av_clipf(float a, float amin, float amax)
+{
+    if      (a < amin) return amin;
+    else if (a > amax) return amax;
+    else               return a;
+}
+
 /* math */
 int64_t av_const ff_gcd(int64_t a, int64_t b);