Preprint
Article

A Fast Gradient Iterative Affine Motion Estimation Algorithm Based on Edge Detection for Versatile Video Coding

Altmetrics

Downloads

120

Views

42

Comments

0

A peer-reviewed article of this preprint also exists.

This version is not peer-reviewed

Submitted:

21 July 2023

Posted:

24 July 2023

You are already at the latest version

Alerts
Abstract
In the Versatile Video Coding (VVC) standard, affine motion models have been applied to enhance the resolution of complex motion patterns. However, due to the high computational complexity involved in affine motion estimation, real-time video processing applications face significant challenges. This paper focuses on optimizing affine motion estimation algorithms in the VVC environment and proposes a fast gradient iterative algorithm based on edge detection for efficient computation. Firstly, we establish judging conditions during the construction of affine motion candidate lists to streamline the redundant judging process. Secondly, we employ the Canny edge detection method for gradient assessment in the affine motion estimation process, thereby enhancing the iteration speed of affine motion vectors. Experimental results demonstrate that our affine motion estimation algorithm reduces encoding time by approximately 15%-35% while maintaining video bitrate and quality.
Keywords: 
Subject: Computer Science and Mathematics  -   Computer Vision and Graphics

1. Introduction

With the increasing amount of video data and the growing demand for high-quality video services, efficient video coding technology plays a crucial role in reducing bandwidth requirements and improving video compression performance. The H.266/VVC standard is the latest video coding standard developed by the Joint Video Expert Group (JVET) [1,2,3], aiming to provide significantly improved coding efficiency compared to previous standards and achieve better coding performance than high efficiency video coding (HEVC) [4,5,6,7]. The goal of the H.266/VVC standard is to provide higher compression rates under the same video quality. To achieve this goal, H.266/VVC adopts a series of innovative technologies, including the fast affine motion estimation algorithm (AME), advanced motion vector prediction (AMVP), prediction value correction based on the optical flow field, and interframe weighted prediction. For bidirectional prediction, the decoder-side motion vector refinement (DMVR) [8], bidirectional optical flow (BDOF) [9,10], and affine motion compensation (AMC) [11,12,13] is employed at the decoding end to optimize the precision of prediction, thereby enhancing its overall accuracy.
Affine motion estimation is a crucial step in video coding, serving to characterize inter-frame motion and facilitate differential frame encoding. Compared to previous motion estimation algorithms, affine motion models are more suitable for processing high-definition video content due to their ability to handle complex video scenes that involve translation, rotation, and scaling of objects. However, traditional affine motion estimation algorithms suffer from high computational complexity and insufficient accuracy, which limits the efficiency and quality of video coding. VVC provides two types of affine motion estimation models in the affine motion estimation module, namely the four-parameter affine model and the six-parameter affine model. In the affine motion estimation module, the structure of the current coding unit (CU) is 4×4 subblocks, and the motion vector of each subblock can be obtained from the control point motion vector (CPMV) of the two affine motion models. As shown in Figure 1. Among them, (a) is a four-parameter affine motion model, and (b) is a six-parameter affine motion model.
The affine motion model depicts the motion of an object or image in two-dimensional space under transformations such as translation, rotation, scaling, and misalignment. Affine transformations can be expressed as a combination of linear transformations and translations while preserving their affine properties. Through Affine transformation, the image can be geometrically corrected, scaled, and aligned to improve the accuracy and stability of image processing and analysis. The Affine transformation model of an image can be obtained through dimensionality reduction, utilizing the translation properties of Fourier transform and estimation theory for log-polar transformed images. Assuming that image. f p 2 ( x , y ) is the result of a translation of the image f p 1 ( x , y ) by Δ x , Δ y ,the relationship between the two images is shown in formula (1), with the Fourier transform relationship as formula (2) and the energy spectrum (amplitude spectrum) represented by formula (3).
f p 2 ( x , y ) = f p 1 ( x Δ x , y Δ y )
F 2 ( ξ , η ) = e j 2 π ( ξ Δ x + η Δ y ) F 1 ( ξ , η )
M 2 ( ξ , η ) = M 1 ( ξ , η )
where M 2 and M 1 are the energy spectra of F 2 and F 1 , the statement implies that the amplitude spectrum of the image translation remains unchanged in the frequency domain, which can be utilized for dimensionality reduction estimation of image transformation. Assuming that the positional relationship of the image satisfies formula (4), formula (5) is the relationship expression between two images.
( x , y ) = s R ( α ) ( x 1 , y 1 ) + T
f p 2 ( x , y ) = f p 1 ( x , y ) x 1 = s x cos α + s y sin α + Δ x y 1 = s x sin α + s y cos α + Δ y
where R ( α ) = cos α sin α sin α cos α , T = ( Δ x , Δ y ) according to the translation theory, formula (6) is obtained, and polar coordinate transformation is performed on formula (6), followed by logarithmic transformation to obtain formula (7).
M 2 ( ξ , η ) = s 2 M 1 ( ξ 1 , η 1 )
M 2 ( log r , θ ) = s 2 M 1 ( log r log s , θ + α )
where ρ = log r ; d = log s the nonlinear mapping of the image is realized by Bilinear interpolation. In this way, the rotation and scaling transformation of the image are reduced to the translation transformation, and the four-parameter motion model can be obtained. The motion vectors of the sub-blocks based on the current coding block can be obtained by affine motion model with four and six parameters of two control point motion vectors CPMV1 and CPMV2, or three control point motion vectors CPMV1, CPMV2, and CPMV3. As shown in Figure 1, where (a) is a four-parameter affine motion model, and (b) is a six-parameter affine motion model, where CPMV1, CPMV2, and CPMV3 are the motion vectors of the upper left corner control point, upper right corner motion vector, and lower left corner control point motion vectors of the current coding unit. The motion vectors of the sub-blocks centered on (x,y) in Figure 1 can be calculated by the following equation.
m v ( x , y ) h = m v 2 h m v 1 h W x + m v 2 v m v 1 v W y + m v 1 h m v ( x , y ) v = m v 2 v m v 1 v W x + m v 2 h m v 1 h W y + m v 1 v
where m v ( x , y ) h and m v ( x , y ) v represent the motion vectors in the horizontal and vertical directions of the current encoding subblocks ( x , y ) , and W is the width of the current encoding unit. Through this method, the current encoding unit can be obtained from the motion vectors of 4×4 subblocks.
The six-parameter affine motion model has one more CPMV than the four-parameter affine model. The formula for calculating the motion vector centered on the current block ( x , y ) is as follows:
m v ( x , y ) h = m v 2 h m v 1 h W x + m v 3 v m v 1 v H y + m v 1 h m v ( x , y ) v = m v 2 v m v 1 v W x + m v 3 h m v 1 h H y + m v 1 v
where m v 3 v and m v 3 h represent the motion vectors in the horizontal and vertical directions motion vectors.
Introducing an affine motion estimation model in VVC can effectively describe complex video content and improve the performance of the encoder. However, the computational complexity of AME is high, and the motion estimation algorithm in the inter-prediction module takes up a long encoding time. To achieve better encoding gain while reducing its computational complexity, many researchers have attempted to reduce its computational complexity in traditional affine motion estimation modules. However, there is still little work in the inter-frame prediction affine motion estimation module of VVC and there is still a large optimization space.
This paper proposes a fast gradient iterative affine motion estimation algorithm based on edge detection, which can effectively accelerate the affine motion estimation process of inter-frame prediction and achieve the goal of shortening the overall encoding time of the encoder. This method consists of two steps. The first process is to set judging conditions in the candidate set of affine motion vectors and achieve the goal of skipping redundant judging when the candidate set meets the conditions. The second process is to use the Canny edge detection operator in the affine motion estimation to obtain the gradient, thereby accelerating the gradient iteration. While ensuring coding performance and image quality, it accelerates the time for the affine motion estimation part of inter-frame prediction and reduces the overall encoding time of the encoder.
The arrangement of the entire article is as follows: Section 2 reviews the relevant research achievements and progress, Section 3 provides a detailed introduction to the fast affine motion estimation algorithm proposed in this paper, Section 4 provides experimental analysis and results, and Section 5 provides the conclusion of this paper.

