The H.264 advanced video coding (AVC) standard1 is the newest standard from the ITU-T Video Coding Experts Group and the ISO/IEC Moving Pictures Experts Group. Its main advantages are the great variety of applications in which it can be used and its versatile design. This standard has shown significant rate-distortion (RD) improvements as compared to other standards for video compression.
The standard provides great flexibility in the selection of block sizes for motion estimation/compensation, with a minimum luma block size as small as . Although most prior standards enable half-pixel motion vector accuracy at most, the H264/AVC further allows quarter-pixel motion vector accuracy for improved performance. Although the standard has shown significant RD improvements, it has also increased the overall encoding complexity due to the very refined motion-estimation (ME) process. The ME process consists of two stages: integer-pixel motion search and fractional-pixel motion search. Because the complexity of integer-pixel ME has been greatly reduced by numerous fast ME algorithms,2, 3 the computation overhead required by fractional-pixel ME has become relatively significant.
Different fast fractional-pixel ME algorithms3, 4, 5, 6 have been proposed, and some of them are used by the JM reference software.7 Their common idea is to simplify the search pattern by applying very refined prediction algorithms and improved adaptive threshold schemes to terminate unnecessary search positions.
In this paper, we focus on decreasing the complexity of fractional-pixel ME by effectively applying a two-step algorithm. First, we examine the macroblock fractional-pixel ME best match, derived from the outcome we eliminate the fractional-pixel motion search for and macroblock partitions. Likewise, in the second step we examine the macroblock partitions fractional-pixel ME best matches and, derived from the outcome, we eliminate the fractional-pixel motion search for , , and macroblock partitions.
Our algorithm differs from the previous methods in two aspects: (i) It uses the similarities between the interpolation effect on the macroblock and its partitions to completely eliminate the fractional-pixel ME. (ii) The proposed algorithm is adaptive and can be applied to any combination of integer and fractional-pixel ME schemes.
The rest of the paper is organized as follows. Section 2 gives a brief overview of the ME algorithms proposed in the H.264/AVC. Section 3 describes the proposed ME algorithm. Section 4 contains a comprehensive list of experiments and a discussion. Section 5 concludes the letter.
ME in the H.264/AVC
In the first stage of ME, integer-pixel motion search is performed for each square block of the slice to be encoded in order to find one (or more) displacement vector(s) within a search range. The best match is the position that minimizes the Lagrangian cost functionis the Lagrangian multiplier, is an error measure between the candidate macroblock taken from the reference frame(s) and the current macroblock, and is the number of bits required to encode the difference between the motion vector(s) and its prediction from the neighboring macroblocks (differential coding). A similar functional to Eq. 1 is used to decide the optimal block size for ME. The most common error measures are the sum of absolute difference (SAD) and the sum of absolute transformed differences (SATD).
After the integer-pixel motion search finds the best match, the values at half-pixel positions around the best match are interpolated by applying a one-dimensional six-tap finite impulse response (FIR) filter horizontally and vertically. Then the values of the quarter-pixel positions are generated by averaging pixels at integer and half-pixel positions. Figure 1 illustrates the interpolated fractional pixel positions. Uppercase letters indicate pixels on the full-pixel grid, while numeric values indicate elements at half-pixel positions and lowercase letters indicate pixels in-between, at quarter-pixel positions.
For example, in Fig. 1, if the integer best match is position E, the half-pixel positions 1–8 are searched using Eq. 1. Suppose position 7 is the best match of the half pixel search. Then the quarter-pixel positions a–h are searched, again using Eq. 1.
In slow-motion video sequences or in the slow motion segments of fast video sequences, the ME process might find a best-match position during the integer-pixel motion search, which does not change after the subsequent fractional-pixel motion search. Furthermore, if the integer-pixel ME best match for a bigger block size does not change during fractional-pixel motion search, it is “highly likely” that this blocks’ partitions integer-pixel ME result will also not change during the fractional-pixel motion search. How likely, depends on the difference in block sizes as demonstrated below. The above observations are shown in Table 1.
Evaluation of the conditional probabilities.
Table 1 is divided into three rows. The first row shows the probability that the and macroblock partitions have the same best match in integer- and fractional-pixel ME, given that the macroblock has the same best match in integer- and fractional-pixel ME. We call this probability PROB(1). Similarly, the second row shows the probability of , , , and blocks having the same best match in integer and fractional-pixel-ME, given that the macroblock has the same best match in integer- and fractional-pixel ME. We call this probability PROB(2). The third row shows the probability of , , , and blocks partitions having the same best match in integer- and fractional-pixel ME, given that the blocks have the same best match in integer- and fractional-pixel ME. We call this probability PROB(3).These probabilities are averaged across sequences with different motion characteristics and are shown in the second column of Table 1.
From Table 1, it can be seen that the conditional probabilities are reasonably high only when the macroblock/block and their partitions do not differ much in terms of size. For example, we cannot safely say that the , , and partitions would find the same best match in the integer- and fractional-pixel motion search, given that enclosing macroblock does so. In this case, the difference in size is big, because the macroblock is 8, 8, and 16 times bigger with respect to the aforementioned block sizes. Using the above insights, we have developed the following scheme:
If the macroblock finds the same best match in the integer- and fractional-pixel motion searches, then we disable the fractional-pixel motion search for all the enclosed and blocks. Thus, we can save all the fractional-pixel search, SAD, and Hadamard transform calculations for these blocks, Otherwise, the fractional-pixel motion search is performed.
Similarly, if the block partitions of the macroblock find the same best match in the integer- and fractional-pixel motion searches, we disable the fractional-pixel motion search for all the enclosed , , and blocks. Otherwise, the fractional-pixel motion search is performed.
To assess the proposed algorithm, a comprehensive set of experiments for a variety of video sequences with different motion characteristics was performed. In this experiment, the source code for the H.264 Reference Software Version JM12.27 was used in a Pentium-4 PC running at with RAM. Table 2 illustrates the conditions of the experiments.
Encoder experiment conditions
|Level IDC7||40||B-Frame||Not used|
|ME metriclevel 0||SAD||ME metriclevels 1&2||HadamardSAD|
Table 3 shows the percentage cycle savings, the Bjontegaard Delta bit rate (BDBR) percentage differences, and the Bjontegaard Delta Peak signal-to-noise ratio (BDPSNR) differences (in decibels)8 between the H264/AVC and the algorithm we propose when full search (FS), enhanced predictive zonal search (EPZS),2 and unsymmetrical-cross multi-hexagon-grid search (UMHEXS)3 are used as full and fractional-pixel ME schemes.
|Sequence||Size||FullpixelME||Sub pixelME||FullpixelME||Sub pixelME||FullpixelME||Sub pixelME||FullpixelME||Sub pixelME||FullpixelME||Sub pixelME|
|BDPSNR (db)||BDBR (%)||Cycles (%)||BDPSNR (db)||BDBR (%)||Cycles (%)||BDPSNR (db)||BDBR (%)||Cycles (%)||BDPSNR (db)||BDBR (%)||Cycles (%)||BDPSNR (db)||BDBR (%)||Cycles (%)|
The Intel VTune performance analyzer was used to measure the number of machine cycles differences. Table 3 shows that the BDBR percentage differences are in the range of , while the BDPSNR differences are in the range of . The minus signs denote PSNR degradation and bit-rate savings, respectively.
This clearly shows that the proposed algorithm has very similar RD performance to the H.264/AVC. Furthermore, percentage cycle savings up to 16% are observed. It also can be seen that the reduction in the CPU cycles depends on the characteristics of the image sequences. For a slow image sequence with a simple background, the reduction is much more significant than for a fast image sequence or sequences with a more complex background.
In conclusion, we proposed a fast Subpixel ME based on the interpolation effect on different block sizes for H264/AVC standard. For RD performance very similar to the standard, the proposed technique can reduce up to 16% of the CPU cycles required for different ME schemes. Our scheme is very relevant to low-complexity video-coding systems.