Mercurial > libavcodec.hg
changeset 637:de12d5b9c9ad libavcodec
higher accuracy
author | michaelni |
---|---|
date | Sun, 01 Sep 2002 20:54:38 +0000 |
parents | 57b9a37546a0 |
children | 0012f75c92bb |
files | jfdctint.c |
diffstat | 1 files changed, 4 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- a/jfdctint.c Sun Sep 01 18:07:56 2002 +0000 +++ b/jfdctint.c Sun Sep 01 20:54:38 2002 +0000 @@ -30,8 +30,10 @@ #define SHIFT_TEMPS #define DCTSIZE 8 +#define BITS_IN_JSAMPLE 8 #define GLOBAL(x) x #define RIGHT_SHIFT(x, n) ((x) >> (n)) +#define MULTIPLY16C16(var,const) ((var)*(const)) #if 1 //def USE_ACCURATE_ROUNDING #define DESCALE(x,n) RIGHT_SHIFT((x) + (1 << ((n) - 1)), n) @@ -85,7 +87,7 @@ #if BITS_IN_JSAMPLE == 8 #define CONST_BITS 13 -#define PASS1_BITS 2 +#define PASS1_BITS 4 /* set this to 2 if 16x16 multiplies are faster */ #else #define CONST_BITS 13 #define PASS1_BITS 1 /* lose a little precision to avoid overflow */ @@ -134,7 +136,7 @@ * For 12-bit samples, a full 32-bit multiplication will be needed. */ -#if BITS_IN_JSAMPLE == 8 +#if BITS_IN_JSAMPLE == 8 && CONST_BITS<=13 && PASS1_BITS<=2 #define MULTIPLY(var,const) MULTIPLY16C16(var,const) #else #define MULTIPLY(var,const) ((var) * (const))