2. Related Work

Modern multimedia applications have increasingly high requirements for video encoders, requiring both high coding efficiency and low computational complexity to ensure low latency and high transmission speed in real-time applications. To meet this demand, researchers are committed to designing efficient and low-complexity video encoders. Although there has been some research work on reducing the computational complexity of VVC encoders, most of the research has focused on accelerating early decision-making in the partitioning process [14,15,16,17,18,19,20]. Reference [14] proposed a fast partitioning algorithm for intra and inter-frame encoding. For intra-frame encoding, the Canny edge detection algorithm is used to extract the features of image encoding and the features are used to determine whether to skip vertical or horizontal partitioning, achieving the goal of early termination. For inter-frame encoding, the three-frame difference method is used to determine whether an object is a moving target. Reference [15] proposes a fast texture-based CU partitioning method, which evaluates the complexity of the current CU to determine whether to skip subsequent partitioning. At the same time, an improved Canny operator is used to extract edge information to exclude horizontal or vertical partitioning patterns. Reference [16] analyzes the probability of affine motion estimation mode in bidirectional prediction, explores the mutual exclusion between skip mode and affine mode, and proposes a VVC fast affine motion estimation mode based on near coding information. Reference [17] studied a fast motion estimation algorithm for early termination of partial blocks in CU, using skip mode for CU that does not require affine changes. Reference [18] Zhao et al. extracted standard deviation and edge ratio to accelerate the division of CU. The CU split information and the time position of the encoded frame are used for low-complexity encoders [19]. Reference [20] checks whether the optimal prediction mode of the current encoding block is skip mode. If it does, it skips the entire affine motion estimation process and checks the direction of the optimal prediction. The detection results determine whether to reduce the size of the reference sequence, thereby reducing computational complexity. Reference [21] proposes an adaptive affine four-parameter and six-parameter encoding architecture, where the encoder can adaptively select between two affine motion models. Reference [22] proposes an affine motion estimation model that iteratively searches for affine motion vectors, and a method for constructing an affine advanced motion vector prediction candidate (AAMVP) list, which has been adopted by the VVC standard. Reference [23] proposes an affine motion compensation based on feature matching, which can further improve the efficiency of video coding. Reference [24] carries out affine motion estimation through block division and predicts each pixel using a reference coordinate system, to achieve the purpose of predicting Affine transformation. Reference [25] proposes an affine motion estimation scheme that does not require additional alternating segmentation and estimation, described by applying a segmented function of the parameter field, and derives a specific splitting optimization scheme at close range. Reference [26] proposed a method to use Rate–distortion theory and displacement estimation error to determine the minimum bit rate required for information transmission of prediction error in the coding process. Reference [27] proposed a method to solve the problem of relative pose estimation by using the Affine transformation between feature points. Reference [28] proposed a motion compensation scheme for three-zone segmentation. Based on segmentation information, three motion compensation regions are divided, namely the edge region, foreground region, and background region. By using the information from these three regions, the accuracy and encoding efficiency of motion compensation are improved. Reference [29] proposed a method of edge video compression texture synthesis based on a Generative adversarial network to obtain the most authentic texture information. Reference [30] proposes an affine parameter model that utilizes matching algorithms to discover and extract feature point pairs from edges within consecutive frames and selects the optimal set of three sets of point pairs to describe global motion. Reference [31] proposes linear applications of traditional intra-prediction modes based on pattern correlation processing sequence, region-based template matching prediction methods, and neural network-based intra-prediction modes. Reference [32] proposes a context-based inter-mode judging method that skips affine modes by determining whether radial motion estimation is performed during the rate-distortion optimization process of the optimal CU mode decision. Reference [33] added momentum parameters to accelerate the iterative process based on the symmetry of the affine motion estimation iterative process.
Overall, most of the current research work is focused on the skip judging of the affine motion estimation module. However, there have not been many improvements and optimizations to the architecture of the affine motion itself, resulting in the high computational complexity and complexity of the affine motion estimation module itself not being well addressed. This is what current research work needs to do.

