Mercurial > libavcodec.hg
changeset 6852:84dc84916bab libavcodec
Simplify eq()
author | vitor |
---|---|
date | Sat, 24 May 2008 12:33:00 +0000 |
parents | c225307f241d |
children | 9bfb69f1739e |
files | ra144.c |
diffstat | 1 files changed, 12 insertions(+), 29 deletions(-) [+] |
line wrap: on
line diff
--- a/ra144.c Sat May 24 09:20:09 2008 +0000 +++ b/ra144.c Sat May 24 12:33:00 2008 +0000 @@ -252,37 +252,23 @@ static int eq(const short *in, int *target) { - int retval; - int a; - int b; - int c; + int retval = 0; + int b, c, i; unsigned int u; - const short *sptr; - int *ptr1, *ptr2, *ptr3; - int *bp1, *bp2; int buffer1[10]; int buffer2[10]; - - retval = 0; - bp1 = buffer1; - bp2 = buffer2; - ptr2 = (ptr3 = buffer2) + 9; - sptr = in; + int *bp1 = buffer1; + int *bp2 = buffer2; - while (ptr2 >= ptr3) - *(ptr3++) = *(sptr++); + for (i=0; i < 10; i++) + buffer2[i] = in[i]; - target += 9; - a = bp2[9]; - *target = a; + u = target[9] = bp2[9]; - if (a + 0x1000 > 0x1fff) + if (u + 0x1000 > 0x1fff) return 0; /* We're screwed, might as well go out with a bang. :P */ - c = 8; - u = a; - - while (c >= 0) { + for (c=8; c >= 0; c--) { if (u == 0x1000) u++; @@ -294,13 +280,10 @@ if (b == 0) b++; - ptr2 = bp1; - ptr1 = (ptr3 = bp2) + c; + for (u=0; u<=c; u++) + bp1[u] = ((bp2[u] - ((target[c+1] * bp2[c-u]) >> 12)) * (0x1000000 / b)) >> 12; - for (u=0; u<=c; u++) - *(ptr2++) = ((*(ptr3++) - (((*target) * (*(ptr1--))) >> 12)) * (0x1000000 / b)) >> 12; - - *(--target) = u = bp1[(c--)]; + target[c] = u = bp1[c]; if ((u + 0x1000) > 0x1fff) retval = 1;