[SCM] libav/experimental: Simplify implicit_weight table init.

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 17:02:33 UTC 2013


The following commit has been merged in the experimental branch:
commit 72f86ec013714d15cdef4e9e541ab87f34b670ec
Author: Michael Niedermayer <michaelni at gmx.at>
Date:   Wed Mar 3 10:57:38 2010 +0000

    Simplify implicit_weight table init.
    
    Originally committed as revision 22168 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavcodec/h264.c b/libavcodec/h264.c
index 15c4147..0bc8739 100644
--- a/libavcodec/h264.c
+++ b/libavcodec/h264.c
@@ -1435,16 +1435,14 @@ static void implicit_weight_table(H264Context *h){
         for(ref1=0; ref1 < h->ref_count[1]; ref1++){
             int poc1 = h->ref_list[1][ref1].poc;
             int td = av_clip(poc1 - poc0, -128, 127);
+            h->implicit_weight[ref0][ref1] = 32;
             if(td){
                 int tb = av_clip(cur_poc - poc0, -128, 127);
                 int tx = (16384 + (FFABS(td) >> 1)) / td;
-                int dist_scale_factor = av_clip((tb*tx + 32) >> 6, -1024, 1023) >> 2;
-                if(dist_scale_factor < -64 || dist_scale_factor > 128)
-                    h->implicit_weight[ref0][ref1] = 32;
-                else
+                int dist_scale_factor = (tb*tx + 32) >> 8;
+                if(dist_scale_factor >= -64 && dist_scale_factor <= 128)
                     h->implicit_weight[ref0][ref1] = 64 - dist_scale_factor;
-            }else
-                h->implicit_weight[ref0][ref1] = 32;
+            }
         }
     }
 }

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list