3. Materials and Methods

Affine motion estimation is located in the inter-prediction module of the H.266/VVC encoder, which uses a method similar to the inter-prediction motion estimation in H.265/HEVC to search for motion vectors. The affine motion estimation of the VVC encoder first uses affine advanced motion vector prediction technology (AAMVP) to obtain the starting candidate list of affine motion vectors for the current encoding block. Then, a set of optimal candidate running vectors is selected as the starting search points in the list, and the optimal motion vector combination for the current encoding block is determined through iterative search.

3.1. Affine advanced motion vector prediction

The AAMVP technology is used in the inter-frame prediction of VVC to construct a candidate list of starting vector groups while using judging conditions to select the optimal set of vector combinations as the starting position for the iterative search. In VVC, the candidate length of AAMVP is defined as two, and the candidate list is established for each predicted image. Each list only contains unidirectional motion information. Figure 2 is the AAMVP candidate list build diagram. The encoder first checks the inheritance of available information adjacent to the current encoding unit in the order of bottom left, bottom, top right, and top left. If affine motion estimation mode is used in adjacent blocks, the affine information of adjacent encoded blocks is directly inherited. If the candidate set of the previous operation is not filled, adjacent blocks at the motion vectors of the three control points of the current encoding block are checked separately, and the motion vectors are combined using the first nonaffine motion mode translation motion vector at each CPMV. If it is still not satisfied, the time-domain translation motion vector and zero value MV are combined to fill the candidate list. It can be seen that the candidate list of AAMVP adopts five steps to construct motion vector combinations, namely: spatial adjacent affine mode CU inheritance; Translation construction of adjacent CU in airspace; Translated MV filling of adjacent CU in airspace; Time domain translation MV filling; Zero value MV padding.
In the process of constructing the candidate list for AAMVP, the adjacent blocks of adjacent affine modes in the spatial domain need to meet three conditions: first, they must be in inter-frame encoding mode, then in affine encoding mode, and finally, the reference image must be the same as the current CU reference image. The translation construction of adjacent CU in the same spatial domain also needs to meet three conditions: first, the inter-frame encoding mode, then the nonaffine encoding mode, and finally, the reference image must be the same as the reference image of the current CU. We define the first condition as C o n d i t i o n _ 1 . The second condition is C o n d i t i o n _ 2 . When the conditions are not met, skip the judging of the current neighboring block in advance, and there is no need to perform other complex condition calculations and judgings. At the same time, in the process of constructing the candidate set, after each step, a judging is made on whether the candidate set is filled. If the candidate set has already been filled in the current step, the subsequent judging steps are skipped, which can achieve early termination of the candidate list construction process and reduce the computational burden of the encoder in this step. Figure 3 below is the optimization flowchart of AMMVP.

