# HG changeset patch # User kostya # Date 1163743953 0 # Node ID ff9a94fce87995bbd03f399f88e312faf866de44 # Parent 6f6fe05712e4e305a88f1be82f30e5f7163f29aa Optimize overlapping Suggested by Skal, sprintf(mail, "skal%d@orange.fr", 0xFFFF) diff -r 6f6fe05712e4 -r ff9a94fce879 vc1dsp.c --- a/vc1dsp.c Fri Nov 17 06:10:52 2006 +0000 +++ b/vc1dsp.c Fri Nov 17 06:12:33 2006 +0000 @@ -35,16 +35,19 @@ { int i; int a, b, c, d; + int d1, d2; for(i = 0; i < 8; i++) { a = src[-2*stride]; b = src[-stride]; c = src[0]; d = src[stride]; + d1 = (a - d + 3 + rnd) >> 3; + d2 = (a - d + b - c + 4 - rnd) >> 3; - src[-2*stride] = clip_uint8((7*a + d + 4 - rnd) >> 3); - src[-stride] = clip_uint8((-a + 7*b + c + d + 3 + rnd) >> 3); - src[0] = clip_uint8((a + b + 7*c - d + 4 - rnd) >> 3); - src[stride] = clip_uint8((a + 7*d + 3 + rnd) >> 3); + src[-2*stride] = a - d1; + src[-stride] = b - d2; + src[0] = c + d2; + src[stride] = d + d1; src++; } } @@ -55,16 +58,19 @@ { int i; int a, b, c, d; + int d1, d2; for(i = 0; i < 8; i++) { a = src[-2]; b = src[-1]; c = src[0]; d = src[1]; + d1 = (a - d + 3 + rnd) >> 3; + d2 = (a - d + b - c + 4 - rnd) >> 3; - src[-2] = clip_uint8((7*a + d + 4 - rnd) >> 3); - src[-1] = clip_uint8((-a + 7*b + c + d + 3 + rnd) >> 3); - src[0] = clip_uint8((a + b + 7*c - d + 4 - rnd) >> 3); - src[1] = clip_uint8((a + 7*d + 3 + rnd) >> 3); + src[-2] = a - d1; + src[-1] = b - d2; + src[0] = c + d2; + src[1] = d + d1; src += stride; } }