# HG changeset patch # User michael # Date 1004495342 0 # Node ID 626bfabff1f5e3a53fe9b58ea4bfdb3a5b4f4e42 # Parent 52ed0baddd560084ee5b63dd63acdd9b79775a5f c speedup (x1, rk1 filters) diff -r 52ed0baddd56 -r 626bfabff1f5 libpostproc/postprocess.c --- a/libpostproc/postprocess.c Tue Oct 30 21:14:02 2001 +0000 +++ b/libpostproc/postprocess.c Wed Oct 31 02:29:02 2001 +0000 @@ -670,20 +670,19 @@ // const int l8= stride + l7; // const int l9= stride + l8; int x; + const int QP15= QP + (QP>>2); src+= stride*3; for(x=0; x>3; + src[x+l4] +=v>>1; + src[x+l5] -=v>>1; + src[x+l6] -=v>>3; } - src++; } #endif @@ -803,18 +802,19 @@ int b= src[l4] - src[l5]; int c= src[l5] - src[l6]; - int d= MAX(ABS(b) - (ABS(a) + ABS(c))/2, 0); + int d= ABS(b) - ((ABS(a) + ABS(c))>>1); + d= MAX(d, 0); if(d < QP) { int v = d * SIGN(-b); - src[l2] +=v/8; - src[l3] +=v/4; - src[l4] +=3*v/8; - src[l5] -=3*v/8; - src[l6] -=v/4; - src[l7] -=v/8; + src[l2] +=v>>3; + src[l3] +=v>>2; + src[l4] +=(3*v)>>3; + src[l5] -=(3*v)>>3; + src[l6] -=v>>2; + src[l7] -=v>>3; } src++; diff -r 52ed0baddd56 -r 626bfabff1f5 libpostproc/postprocess_template.c --- a/libpostproc/postprocess_template.c Tue Oct 30 21:14:02 2001 +0000 +++ b/libpostproc/postprocess_template.c Wed Oct 31 02:29:02 2001 +0000 @@ -670,20 +670,19 @@ // const int l8= stride + l7; // const int l9= stride + l8; int x; + const int QP15= QP + (QP>>2); src+= stride*3; for(x=0; x>3; + src[x+l4] +=v>>1; + src[x+l5] -=v>>1; + src[x+l6] -=v>>3; } - src++; } #endif @@ -803,18 +802,19 @@ int b= src[l4] - src[l5]; int c= src[l5] - src[l6]; - int d= MAX(ABS(b) - (ABS(a) + ABS(c))/2, 0); + int d= ABS(b) - ((ABS(a) + ABS(c))>>1); + d= MAX(d, 0); if(d < QP) { int v = d * SIGN(-b); - src[l2] +=v/8; - src[l3] +=v/4; - src[l4] +=3*v/8; - src[l5] -=3*v/8; - src[l6] -=v/4; - src[l7] -=v/8; + src[l2] +=v>>3; + src[l3] +=v>>2; + src[l4] +=(3*v)>>3; + src[l5] -=(3*v)>>3; + src[l6] -=v>>2; + src[l7] -=v>>3; } src++;