3.2. The iterative search of affine motion vectors

In the VVC standard, the encoder uses the AAMVP technique from the previous step to obtain the optimal affine motion vector combination as the starting search motion vector group and obtains the optimal affine motion vector combination for the current encoding block through iterative search. Fast affine motion estimation needs to calculate a set of optimal affine motion vectors, usually two or three, so the VVC encoder uses Mean squared error (MSE) as the matching criterion. The formula definition for MSE is as follows:
M S E = 1 w × h ( x , y ) C u r P c u r ( x , y ) P r e f ( ( x , y ) + m v ( x , y ) ) 2
where w and h are the width and height of the current encoding block, P c u r ( x , y ) is the image where the current encoding block is located, and P r e f ( x , y ) is the reference image for the current encoding block.
Define the change in motion vector after the i t h iteration as d M V i . The expression of the motion vector at the i t h iteration can be defined as follows:
m v ( x , y ) i = A ( x , y ) ( ( m v ( x , y ) i 1 ) T + ( d M V i ) T ) = m v ( x , y ) i 1 + A ( x , y ) ( d M V i ) T
where ( x , y ) represents the position of the current encoding block, and the change of the motion vector d M V i is a row matrix. Now its Transpose is given as follows:
( d M V i ) T = d M V 1 h d M V 2 h d M V 1 v d M V 2 v = m v 1 i h m v 1 ( i 1 ) h m v 2 i h m v 2 ( i 1 ) h m v 1 i v m v 1 ( i 1 ) v m v 2 i v m v 2 ( i 1 ) v
After i iterations, the pixel values of the current reference point can be obtained as follows:
P r e f ( ( x , y ) + m v ( x , y ) ) = P r e f ( ( x i 1 , y i 1 ) + A ( x , y ) ( d M V i ) T )
where ( x i 1 , y i 1 ) is the position of the matching block during the previous iteration search, and Taylor polynomial expansion is performed on formula (13) while ignoring higher-order polynomials to obtain formula (14):
P ref ( ( x i 1 , y i 1 ) + A ( x , y ) ( d MV i ) T ) P ref ( x i 1 , y i 1 ) + P ref ( x i 1 , y i 1 ) A ( x , y ) ( d MV i ) T
To minimize the value of MSE during the iteration process, the pixel value P r e f ( x , y ) of the reference point needs to be as close as possible to the original pixel value P c u r ( x , y ) . Set the relative gradient of the relative change d M V i of the motion vector to zero. If the value is zero during the iteration process, it indicates that the current reference pixel value is closest to the original pixel value and is the best-matched result. In the encoder model of VVC, the Sobel operator is used to convolution the pixel matrix to obtain the gradient. The formula is as follows:
g h = 1 0 1 2 0 2 1 0 1 × P i 1 , j 1 P i 1 , j P i 1 , j + 1 P i , j 1 P i , j P i , j + 1 P i + 1 , j 1 P i + 1 , j P i + 1 , j + 1 g v = 1 2 1 0 0 0 1 2 1 × P i 1 , j 1 P i 1 , j P i 1 , j + 1 P i , j 1 P i , j P i , j + 1 P i + 1 , j 1 P i + 1 , j P i + 1 , j + 1
Considering the complexity of high-definition video content, using the Sobel operator to traverse images to obtain gradients greatly increases computational complexity, and the encoder has high time consumption. This article uses the Canny edge detection algorithm to optimize the operation of traversing images. In affine motion models, the Canny edge detection algorithm is more efficient than simply using the Sobel algorithm to obtain the gradient changes of motion vector groups. However, the computational complexity of the Canny edge detection algorithm is higher. Considering that the affine motion estimation model is only used in the inter-prediction module of the VVC encoder, the affine motion model is only used when it meets specific conditions. Therefore, when the encoder chooses to use the affine motion mode, the Canny edge detection algorithm is activated. At the same time, when performing affine motion estimation, the Canny algorithm performs global gradient calculation during the processing of the first frame image and then makes corresponding marks. When processing subsequent images, it detects whether the current encoding block has already been calculated as a gradient in the first frame image. If it has already been calculated, the gradient value is directly read from the cache without the need for global calculations. The purpose of this operation is to skip the image area with unchanged background and focus the focus of image processing on the changing area, which is the calculation of motion vectors. Figure 4 is the C++ Pseudocode proposed for gradient calculation. The specific steps of Figure 4 are as follows:
  • Obtain the original data of the image, initialize the variable, cache, and mark the image with calculated edges.
  • By traversing each pixel of the image, calculate the gradient and error at each pixel position. If isCannyComputed is false, it indicates that the Canny edge image needs to be recalculated for the first time, otherwise, skip.
  • Traverse the image and repeat the calculation.

