Add av_compare_mod()
authorMichael Niedermayer <michaelni@gmx.at>
Wed, 9 Jun 2010 17:27:42 +0000 (17:27 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Wed, 9 Jun 2010 17:27:42 +0000 (17:27 +0000)
Originally committed as revision 23551 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavutil/mathematics.c
libavutil/mathematics.h

index c06cb16..00b81f1 100644 (file)
@@ -144,6 +144,13 @@ int av_compare_ts(int64_t ts_a, AVRational tb_a, int64_t ts_b, AVRational tb_b){
     return 0;
 }
 
+int64_t av_compare_mod(uint64_t a, uint64_t b, uint64_t mod){
+    int64_t c= (a-b) & (mod-1);
+    if(c > (mod>>1))
+        c-= mod;
+    return c;
+}
+
 #ifdef TEST
 #include "integer.h"
 #undef printf
index e198aef..889ce95 100644 (file)
@@ -94,5 +94,14 @@ int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq) av_const;
  */
 int av_compare_ts(int64_t ts_a, AVRational tb_a, int64_t ts_b, AVRational tb_b);
 
+/**
+ * Compare 2 integers modulo mod.
+ * That is we compare integers a and b for which only the least significant log2(mod) bits are known
+ * @param mod must be a power of 2
+ * @returns a negative value if a is smaller than b
+ *          a positiv  value if a is greater than b
+ *          0                if a equals          b
+ */
+int64_t av_compare_mod(uint64_t a, uint64_t b, uint64_t mod);
 
 #endif /* AVUTIL_MATHEMATICS_H */