summaryrefslogtreecommitdiff
path: root/libavcodec/dct-test.c
diff options
context:
space:
mode:
authorFabrice Bellard <fabrice@bellard.org>2002-10-03 21:03:59 +0000
committerFabrice Bellard <fabrice@bellard.org>2002-10-03 21:03:59 +0000
commit652f01978626257e38d1e333af45055d2b9465b5 (patch)
treedd09bd5b0a1f5bb5225a3d26af77cb1ad29e3e92 /libavcodec/dct-test.c
parent5917d17cb79af27681209a745492bdccc37d2f76 (diff)
in fact IDCT248 needs to be normalized as I suspected
Originally committed as revision 997 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/dct-test.c')
-rw-r--r--libavcodec/dct-test.c36
1 files changed, 20 insertions, 16 deletions
diff --git a/libavcodec/dct-test.c b/libavcodec/dct-test.c
index ecc6a680c9..e36a9a07f0 100644
--- a/libavcodec/dct-test.c
+++ b/libavcodec/dct-test.c
@@ -299,10 +299,11 @@ void idct248_ref(UINT8 *dest, int linesize, INT16 *block)
}
/* butterfly */
+ s = 0.5 * sqrt(2.0);
for(i=0;i<4;i++) {
for(j=0;j<8;j++) {
- block1[8*(2*i)+j] = (block[8*(2*i)+j] + block[8*(2*i+1)+j]) * 0.5;
- block1[8*(2*i+1)+j] = (block[8*(2*i)+j] - block[8*(2*i+1)+j]) * 0.5;
+ block1[8*(2*i)+j] = (block[8*(2*i)+j] + block[8*(2*i+1)+j]) * s;
+ block1[8*(2*i+1)+j] = (block[8*(2*i)+j] - block[8*(2*i+1)+j]) * s;
}
}
@@ -336,7 +337,7 @@ void idct248_ref(UINT8 *dest, int linesize, INT16 *block)
/* clamp and store the result */
for(i=0;i<8;i++) {
for(j=0;j<8;j++) {
- v = block3[8*i+j] + 128.0;
+ v = block3[8*i+j];
if (v < 0)
v = 0;
else if (v > 255)
@@ -357,13 +358,27 @@ void idct248_error(const char *name,
important here) */
err_max = 0;
for(it=0;it<NB_ITS;it++) {
- for(i=0;i<64;i++)
- block1[i] = (random() % 512) - 256;
+ /* XXX: use forward transform to generate values */
+ for(i=0;i<64;i++)
+ block1[i] = (random() % 256) - 128;
+ block1[0] += 1024;
+
for(i=0; i<64; i++)
block[i]= block1[i];
idct248_ref(img_dest1, 8, block);
+ for(i=0; i<64; i++)
+ block[i]= block1[i];
+ idct248_put(img_dest, 8, block);
+
+ for(i=0;i<64;i++) {
+ v = abs((int)img_dest[i] - (int)img_dest1[i]);
+ if (v == 255)
+ printf("%d %d\n", img_dest[i], img_dest1[i]);
+ if (v > err_max)
+ err_max = v;
+ }
#if 0
printf("ref=\n");
for(i=0;i<8;i++) {
@@ -373,13 +388,7 @@ void idct248_error(const char *name,
}
printf("\n");
}
-#endif
-
- for(i=0; i<64; i++)
- block[i]= block1[i];
- idct248_put(img_dest, 8, block);
-#if 0
printf("out=\n");
for(i=0;i<8;i++) {
int j;
@@ -389,11 +398,6 @@ void idct248_error(const char *name,
printf("\n");
}
#endif
- for(i=0;i<64;i++) {
- v = abs(img_dest[i] - img_dest1[i]);
- if (v > err_max)
- err_max = v;
- }
}
printf("%s %s: err_inf=%d\n",
1 ? "IDCT248" : "DCT248",