4. Experiments and Results Analysis

4.1. Simulation Setup

In order to analyze and evaluate the performance of the algorithm proposed in this paper, the official testing software VTM10.0 of H.266/VVC was used as the anchor for testing, and the algorithm proposed in this article was implemented using JVET Common Test Condition (CTC) [34] configuration. The compiling environment is VS 2019, the hardware platform is Intel (R) Core (TM) i5-7300HQ CPU @ 2.50GHz, 16.0GB RAM, and Microsoft Windows 10 64-bit Bitwise operation operating system is adopted. The configuration file in the experiment uses low latency P-frames, and the quantization parameters (QP) are 22,27,32,37. Table 1 shows the experimental environment parameters.

4.2. Performance and Analysis

At the same time, the evaluation index uses The Bjøntegard Delta Bitrate (BDBR) [35] to measure the encoding performance of the proposed algorithm and the original algorithm on Bitrate. A negative number of data indicates that the proposed algorithm can save corresponding data volume, while a negative number indicates an increase in data volume and poor performance. In addition, the Bjø- ntegard delta peak signal-to-noise rate (BD-PSNR) was used to evaluate the performance index of the proposed algorithm and the original algorithm in encoding image quality. A positive value represents an enhancement of the processed image quality, while a negative value indicates significant distortion and poor performance compared to the original image. Table 2 provides parameter information for the test sequence.
Firstly, VTM10.0 and the proposed algorithm are compared. In order to compare the impact of the proposed algorithm and the algorithm in VTM10.0 on encoder encoding time, a formula is defined to calculate the average time of each algorithm.
E n c T a l l , a f f = 1 4 Q P i { 37 , 32 , 27 , 22 } ( T o r g ( Q P i ) T p r o ( Q P i ) T o r g ( Q P i ) × 100 % )
where E n c T a l l , a f f represents the overall encoding time of the encoder or the affine motion estimation encoding time. Due to the corresponding changes in algorithm testing time based on changes in QP, the method of taking the average value is adopted for evaluation and measurement. Table 3 shows the experimental results of the algorithm proposed in this article. In the improved algorithm, the overall encoding time of the encoder was saved by 6.22%, and the encoding time in the affine motion estimation module was reduced by an average of 24.79%. Among them, the reduction in encoding time for sequences BasketballPass, BQSquare, and KristenAndSara affine motion estimation was all over 30%, indicating that the improved algorithm has a good optimization effect on processing video sequences with a large amount of affine motion, It can effectively reduce the encoding time of the encoder. On the contrary, the bitrate of the Basketball Drive video sequence has increased too significantly, indicating a large amount of data when processing certain high-definition videos.
In order to further compare the performance of the algorithm proposed in this article, we will conduct a comparative analysis between the algorithm proposed in this article and the current research methods for related work. As shown in Table 4, compared with REN et al. [33], the algorithm proposed in this paper has a better effect in reducing the overall encoding time of VVC encoders, with little loss in BDPSNR and little increase in bitrate. The method proposed by REN et al [33]. effectively reduces the computational complexity of affine motion estimation, but when CU adopts affine mode, the process of affine motion estimation still needs to be executed, although momentum parameters are added to accelerate the iteration process.
In order to observe more intuitively the compression and distortion degree of the proposed algorithm on video images, Figure 6 shows the RD curves of the test sequences KristenAndSara and Cactus. From the RD curve, it can be seen that the method proposed in this paper coincides with the algorithm curve in the official testing sequence VTM10.0 of VVC. This means that the algorithm proposed in this article greatly shortens the encoding time required by the encoder while maintaining almost constant video quality and bit rate. At the same time, Figure 5 shows the reconstructed and original frames of the video sequence processed by the algorithm in this paper. From the subjective naked eye observation, the distortion of the image is almost invisible. In summary, the algorithm proposed in this article can shorten encoding time while ensuring video quality and bitrate.

5. Conclusions

