diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2003-12-31 02:32:54 +0000 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2003-12-31 02:32:54 +0000 |
commit | 9e2a16e1a7b244fef9621e5fc944afefe5410367 (patch) | |
tree | a47eec62ef37e691e3ce27f1ede945471b1bf29b | |
parent | 7d67aa9b0f3bd2cb6c023e8b9e537606aa6b08d9 (diff) | |
download | ffmpeg-9e2a16e1a7b244fef9621e5fc944afefe5410367.tar.gz |
fixpoint log() for tiny_psnr so it can output actual PSNR
Originally committed as revision 2640 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | tests/ffmpeg.regression.ref | 44 | ||||
-rw-r--r-- | tests/rotozoom.regression.ref | 44 | ||||
-rw-r--r-- | tests/tiny_psnr.c | 67 |
3 files changed, 108 insertions, 47 deletions
diff --git a/tests/ffmpeg.regression.ref b/tests/ffmpeg.regression.ref index 4ec3c8f519..fc6e052ba0 100644 --- a/tests/ffmpeg.regression.ref +++ b/tests/ffmpeg.regression.ref @@ -1,70 +1,70 @@ ffmpeg regression test 74e25b401f34321aeb854e264ef62df8 *./data/a-mpeg1.mpg 1ee8816bd078efe66be0090b1d9b0af1 *./data/out.yuv -stddev: 7.63 bytes:7602176 +stddev: 7.63 PSNR:30.47 bytes:7602176 b588110bebb48b5a1815ac26d0f0c9cc *./data/a-mpeg2.mpg ddfa5c618dab54df0f47976ddd55d90f *./data/out.yuv -stddev: 7.65 bytes:7602176 +stddev: 7.65 PSNR:30.44 bytes:7602176 345b79f7afe43abc0128a7b1d5fff949 *./data/a-mpeg2i.mpg 5df468301367ed2dde5f064bf4c17301 *./data/out.yuv -stddev: 7.96 bytes:7602176 +stddev: 7.96 PSNR:30.10 bytes:7602176 d0dc46dd831398237a690ebbeff18b64 *./data/a-msmpeg4v2.avi 712aa6c959d1d90a78fe98657cbff19c *./data/out.yuv -stddev: 8.11 bytes:7602176 +stddev: 8.11 PSNR:29.94 bytes:7602176 dae855177b45cbe6e40c6777f95095ef *./data/a-msmpeg4.avi 8786aa956838234fe3e48d0ef8cbd46c *./data/out.yuv -stddev: 8.12 bytes:7602176 +stddev: 8.12 PSNR:29.93 bytes:7602176 6633a1111c734c9156729b8b7e198c17 *./data/a-wmv1.avi 7261e23fd8ad1de6efee022051b936be *./data/out.yuv -stddev: 8.10 bytes:7602176 +stddev: 8.10 PSNR:29.94 bytes:7602176 30dcbbe391149d981162a1f4727c43d6 *./data/a-wmv2.avi 7261e23fd8ad1de6efee022051b936be *./data/out.yuv -stddev: 8.10 bytes:7602176 +stddev: 8.10 PSNR:29.94 bytes:7602176 4bf9df20cdeb1aa01115761642b4e80b *./data/a-h263.avi 545df74e0aa443499600faedd10a7065 *./data/out.yuv -stddev: 8.18 bytes:7602176 +stddev: 8.18 PSNR:29.86 bytes:7602176 920a0a8a0063655d1f34dcaad7857f98 *./data/a-h263p.avi 0eb167c9dfcbeeecbf3debed8af8f811 *./data/out.yuv -stddev: 2.08 bytes:7602176 +stddev: 2.08 PSNR:41.74 bytes:7602176 66f8b4b5b4f0655cff7bdbc44969cab3 *./data/a-odivx.mp4 5bd332c77ef45e58b7017e06a0467dd3 *./data/out.yuv -stddev: 7.94 bytes:7602176 +stddev: 7.94 PSNR:30.12 bytes:7602176 5704a082cc5c5970620123ae20566286 *./data/a-huffyuv.avi 799d3db687f6cdd7a837ec156efc171f *./data/out.yuv -stddev: 0.00 bytes:7602176 +stddev: 0.00 PSNR:99.99 bytes:7602176 e9f63126859b97cd23cd1413038f8f7b *./data/a-mpeg4-rc.avi 90a159074b1b109569914ee63f387860 *./data/out.yuv -stddev: 10.18 bytes:7145472 +stddev: 10.18 PSNR:27.96 bytes:7145472 d7d295f97a1e07b633f973d2325880ce *./data/a-mpeg4-adv.avi 612f79510c8098f1421aa154047e2bf2 *./data/out.yuv -stddev: 7.25 bytes:7602176 +stddev: 7.25 PSNR:30.91 bytes:7602176 f863f4198521bd76930ea33991b47273 *./data/a-error-mpeg4-adv.avi ba7fcd126c7c9fead5a5de71aaaf0624 *./data/out.yuv -stddev: 16.80 bytes:7602176 +stddev: 16.80 PSNR:23.61 bytes:7602176 328ebd044362116e274739e23c482ee7 *./data/a-mpeg1b.mpg 788a9d500dc8986231a18076fc80fd73 *./data/out.yuv -stddev: 10.07 bytes:7145472 +stddev: 10.07 PSNR:28.06 bytes:7145472 07042f42b3119c39eb26537a84a451df *./data/a-mjpeg.avi f23a9e50a559e174766ee808c48fea22 *./data/out.yuv -stddev: 8.87 bytes:7602176 +stddev: 8.87 PSNR:29.15 bytes:7602176 1d565db4a3a054261af95f2483a37cd6 *./data/a-ljpeg.avi 799d3db687f6cdd7a837ec156efc171f *./data/out.yuv -stddev: 0.00 bytes:7602176 +stddev: 0.00 PSNR:99.99 bytes:7602176 4b37703d3dc03873f99603165c0fe11e *./data/a-rv10.rm 255469fef47bee94cfb2e3385ebb736b *./data/out.yuv -stddev: 13.42 bytes:7602176 +stddev: 13.42 PSNR:25.56 bytes:7602176 89ad858355f9b0a92d024c5ba6e369dd *./data/a-asv1.avi b3e1696d73071c8f7f0ff4e10c1677ca *./data/out.yuv -stddev: 19.19 bytes:7602176 +stddev: 19.19 PSNR:22.46 bytes:7602176 3909db39c3d2e9a72a952254e8685ff7 *./data/a-asv2.avi 551b263bfb2acb9ea6dd2000f184494f *./data/out.yuv -stddev: 17.98 bytes:7602176 +stddev: 17.98 PSNR:23.02 bytes:7602176 37a528aa9efc28c5c3cc8191da90e012 *./data/a-flv.flv 57ea0821ec4377e96647adc22717a4ba *./data/out.yuv -stddev: 8.19 bytes:7602176 +stddev: 8.19 PSNR:29.85 bytes:7602176 0ed9b02681d6d44bf8c390ba6c4f5c66 *./data/a-ffv1.avi 799d3db687f6cdd7a837ec156efc171f *./data/out.yuv -stddev: 0.00 bytes:7602176 +stddev: 0.00 PSNR:99.99 bytes:7602176 21f8ff9f1daacd9133683bb4ea0f50a4 *./data/a-mp2.mp2 624d9789f3ac193bbae4af3bd8cb02b7 *./data/out.wav d056da679e6d6682812fffb28a7f0db6 *./data/a-ac3.rm diff --git a/tests/rotozoom.regression.ref b/tests/rotozoom.regression.ref index 3277747836..3f9edc69fe 100644 --- a/tests/rotozoom.regression.ref +++ b/tests/rotozoom.regression.ref @@ -1,70 +1,70 @@ ffmpeg regression test a6ccb5e768c7bed7a08f8e4343d81871 *./data/a-mpeg1.mpg 9364e15902bc56603dfb453f8bf146e0 *./data/out.yuv -stddev: 4.93 bytes:7602176 +stddev: 4.93 PSNR:34.25 bytes:7602176 aa0f088777131d8ffb627e6ff37312ca *./data/a-mpeg2.mpg 830e7d798089ea6213e0867fd7676fde *./data/out.yuv -stddev: 4.95 bytes:7602176 +stddev: 4.95 PSNR:34.22 bytes:7602176 ed480119089c61ba5a5a8668675c7d49 *./data/a-mpeg2i.mpg a6ec3343ce12d72ccc7d0d8303b84781 *./data/out.yuv -stddev: 4.96 bytes:7602176 +stddev: 4.96 PSNR:34.20 bytes:7602176 14db391f167b52b21a983157b410affc *./data/a-msmpeg4v2.avi fc8881e0904af9491d5fa0163183954b *./data/out.yuv -stddev: 5.29 bytes:7602176 +stddev: 5.29 PSNR:33.64 bytes:7602176 484b4dccac1e552f0f29971f4a066598 *./data/a-msmpeg4.avi dd82e8badc40ad5f76b0ffc1d6945b1c *./data/out.yuv -stddev: 5.29 bytes:7602176 +stddev: 5.29 PSNR:33.64 bytes:7602176 d63c0cbb6d845bfd8e2735b4ea733a53 *./data/a-wmv1.avi 407c23671e7c7265c19c91966dbba317 *./data/out.yuv -stddev: 5.29 bytes:7602176 +stddev: 5.29 PSNR:33.65 bytes:7602176 ba4616dc4db0db636a7c26bc8f2de04e *./data/a-wmv2.avi 407c23671e7c7265c19c91966dbba317 *./data/out.yuv -stddev: 5.29 bytes:7602176 +stddev: 5.29 PSNR:33.65 bytes:7602176 f980b5e38c4b919fbe5b660fe12fcf1a *./data/a-h263.avi 8bcc9f78373ec424e864b40734e124ba *./data/out.yuv -stddev: 5.41 bytes:7602176 +stddev: 5.41 PSNR:33.45 bytes:7602176 f7828488c31ccb6787367ef4e4a2ad42 *./data/a-h263p.avi 7d39d1f272205a6a231d0e0baf32ff9d *./data/out.yuv -stddev: 1.91 bytes:7602176 +stddev: 1.91 PSNR:42.49 bytes:7602176 a831828595e5764e6ee30c2d9e548385 *./data/a-odivx.mp4 ad75d173bd30d642147f00da21df0012 *./data/out.yuv -stddev: 5.27 bytes:7602176 +stddev: 5.27 PSNR:33.67 bytes:7602176 242a7a18c2793e115007bc163861ef4e *./data/a-huffyuv.avi dde5895817ad9d219f79a52d0bdfb001 *./data/out.yuv -stddev: 0.00 bytes:7602176 +stddev: 0.00 PSNR:99.99 bytes:7602176 6a469f42ce6946dd4c708f9e51e3da6a *./data/a-mpeg4-rc.avi df9de7134d961119705b4e0cabca1f12 *./data/out.yuv -stddev: 4.20 bytes:7145472 +stddev: 4.20 PSNR:35.64 bytes:7145472 483504d060b0bd8ac1acfa3a823c2ad7 *./data/a-mpeg4-adv.avi 08d24bdd7da80cffaf8abaa3e71b1843 *./data/out.yuv -stddev: 4.96 bytes:7602176 +stddev: 4.96 PSNR:34.20 bytes:7602176 03ff35856faefb4882eaf4d86d95bea7 *./data/a-error-mpeg4-adv.avi 8550acff0851ee915bd5800f1e20f37c *./data/out.yuv -stddev: 9.66 bytes:7602176 +stddev: 9.66 PSNR:28.42 bytes:7602176 671802a2c5078e69f7f422765ea87f2a *./data/a-mpeg1b.mpg d3d5876cef34b728602d5a22eee9249f *./data/out.yuv -stddev: 5.93 bytes:7145472 +stddev: 5.93 PSNR:32.66 bytes:7145472 e9218a1db885fe0262e88f9df630307d *./data/a-mjpeg.avi a365b4da246ad68caf96b702b7f961a1 *./data/out.yuv -stddev: 4.76 bytes:7602176 +stddev: 4.76 PSNR:34.56 bytes:7602176 defd90b44bced2772c6ca0d8eb75f668 *./data/a-ljpeg.avi dde5895817ad9d219f79a52d0bdfb001 *./data/out.yuv -stddev: 0.00 bytes:7602176 +stddev: 0.00 PSNR:99.99 bytes:7602176 1b46671251277c14f3a24a034648c458 *./data/a-rv10.rm e1923bc2940a017858e354c3fb0e6244 *./data/out.yuv -stddev: 13.18 bytes:7602176 +stddev: 13.18 PSNR:25.72 bytes:7602176 9c4f5a4613a5595c90c6b99bf143b6a9 *./data/a-asv1.avi 4251d7f496bbf362251b065e840a1b73 *./data/out.yuv -stddev: 9.80 bytes:7602176 +stddev: 9.80 PSNR:28.29 bytes:7602176 19652f2aac2d4d0379d37ce17e0bbea7 *./data/a-asv2.avi 7d887519f7884e7c49c591831c11ac50 *./data/out.yuv -stddev: 9.71 bytes:7602176 +stddev: 9.71 PSNR:28.37 bytes:7602176 bee27a404ab6a1b7ab1d3551eb4f1877 *./data/a-flv.flv 86da6ee46d2df190b4a0d72523b14a25 *./data/out.yuv -stddev: 5.29 bytes:7602176 +stddev: 5.29 PSNR:33.64 bytes:7602176 0db09835ebc3d22f166f30879f3ccc38 *./data/a-ffv1.avi dde5895817ad9d219f79a52d0bdfb001 *./data/out.yuv -stddev: 0.00 bytes:7602176 +stddev: 0.00 PSNR:99.99 bytes:7602176 21f8ff9f1daacd9133683bb4ea0f50a4 *./data/a-mp2.mp2 624d9789f3ac193bbae4af3bd8cb02b7 *./data/out.wav d056da679e6d6682812fffb28a7f0db6 *./data/a-ac3.rm diff --git a/tests/tiny_psnr.c b/tests/tiny_psnr.c index 2104dd4726..84ad90ebce 100644 --- a/tests/tiny_psnr.c +++ b/tests/tiny_psnr.c @@ -19,10 +19,63 @@ #include <stdio.h> #include <inttypes.h> +#include <assert.h> #define F 100 #define SIZE 2048 +uint64_t exp16_table[20]={ + 65537, + 65538, + 65540, + 65544, + 65552, + 65568, + 65600, + 65664, + 65793, + 66050, + 66568, + 67616, + 69763, + 74262, + 84150, + 108051, + 178145, + 484249, + 3578144, + 195360063, +}; +#if 1 +// 16.16 fixpoint exp() +static unsigned int exp16(unsigned int a){ + int i; + int out= 1<<16; + + for(i=19;i>=0;i--){ + if(a&(1<<i)) + out= (out*exp16_table[i] + (1<<15))>>16; + } + + return out; +} +// 16.16 fixpoint log() +static uint64_t log16(uint64_t a){ + int i; + int out=0; + + assert(a >= (1<<16)); + a<<=16; + + for(i=19;i>=0;i--){ + if(a<(exp16_table[i]<<16)) continue; + out |= 1<<i; + a = ((a<<16) + exp16_table[i]/2)/exp16_table[i]; + } + return out; +} + +#endif static uint64_t int_sqrt(uint64_t a) { uint64_t ret=0; @@ -45,6 +98,7 @@ int main(int argc,char* argv[]){ uint64_t dev; FILE *f[2]; uint8_t buf[2][SIZE]; + uint64_t psnr; if(argc!=3){ printf("tiny_psnr <file1> <file2>\n"); @@ -66,9 +120,16 @@ int main(int argc,char* argv[]){ } dev= int_sqrt((sse*F*F)/i); + if(sse) + psnr= (log16(256*256*255*255LL*i/sse)*284619LL*F + (1<<31)) / (1LL<<32); + else + psnr= 100*F-1; //floating point free infinity :) - //FIXME someone should write a integer fixpoint log() function for bitexact PSNR scores ... - printf("stddev:%3d.%02d bytes:%d\n", (int)(dev/F), (int)(dev%F), i); - + printf("stddev:%3d.%02d PSNR:%2d.%02d bytes:%d\n", + (int)(dev/F), (int)(dev%F), + (int)(psnr/F), (int)(psnr%F), + i); return 0; } + + |