1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2024-11-21 10:55:51 +02:00
FFmpeg/tests
Martin Storsjö 9c8bc74c2b arm: vp9itxfm: Skip empty slices in the first pass of idct_idct 16x16 and 32x32
This work is sponsored by, and copyright, Google.

Previously all subpartitions except the eob=1 (DC) case ran with
the same runtime:

                                     Cortex A7       A8       A9      A53
vp9_inv_dct_dct_16x16_sub16_add_neon:   3188.1   2435.4   2499.0   1969.0
vp9_inv_dct_dct_32x32_sub32_add_neon:  18531.7  16582.3  14207.6  12000.3

By skipping individual 4x16 or 4x32 pixel slices in the first pass,
we reduce the runtime of these functions like this:

vp9_inv_dct_dct_16x16_sub1_add_neon:     274.6    189.5    211.7    235.8
vp9_inv_dct_dct_16x16_sub2_add_neon:    2064.0   1534.8   1719.4   1248.7
vp9_inv_dct_dct_16x16_sub4_add_neon:    2135.0   1477.2   1736.3   1249.5
vp9_inv_dct_dct_16x16_sub8_add_neon:    2446.7   1828.7   1993.6   1494.7
vp9_inv_dct_dct_16x16_sub12_add_neon:   2832.4   2118.3   2266.5   1735.1
vp9_inv_dct_dct_16x16_sub16_add_neon:   3211.7   2475.3   2523.5   1983.1
vp9_inv_dct_dct_32x32_sub1_add_neon:     756.2    456.7    862.0    553.9
vp9_inv_dct_dct_32x32_sub2_add_neon:   10682.2   8190.4   8539.2   6762.5
vp9_inv_dct_dct_32x32_sub4_add_neon:   10813.5   8014.9   8518.3   6762.8
vp9_inv_dct_dct_32x32_sub8_add_neon:   11859.6   9313.0   9347.4   7514.5
vp9_inv_dct_dct_32x32_sub12_add_neon:  12946.6  10752.4  10192.2   8280.2
vp9_inv_dct_dct_32x32_sub16_add_neon:  14074.6  11946.5  11001.4   9008.6
vp9_inv_dct_dct_32x32_sub20_add_neon:  15269.9  13662.7  11816.1   9762.6
vp9_inv_dct_dct_32x32_sub24_add_neon:  16327.9  14940.1  12626.7  10516.0
vp9_inv_dct_dct_32x32_sub28_add_neon:  17462.7  15776.1  13446.2  11264.7
vp9_inv_dct_dct_32x32_sub32_add_neon:  18575.5  17157.0  14249.3  12015.1

I.e. in general a very minor overhead for the full subpartition case due
to the additional loads and cmps, but a significant speedup for the cases
when we only need to process a small part of the actual input data.

In common VP9 content in a few inspected clips, 70-90% of the non-dc-only
16x16 and 32x32 IDCTs only have nonzero coefficients in the upper left
8x8 or 16x16 subpartitions respectively.

Signed-off-by: Martin Storsjö <martin@martin.st>
2016-11-30 23:54:07 +02:00
..
checkasm arm: vp9itxfm: Skip empty slices in the first pass of idct_idct 16x16 and 32x32 2016-11-30 23:54:07 +02:00
fate fate: Add h264 and hevc extradata reload tests 2016-11-16 11:17:27 -05:00
filtergraphs FATE: add a test for the ONE_STR mapping mode of the channelmap filter 2014-03-16 07:44:03 +01:00
ref fate: Add h264 and hevc extradata reload tests 2016-11-16 11:17:27 -05:00
.gitignore Split global .gitignore file into per-directory files 2016-05-13 14:55:56 +02:00
audiogen.c cosmetics: Write NULL pointer inequality checks more compactly 2014-08-15 05:34:13 -07:00
base64.c tests: K&R formatting cosmetics for test programs 2012-01-18 21:07:17 +01:00
fate-run.sh fate: Add tests for mov display matrix 2016-11-01 11:55:54 -04:00
fate.sh fate.sh: Allow setting other make flags for running tests 2016-11-23 15:05:51 +02:00
lavf-regression.sh Remove avserver. 2014-06-18 14:55:28 +02:00
Makefile fate: Add tests for mov display matrix 2016-11-01 11:55:54 -04:00
md5.sh fate: improve md5sum utility selection 2012-10-15 21:40:08 +01:00
reference.pnm Replace lena.pnm 2014-11-28 17:55:27 -05:00
regression-funcs.sh lavf: add AVFMT_FLAG_BITEXACT. 2014-05-15 07:42:07 +02:00
rotozoom.c fate: avoid freopen(NULL) in videogen/rotozoom 2012-06-07 11:28:39 +01:00
tiny_psnr.c Drop pointless assert.h #includes 2016-05-03 15:45:10 +02:00
utils.c fate: teach videogen/rotozoom to output a single raw video stream 2012-05-29 08:27:19 +01:00
videogen.c fate: avoid freopen(NULL) in videogen/rotozoom 2012-06-07 11:28:39 +01:00