Due to the complexity of high-definition video content and the addition of multiple optimization algorithms to the encoder, the processing of affine motion estimation in VVC inter-frame prediction needs to be optimized. To address the above issues, this paper proposes a fast affine motion algorithm based on edge detection to accelerate the encoder’s processing of affine motion patterns. By adding pre-judging conditions in the process of constructing affine candidate lists, unnecessary judging steps are skipped to achieve acceleration. In the iterative search process of affine motion vectors, the Canny edge detection algorithm is used to accelerate the iterative gradient, making full use of the readily calculated image gradient, avoiding repeated calculations, and making the calculation process more efficient. The experimental results show that while ensuring the encoding rate and video quality, the overall encoding time of our algorithm is reduced by 6.22% compared to the anchor algorithm encoder, and the encoding time of the affine motion estimation part in the inter-prediction part is reduced by approximately 24.79%. In future research work, we will focus on the overall model of affine motion estimation, which can be combined with hardware to achieve the goal of saving more encoding time.

Author Contributions

Z.D. conceived the idea, J.H. conducted the analyses and writing. X.Z., N.S. and Y.C. contributed to the writing and revisions. P.C. provided funding support. All authors have read and agreed to the published version of the manuscript.

Funding

This work was supported in part by the General Project of National Natural Science Foundation of China under Grant 61972042 and in part by the Discipline Construction Project of Beijing Institute of Graphic Communication under Grant 21090123009

Data Availability Statement

Not applicable.

Conflicts of Interest

The authors declare that they have no known competing financial interests or personal relationships that could have appeared to influence the work reported in this paper.

References

  1. Li, X.; He, J.; Li, Q.; Chen, X. An Adjacency Encoding Information-Based Fast Affine Motion Estimation Method for Versatile Video Coding. Electronics 2022, 11, 3429. [Google Scholar] [CrossRef]
  2. Bross, B.; Chen, J.; Ohm, J.R.; Sullivan, G.J.; Wang, Y.K. Developments in international video coding standardization after avc, with an overview of versatile video coding (vvc). Proceedings of the IEEE 2021, 109, 1463–1493. [Google Scholar] [CrossRef]
  3. Hamidouche, W.; Biatek, T.; Abdoli, M.; François, E.; Pescador, F.; Radosavljević, M.; Menard, D.; Raulet, M. Versatile video coding standard: A review from coding tools to consumers deployment. IEEE Consumer Electronics Magazine 2022, 11, 10–24. [Google Scholar] [CrossRef]
  4. Sidaty, N.; Hamidouche, W.; Déforges, O.; Philippe, P.; Fournier, J. Compression performance of the versatile video coding: HD and UHD visual quality monitoring. In Proceedings of the 2019 Picture Coding Symposium (PCS). IEEE; 2019; pp. 1–5. [Google Scholar]
  5. Li, X.; Chuang, H.; Chen, J.; Karczewicz, M.; Zhang, L.; Zhao, X.; Said, A. Multi-type-tree, document JVET-D0117. In Proceedings of the Proc. of 4th JVET meeting, Chengdu, CN; 2016. [Google Scholar]
  6. Schwarz, H.; Nguyen, T.; Marpe, D.; Wiegand, T. Hybrid video coding with trellis-coded quantization. In Proceedings of the 2019 Data Compression Conference (DCC). IEEE; 2019; pp. 182–191. [Google Scholar]
  7. Zhao, X.; Chen, J.; Karczewicz, M.; Said, A.; Seregin, V. Joint separable and non-separable transforms for next-generation video coding. IEEE Transactions on Image Processing 2018, 27, 2514–2525. [Google Scholar] [CrossRef]
  8. Sethuraman, S. CE9: Results of dmvr related tests CE9. 2.1 and CE9. 2.2. Joint Video Experts Team (JVET) of ITU-T SG 2019, 16, 9–18. [Google Scholar]
  9. Xiu, X.; He, Y.; Ye, Y.; Luo, J. Complexity reduction and bit-width control for bi-directional optical flow, 2022. US Patent 11,470, 308.
  10. Kato, Y.; Toma, T.; Abe, K. Simplification of BDOF, document JVET-O0304. In Proceedings of the Proceedings of the 15th JVET Meeting, Gothenburg, Sweden, 2019, pp. 3–12.
  11. Lin, S.; Chen, H.; Zhang, H.; Sychev, M.; Yang, H.; Zhou, J. Affine transform prediction for next generation video coding, document COM16-C1016. Huawei Technologies, International Organisation for Standardisation Organisation Internationale de Normalisation ISO/IEC JTC1/SC29/WG11 Coding of Moving Pictures and Audio, ISO/IEC JTC1/SC29/WG11 MPEG2015/m37525 2007.
  12. Chen, J.; Karczewicz, M.; Huang, Y.W.; Choi, K.; Ohm, J.R.; Sullivan, G.J. The joint exploration model (JEM) for video compression with capability beyond HEVC. IEEE Transactions on Circuits and Systems for Video Technology 2019, 30, 1208–1225. [Google Scholar] [CrossRef]
  13. Meuel, H.; Ostermann, J. Analysis of affine motion-compensated prediction in video coding. IEEE Transactions on Image Processing 2020, 29, 7359–7374. [Google Scholar] [CrossRef]
  14. Tang, N.; Cao, J.; Liang, F.; Wang, J.; Liu, H.; Wang, X.; Du, X. Fast CTU partition decision algorithm for VVC intra and inter coding. In Proceedings of the 2019 IEEE Asia Pacific Conference on Circuits and Systems (APCCAS). IEEE; 2019; pp. 361–364. [Google Scholar]
  15. Zhang, Q.; Zhao, Y.; Jiang, B.; Huang, L.; Wei, T. Fast CU partition decision method based on texture characteristics for H. 266/VVC. IEEE Access 2020, 8, 203516–203524. [Google Scholar] [CrossRef]
  16. Li, X.; He, J.; Li, Q.; Chen, X. An Adjacency Encoding Information-Based Fast Affine Motion Estimation Method for Versatile Video Coding. Electronics 2022, 11, 3429. [Google Scholar]
  17. Guan, X.; Sun, X. VVC fast ME algorithm based on spatial texture features and time correlation. In Proceedings of the 2021 International Conference on Digital Society and Intelligent Systems (DSInS). IEEE; 2021; pp. 371–377. [Google Scholar]
  18. Zhao, J.; Wu, A.; Zhang, Q. SVM-based fast CU partition decision algorithm for VVC intra coding. Electronics 2022, 11, 2147. [Google Scholar] [CrossRef]
  19. Khan, S.N.; Muhammad, N.; Farwa, S.; Saba, T.; Khattak, S.; Mahmood, Z. Early Cu depth decision and reference picture selection for low complexity Mv-Hevc. Symmetry 2019, 11, 454. [Google Scholar] [CrossRef]
  20. Park, S.H.; Kang, J.W. Fast affine motion estimation for versatile video coding (VVC) encoding. IEEE Access 2019, 7, 158075–158084. [Google Scholar] [CrossRef]
  21. Zhang, K.; Chen, Y.W.; Zhang, L.; Chien, W.J.; Karczewicz, M. An improved framework of affine motion compensation in video coding. IEEE Transactions on Image Processing 2018, 28, 1456–1469. [Google Scholar]
  22. Li, L.; Li, H.; Liu, D.; Li, Z.; Yang, H.; Lin, S.; Chen, H.; Wu, F. An efficient four-parameter affine motion model for video coding. IEEE Transactions on Circuits and Systems for Video Technology 2017, 28, 1934–1948. [Google Scholar] [CrossRef]
  23. Zhang, X.; Ma, S.; Wang, S.; Zhang, X.; Sun, H.; Gao, W. A joint compression scheme of video feature descriptors and visual content. IEEE Transactions on Image Processing 2016, 26, 633–647. [Google Scholar] [CrossRef] [PubMed]
  24. Kordasiewicz, R.C.; Gallant, M.D.; Shirani, S. Affine motion prediction based on translational motion vectors. IEEE Transactions on Circuits and Systems for Video Technology 2007, 17, 1388–1394. [Google Scholar] [CrossRef]
  25. Fortun, D.; Storath, M.; Rickert, D.; Weinmann, A.; Unser, M. Fast piecewise-affine motion estimation without segmentation. IEEE Transactions on Image Processing 2018, 27, 5612–5624. [Google Scholar]
  26. Meuel, H.; Ostermann, J. Analysis of affine motion-compensated prediction in video coding. IEEE Transactions on Image Processing 2020, 29, 7359–7374. [Google Scholar]
  27. Guan, B.; Zhao, J.; Li, Z.; Sun, F.; Fraundorfer, F. Relative pose estimation with a single affine correspondence. IEEE Transactions on Cybernetics 2021, 52, 10111–10122. [Google Scholar] [CrossRef]
  28. Wang, Z.; Wang, S.; Zhang, X.; Wang, S.; Ma, S. Three-zone segmentation-based motion compensation for video compression. IEEE Transactions on Image Processing 2019, 28, 5091–5104. [Google Scholar] [CrossRef]
  29. Zhu, C.; Xu, J.; Feng, D.; Xie, R.; Song, L. Edge-based video compression texture synthesis using generative adversarial network. IEEE Transactions on Circuits and Systems for Video Technology 2022, 32, 7061–7076. [Google Scholar] [CrossRef]
  30. Huang, J.C.; Hsieh, W.S. Automatic feature-based global motion estimation in video sequences. IEEE Transactions on Consumer Electronics 2004, 50, 911–915. [Google Scholar] [CrossRef]
  31. Pfaff, J.; Schwarz, H.; Marpe, D.; Bross, B.; De-Luxán-Hernández, S.; Helle, P.; Helmrich, C.R.; Hinz, T.; Lim, W.Q.; Ma, J.; et al. Video compression using generalized binary partitioning, trellis coded quantization, perceptually optimized encoding, and advanced prediction and transform coding. IEEE Transactions on Circuits and Systems for Video Technology 2019, 30, 1281–1295. [Google Scholar] [CrossRef]
  32. Jung, S.; Jun, D. Context-based inter mode decision method for fast affine prediction in versatile video coding. Electronics 2021, 10, 1243. [Google Scholar] [CrossRef]
  33. Ren, W.; He, W.; Cui, Y. An improved fast affine motion estimation based on edge detection algorithm for VVC. Symmetry 2020, 12, 1143. [Google Scholar] [CrossRef]
  34. Bossen, F.; Boyce, J.; Li, X.; Seregin, V.; Sühring, K. JVET common test conditions and software reference configurations for SDR video. Joint Video Experts Team (JVET) of ITU-T SG 2019, 16, 19–27. [Google Scholar]
  35. Gisle, B. Improvements of the BD-PSNR model. In Proceedings of the ITUT SG16/Q6, 34^< th> VCEG Meeting, Berlin, Germanu, July 2008, 2008.
Figure 1. Affine motion model:(a)four-parameter affine model,(b)six-parameter affine model
Figure 1. Affine motion model:(a)four-parameter affine model,(b)six-parameter affine model
Preprints 80164 g001
Figure 2. Affine advanced motion vector prediction List
Figure 2. Affine advanced motion vector prediction List
Preprints 80164 g002
Figure 3. Affine advanced motion vector prediction Condition
Figure 3. Affine advanced motion vector prediction Condition
Preprints 80164 g003
Figure 4. Pseudocode
Figure 4. Pseudocode
Preprints 80164 g004
Figure 5. Video Sequence:(a) original frame;(b) reconstructed frame.
Figure 5. Video Sequence:(a) original frame;(b) reconstructed frame.
Preprints 80164 g005
Figure 6. RD Curves:(a) KristenAndSara RD Curve;(b) Cactus RD Curve
Figure 6. RD Curves:(a) KristenAndSara RD Curve;(b) Cactus RD Curve
Preprints 80164 g006
Table 1. The environments and conditions of simulation.
Table 1. The environments and conditions of simulation.
Items Descriptions
Software VTM-10.0
Configuration File encoder_lowdelay_P_vtm.cfg
Number of frames to be coded 30
Quantization Parameter 22,27,32,37
Search Range 64
CU size/depth 64/4
Sampling of Luminance to Chrominance 4:2:0
Table 2. Detailed characteristics of the experimental video sequences.
Table 2. Detailed characteristics of the experimental video sequences.
Sequences Size Bit-Depth Frame Rate
BasketballDrive 1920×1080 8 50
Cactus 1920×1080 10 50
FourPeople 1280×720 8 60
KristenAndSara 1280×720 8 60
BasketballDrill 832×480 8 50
PartyScene 832×480 8 50
RaceHorses 416×240 8 30
BQSquare 416×240 8 60
BasketballPass 416×240 8 50
Table 3. The proposed method compared to the original VVC experimental results.
Table 3. The proposed method compared to the original VVC experimental results.
Sequences BDBR/% BD-PSNR/dB EncTall/% EncTaff/%
BasketballPass 0.34 -0.063 11.12 31.80
BQSquare 0.84 -0.115 9.05 32.11
RaceHorses 0.83 -0.037 8.23 23.59
PartyScene 0.93 -0.040 6.92 18.96
BasketballDrill 0.50 -0.019 3.27 15.39
KristenAndSara 1.06 -0.028 4.81 32.98
FourPeople 0.39 -0.018 4.33 27.13
Cactus 0.51 -0.012 4.36 20.47
BasketballDrive 1.50 -0.030 3.89 20.66
Average 0.76 -0.040 6.22 24.79
Table 4. The proposed method compared to the original VVC experimental results.
Table 4. The proposed method compared to the original VVC experimental results.
SequenceName Ren et al. [33] Proposed
BDBR/% SavTall/% BDBR/% SavTall/%
BasketballDrive 0.08 5.00 1.50 3.89
Cactus 0.11 6.00 0.51 4.36
BasketballDrill 0.06 3.00 0.50 3.27
PartyScene 0.26 4.00 0.93 6.92
RaceHorses 0.08 5.00 0.83 8.23
BasketballPass 0.08 2.00 0.34 11.12
Average 0.11 4.16 0.77 6.30
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.
Copyright: This open access article is published under a Creative Commons CC BY 4.0 license, which permit the free download, distribution, and reuse, provided that the author and preprint are cited in any reuse.
Prerpints.org logo

Preprints.org is a free preprint server supported by MDPI in Basel, Switzerland.

Subscribe

© 2024 MDPI (Basel, Switzerland) unless otherwise stated