WO2020006969A1 - 运动矢量预测方法以及相关装置 - Google Patents
运动矢量预测方法以及相关装置 Download PDFInfo
- Publication number
- WO2020006969A1 WO2020006969A1 PCT/CN2018/116984 CN2018116984W WO2020006969A1 WO 2020006969 A1 WO2020006969 A1 WO 2020006969A1 CN 2018116984 W CN2018116984 W CN 2018116984W WO 2020006969 A1 WO2020006969 A1 WO 2020006969A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- current block
- motion vector
- block
- control points
- pixel point
- Prior art date
Links
- 230000033001 locomotion Effects 0.000 title claims abstract description 1226
- 239000013598 vector Substances 0.000 title claims abstract description 942
- 238000000034 method Methods 0.000 title claims abstract description 223
- PXFBZOLANLWPMH-UHFFFAOYSA-N 16-Epiaffinine Natural products C1C(C2=CC=CC=C2N2)=C2C(=O)CC2C(=CC)CN(C)C1C2CO PXFBZOLANLWPMH-UHFFFAOYSA-N 0.000 claims abstract description 525
- 230000009466 transformation Effects 0.000 claims abstract description 341
- 238000003860 storage Methods 0.000 claims description 35
- 238000012545 processing Methods 0.000 claims description 28
- 230000008569 process Effects 0.000 abstract description 44
- 230000006872 improvement Effects 0.000 abstract description 10
- 238000004458 analytical method Methods 0.000 description 20
- 238000010586 diagram Methods 0.000 description 17
- 238000006243 chemical reaction Methods 0.000 description 16
- 238000004891 communication Methods 0.000 description 15
- 238000013500 data storage Methods 0.000 description 15
- 230000005540 biological transmission Effects 0.000 description 13
- 238000013461 design Methods 0.000 description 10
- 238000005516 engineering process Methods 0.000 description 9
- 208000037170 Delayed Emergence from Anesthesia Diseases 0.000 description 6
- 230000006870 function Effects 0.000 description 6
- 230000003287 optical effect Effects 0.000 description 6
- 238000012805 post-processing Methods 0.000 description 6
- 238000013139 quantization Methods 0.000 description 6
- 230000011218 segmentation Effects 0.000 description 6
- 230000004927 fusion Effects 0.000 description 5
- 230000003044 adaptive effect Effects 0.000 description 4
- 238000004590 computer program Methods 0.000 description 4
- 238000013519 translation Methods 0.000 description 4
- 238000010276 construction Methods 0.000 description 3
- 230000001360 synchronised effect Effects 0.000 description 3
- 230000002123 temporal effect Effects 0.000 description 3
- 238000003491 array Methods 0.000 description 2
- 230000008901 benefit Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 230000000295 complement effect Effects 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 238000009795 derivation Methods 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000018109 developmental process Effects 0.000 description 2
- 239000000835 fiber Substances 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 238000013138 pruning Methods 0.000 description 2
- 238000005070 sampling Methods 0.000 description 2
- 230000011664 signaling Effects 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 230000007704 transition Effects 0.000 description 2
- NAWXUBYGYWOOIX-SFHVURJKSA-N (2s)-2-[[4-[2-(2,4-diaminoquinazolin-6-yl)ethyl]benzoyl]amino]-4-methylidenepentanedioic acid Chemical compound C1=CC2=NC(N)=NC(N)=C2C=C1CCC1=CC=C(C(=O)N[C@@H](CC(=C)C(O)=O)C(O)=O)C=C1 NAWXUBYGYWOOIX-SFHVURJKSA-N 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000002457 bidirectional effect Effects 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000014509 gene expression Effects 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 238000012432 intermediate storage Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000014759 maintenance of location Effects 0.000 description 1
- 239000011159 matrix material Substances 0.000 description 1
- 238000005192 partition Methods 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000001502 supplementing effect Effects 0.000 description 1
- 230000001131 transforming effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/537—Motion estimation other than block-based
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/513—Processing of motion vectors
- H04N19/517—Processing of motion vectors by encoding
- H04N19/52—Processing of motion vectors by encoding by predictive encoding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/136—Incoming video signal characteristics or properties
- H04N19/137—Motion inside a coding unit, e.g. average field, frame or block difference
- H04N19/139—Analysis of motion vectors, e.g. their magnitude, direction, variance or reliability
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/119—Adaptive subdivision aspects, e.g. subdivision of a picture into rectangular or non-rectangular coding blocks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/132—Sampling, masking or truncation of coding units, e.g. adaptive resampling, frame skipping, frame interpolation or high-frequency transform coefficient masking
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/176—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/537—Motion estimation other than block-based
- H04N19/54—Motion estimation other than block-based using feature points or meshes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/60—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
- H04N19/61—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/70—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
Definitions
- Embodiments of the present invention relate to the technical field of video coding and decoding, and in particular, to a method and a device for predicting a motion vector of a video image, and a corresponding encoder and decoder.
- Video encoding (video encoding and decoding) is widely used in digital video applications, such as broadcast digital television, video transmission on the Internet and mobile networks, real-time conversation applications such as video chat and video conferencing, DVD and Blu-ray discs, video content acquisition and editing systems And security applications for camcorders.
- Video Coding AVC
- ITU-T H.265 High Efficiency Video Coding
- 3D three-dimensional
- HEVC High Efficiency Video Coding
- Embodiments of the present invention provide a motion vector prediction method and related devices, so as to improve coding efficiency and meet user requirements.
- an embodiment of the present invention provides a motion vector prediction method, which is described from the perspective of a decoding end or an encoding end.
- the method can be used to predict an image block to be processed.
- the image block to be processed is obtained by segmenting a video image. It is obtained that, at the encoding end, the image block to be processed is the current affine coding block, and the decoded image block adjacent to the space of the image block to be processed is an adjacent affine coding block.
- the image block to be processed is the current affine decoding block, and the decoded image block adjacent to the spatial domain of the image block to be processed is the adjacent affine decoding block.
- the image blocks to be processed may be collectively referred to as current blocks, and reference blocks adjacent to the spatial domain of the image blocks to be processed are collectively referred to as neighboring blocks.
- the method includes: parsing a bitstream to obtain an index value of a candidate motion vector list; constructing the candidate motion vector list; wherein the candidate motion vector list includes candidate motion vectors of K control points of a current block; the K The candidate motion vector of the control point is obtained according to an affine transformation model of 2 by N parameters adopted by the neighboring block of the current block, and the affine transformation model of 2 by N parameters is based on the neighboring block Obtained from the motion vectors of N control points, where N is an integer greater than or equal to 2 and less than or equal to 4, K is an integer greater than or equal to 2 and less than or equal to 4, and N is not equal to K; according to the index value, Determine the target candidate motion vector of the K control points from the candidate motion vector list; and obtain the predicted motion vector of each sub-block position in the current block according to
- the decoder can construct a candidate list stage at the current block (such as the stage of constructing a candidate motion vector list based on the affine transformation model AMVP mode or Merge mode). ),
- the affine transformation model of the neighboring block is used to construct the affine transformation model for the current block itself, and the affine transformation models of the two can be different. Since the affine transformation model of the current block is more in line with the actual motion situation / actual requirements of the current block, the implementation of this solution can improve the coding efficiency and accuracy of the prediction of the current block to meet user needs.
- the availability of neighboring blocks of one or more preset airspace positions of the current block may be determined according to a preset order, and then the phases available in the preset order are sequentially obtained.
- the pre-available neighboring blocks may include neighboring image blocks located directly above, directly to the left, upper right, lower left, or upper left of the image block to be processed.
- the availability of the neighboring blocks is sequentially checked in the order of neighboring image blocks to the left, neighboring image blocks to the top, neighboring image blocks to the top right, neighboring image blocks to the bottom left, and neighboring image blocks to the top left.
- the candidate motion vectors of the three control points of the current block include the position of the upper left pixel point in the current block (or the upper left vertex, the same below) (x0, y0) motion vector (vx0, vy0) 2.
- the candidate motion vectors of the three control points of the current block are obtained according to the 4-parameter affine transformation model adopted by the neighboring blocks of the current block, including first calculating the upper left vertex of the current block according to the following formula ( x0, y0) motion vector (vx0, vy0), motion vector (vx1, vy1) of the upper right vertex (x1, y1) of the current block, motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block:
- vx 0 is the horizontal component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vy 0 is the vertical component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vx 1 is the The horizontal component of the motion vector corresponding to the position of the upper right pixel point in the current block
- vy 1 is the vertical component of the motion vector corresponding to the position of the upper right pixel point in the current block
- vx 2 is the upper right pixel point in the current block
- vy 2 is the vertical component of the motion vector corresponding to the position of the upper-right pixel point in the current block
- vx 4 is the motion vector corresponding to the position of the upper-left pixel point in the adjacent block.
- vy 4 is the vertical component of the motion vector corresponding to the position of the upper-left pixel point in the adjacent block
- vx 5 is the horizontal component of the motion vector corresponding to the position of the upper-right pixel point in the adjacent block
- vy 5 Is the vertical component of the motion vector corresponding to the position of the upper-right pixel point in the adjacent block
- x 0 is the abscissa of the position of the upper-left pixel point in the current block
- y 0 is the position of the upper-left pixel point in the current block vertical Coordinates
- x 1 is the abscissa of the position of the upper-right pixel point in the current block
- y 1 is the ordinate of the position of the upper-right pixel point in the current block
- x 2 is the abscissa of the position of the lower-left pixel point in the current block
- y 2 is the vertical coordinate of the pixel position of the lower left corner in the current block.
- x 4 is the abscissa of the position of the upper left pixel point in the adjacent block
- y 4 is the ordinate of the position of the upper left pixel point in the current block
- x 5 is the abscissa of the position of the upper right pixel point in the adjacent block.
- the candidate motion vectors of the two control points of the current block include the position of the upper left pixel point (or the upper left vertex, the same below) (x0, y0) in the current block (vx0, vy0). 2.
- the candidate motion vectors of the two control points of the current block are based on the Obtained from the 6-parameter affine transformation model adopted by the neighboring blocks of the current block, including calculating the candidate motion vectors of the 2 control points of the current block according to the following formula:
- vx 0 is the horizontal component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vy 0 is the vertical component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vx 1 is the The horizontal component of the motion vector corresponding to the position of the upper-right pixel point in the current block
- vy 1 is the vertical component of the motion vector corresponding to the position of the upper-right pixel point in the current block
- vx 4 is the upper-left pixel in the adjacent block
- the horizontal component of the motion vector corresponding to the position of the point, vy 4 is the vertical component of the motion vector corresponding to the position of the upper left pixel point in the adjacent block
- vx 5 is the motion corresponding to the position of the upper right pixel point in the adjacent block
- the horizontal component of the vector, vy 5 is the vertical component of the motion vector corresponding to the pixel position of the upper right corner in the adjacent block
- the implementation of the embodiment of the present invention can realize the affine transformation model for the current block by using the affine transformation model of the neighboring block during the analysis stage of the current block (such as the stage of constructing the candidate motion vector list). , And the affine transformation models of the two can be different. Since the affine transformation model of the current block is more in line with the actual motion situation / actual requirements of the current block, the implementation of this solution can improve the coding efficiency and accuracy of the prediction of the current block to meet user needs.
- the process of obtaining the predicted motion vector of each sub-block in the current block includes the following process: According to the target candidate motion vectors of the K control points, the obtained The affine transformation model of 2 ⁇ K parameters of the current block is described; and the predicted motion vector of each sub-block in the current block is obtained according to the affine transformation model of 2 ⁇ K parameters of the current block.
- the motion vectors corresponding to the point coordinates are used as the motion vectors (vx (i, j) , vy (i, j) ) of all pixels in the sub-block:
- the affine motion model used by the current affine decoding block is a 4-parameter affine motion model
- the pixel point coordinates (x (i, j) , y (i, j) ) in the sub-block are substituted into the 4-parameter affine motion model formula to obtain the pixel in each sub-block.
- the motion vectors corresponding to the point coordinates are used as the motion vectors (vx (i, j) , vy (i, j) ) of all pixels in the sub-block:
- the process of obtaining the predicted motion vectors of each sub-block in the current block includes the following process: according to the target candidate motions of the K control points of the current block Vector to obtain the 6-parameter affine transformation model of the current block; according to the 6-parameter affine transformation model of the current block, obtain the predicted motion vector of each sub-block in the current block.
- the 6-parameter affine transformation model is uniformly used to obtain the current block. Motion vector information of each sub-block, thereby achieving reconstruction of each sub-block. For example, if a 4-parameter affine transformation model or an 8-parameter bilinear model is used in the analysis phase, a 6-parameter affine transformation model of the current block will be further constructed. If the 6-parameter affine transformation model is used in the parsing stage, the 6-parameter affine transformation model of the current block continues to be used in the reconstruction stage.
- the current block uses a 4-parameter affine transformation model during the analysis phase
- the neighboring block may use a 4-parameter affine transformation model
- it may also use other parameter affine models.
- the motion vectors of the 2 control points of the current block for example, obtaining the motion vector values (vx4, vy4) and the upper right control points (x5, y5) of the current block's upper left control point (x4, y4) Vector value (vx5, vy5).
- a 6-parameter affine transformation model needs to be constructed according to the motion vectors of the 2 control points of the current block.
- the following control formula is used to obtain the third control point
- the motion vector value of the third control point is, for example, the motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block:
- the motion vector (vx0, vy0) of the upper left control point (x0, y0) of the current block the motion vector (vx1, vy1) of the upper right control point (x1, y1), and the motion vector of the lower left vertex (x2, y2) ( vx2, vy2) to obtain the 6-parameter affine model of the current block reconstruction phase.
- the formula of the 6-parameter affine model is as follows:
- the coordinates (x (i, j) ) of the preset position pixel point (such as the center point) of each sub-block (or each motion compensation unit) in the current block with respect to the upper-left vertex (or other reference point) of the current block, y (i, j) ) is substituted into the above parameter 6 parameter affine model formula, and the motion information of the pixel at the preset position of each sub-block (or each motion compensation unit) can be obtained, and then the reconstruction of each sub-block is subsequently realized.
- the embodiments of the present invention it is possible to implement a unified 6-parameter affine transformation model to predict the current block during the reconstruction stage of the current block. Because the more parameters of the motion model describing the affine motion of the current block, the higher the accuracy, the higher the computational complexity.
- the 6-parameter affine transformation model constructed in the reconstruction phase of this solution can describe the affine transformation of image blocks such as translation, scaling, rotation, etc., and achieves a good balance between model complexity and modeling capabilities. Therefore, the implementation of this solution can improve the coding efficiency and accuracy of prediction of the current block, and meet user needs
- the affine transformation of the 2 ⁇ K parameters is obtained according to the target candidate motion vectors of the K control points.
- the model includes: obtaining the motion vectors of the K control points according to the target candidate motion vectors of the K control points and the motion vector difference of the K control points; The motion vector difference is obtained by analyzing the code stream; according to the motion vectors of the K control points, an affine transformation model of 2 ⁇ K parameters of the current block is obtained.
- the encoding end and the decoding end use the AMVP mode based on the affine transformation model to perform inter prediction, and the constructed list is a candidate motion vector list of the AMVP mode of the affine transformation model.
- the first motion vector prediction method based on a motion model described herein may be used to obtain a candidate motion vector of a control point of a current block to be added to a candidate motion vector list corresponding to an AMVP mode.
- the first motion vector prediction method based on the motion model and the control point motion vector prediction method constructed can also be used, and the candidate motion vectors of the control points of the current block are separately added to the AMVP mode correspondingly. List of candidate motion vectors.
- the encoding end and the decoding end use the Merge mode based on the affine transformation model to perform inter prediction, and the constructed list is a candidate motion vector list of the Merge mode of the affine transformation model.
- the first motion vector prediction method based on a motion model described herein may also be used to obtain the candidate motion vector of the control point of the current block to be added to the candidate motion vector list corresponding to the Merge mode.
- the first motion vector prediction method based on the motion model and the control point motion vector prediction method based on the structure can also be used.
- the candidate motion vectors of the control points of the current block are added to the Merge mode respectively. List of candidate motion vectors.
- both the affine decoding blocks with the same number of parameters as the current block model can be used to obtain the candidate motion vectors of the control points of the current block and added to the candidate motion vector list corresponding to the AMVP mode.
- an affine decoding block with a different number of parameters from the current block model is used to obtain candidate motion vectors for the control points of the current block, and is added to the candidate motion vector list corresponding to the AMVP mode.
- the decoding end during the process of deriving the candidate motion vector of the control point of the current block by the decoding end, it may be necessary to obtain flag information of the affine transformation model of the affine decoding block.
- the flag is stored locally in the decoding end in advance, and the flag is used to indicate the affine transformation model that is actually used when the affine decoding block performs its own sub-block prediction.
- the decoding end when the decoding end recognizes the flag of the affine decoding block, it is determined that the number of model parameters of the affine transformation model actually used by the affine decoding block and the affine transformation model used by the current block are different (or The same), trigger the decoder to use the affine transformation model actually adopted by the affine decoding block to derive the candidate motion vector of the control point of the current block.
- the flag of the affine transformation model of the affine decoding block may not be required.
- the decoder determines the affine transformation model used by the current block
- the decoder obtains the control of a specific number of affine decoded blocks (the specific number is the same as or different from the number of control points of the current block).
- Point a specific number of control points of the affine decoding block are used to form an affine transformation model, and the affine transformation model is used to derive a candidate motion vector of the control point of the current block.
- an embodiment of the present invention provides another motion vector prediction method.
- the method includes: parsing a code stream to obtain an index value of a candidate motion vector list; constructing the candidate motion vector list; wherein the candidate motion vector
- the list includes candidate motion vectors of K control points of the current block; the candidate motion vectors of K control points of the current block are obtained according to an affine transformation model of 2N parameters adopted by neighboring blocks of the current block,
- the 2N parameter affine transformation model is obtained based on the motion vectors of N control points of the neighboring blocks, where N is an integer greater than or equal to 2 and less than or equal to 4, and K is an integer greater than or equal to 2 and less than or equal to 4.
- the adjacent block is a decoded image block that is adjacent to the current block space, the current block includes a plurality of sub-blocks; and an index of the current block is determined from the candidate motion vector list according to the index value
- a target candidate motion vector of K control points according to the target candidate motion vector of K control points of the current block, an affine transformation model of 6 parameters of the current block is obtained;
- the 6-parameter affine transformation model of the previous block obtains the predicted motion vector of each sub-block in the current block.
- the embodiments of the present invention it is possible to implement a unified 6-parameter affine transformation model to predict the current block during the reconstruction stage of the current block. Because the more parameters of the motion model describing the affine motion of the current block, the higher the accuracy, the higher the computational complexity.
- the 6-parameter affine transformation model constructed in the reconstruction phase of this solution can describe the affine transformation of image blocks such as translation, scaling, rotation, etc., and achieves a good balance between model complexity and modeling capabilities. Therefore, the implementation of this solution can improve the coding efficiency and accuracy of prediction of the current block, and meet user needs.
- the candidate motion vectors of the two control points of the current block are obtained according to a 4-parameter affine transformation model adopted by neighboring blocks of the current block.
- the candidate motion vectors of the 2 control points of the current block are based on 6 parameters adopted by the neighboring blocks of the current block Affine transformation model.
- obtaining the 6-parameter affine transformation model of the current block according to the target candidate motion vectors of the K control points of the current block includes:
- a 6-parameter affine transformation model of the current block is obtained according to the target candidate motion vector of the 2 control points of the current block and the motion vector of the third control point.
- the obtaining a 4-parameter affine transformation model of the current block according to the target candidate motion vectors of 2 control points of the current block includes:
- obtaining the 6-parameter affine transformation model of the current block according to the target candidate motion vector of the 2 control points of the current block and the motion vector of the third control point includes:
- an affine transformation model of 6 parameters of the current block is obtained.
- the candidate motion vectors of the 3 control points of the current block are based on 2 parameters adopted by neighboring blocks of the current block. Affine transformation model.
- an embodiment of the present invention provides a decoding device.
- the device includes: a storage unit for storing video data in the form of a code stream; and an entropy decoding unit for parsing the code stream to obtain a list of candidate motion vectors.
- An index value a prediction processing unit configured to construct the candidate motion vector list; wherein the candidate motion vector list includes candidate motion vectors of K control points of the current block; candidate motion vectors of K control points of the current block
- the vector is obtained according to an affine transformation model of 2 by N parameters adopted by neighboring blocks of the current block, and the affine transformation model of 2 by N parameters is based on N control points of the neighboring blocks ,
- N is an integer greater than or equal to 2 and less than or equal to 4
- K is an integer greater than or equal to 2 and less than or equal to 4
- N is not equal to K
- the adjacent block is the same as the current block
- the current block includes a plurality of sub-blocks, and a target candidate motion vector of K control points of the current block is determined from the candidate motion vector list according to the index value
- a root According to the target candidate motion vectors of the K control points of the current block, the predicted motion vectors of each sub-block in the current block are obtained.
- each module of the device may be used to implement the method described in the first aspect.
- an embodiment of the present invention provides a decoding device.
- the device includes: a storage unit for storing video data in the form of a code stream; and an entropy decoding unit for parsing the code stream to obtain a list of candidate motion vectors.
- An index value a prediction processing unit configured to parse a code stream to obtain an index value of a candidate motion vector list; construct the candidate motion vector list; wherein the candidate motion vector list includes candidate motion vectors of K control points of the current block;
- the candidate motion vectors of the K control points of the current block are obtained according to an affine transformation model of 2N parameters adopted by neighboring blocks of the current block, and the affine transformation model of the 2N parameters is based on the neighboring A motion vector of N control points of a block, where N is an integer greater than or equal to 2 and less than or equal to 4 and K is an integer greater than or equal to 2 and less than or equal to 4; the adjacent block is spaced from the current block.
- the current block includes a plurality of sub-blocks
- the target of the K control points of the current block is determined from the candidate motion vector list according to the index value Selecting a motion vector; obtaining a 6-parameter affine transformation model of the current block according to the target candidate motion vectors of the K control points of the current block; The predicted motion vector of each sub-block in the current block is described.
- each module of the device may be used to implement the method described in the second aspect.
- an embodiment of the present invention provides a device for decoding a video, and the device includes:
- Memory for storing video data in the form of a stream
- a decoder for constructing the candidate motion vector list wherein the candidate motion vector list includes candidate motion vectors of the K control points of the current block; the candidate motion vectors of the K control points of the current block are based on the It is obtained by using an affine transformation model of 2 by N parameters of the neighboring block of the current block, and the affine transformation model of 2 by N parameters is based on the motion vectors of N control points of the neighboring block. Obtained, where N is an integer greater than or equal to 2 and less than or equal to 4, K is an integer greater than or equal to 2 and less than or equal to 4, and N is not equal to K; the adjacent block is an already adjacent to the current block space.
- the current block includes a plurality of sub-blocks; determining target candidate motion vectors of K control points of the current block from the candidate motion vector list according to the index value; and according to K of the current block Target candidate motion vectors for each control point to obtain predicted motion vectors for each sub-block in the current block.
- N is equal to 2 and K is equal to 3. Accordingly, the candidate motion vectors of the 3 control points of the current block are based on the 4-parameters adopted by the neighboring blocks of the current block. Affine transformation model.
- the candidate motion vectors of the three control points of the current block include the motion vector of the pixel position of the upper left corner in the current block, and the position of the pixel point of the upper right corner in the current block.
- the decoder is configured to calculate candidate motion vectors of 3 control points of the current block according to the following formula:
- vx 0 is the horizontal component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vy 0 is the vertical component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vx 1 is the The horizontal component of the motion vector corresponding to the position of the upper right pixel point in the current block
- vy 1 is the vertical component of the motion vector corresponding to the position of the upper right pixel point in the current block
- vx 2 is the upper right pixel point in the current block
- vy 2 is the vertical component of the motion vector corresponding to the position of the upper-right pixel point in the current block
- vx 4 is the motion vector corresponding to the position of the upper-left pixel point in the adjacent block.
- vy 4 is the vertical component of the motion vector corresponding to the position of the upper-left pixel point in the adjacent block
- vx 5 is the horizontal component of the motion vector corresponding to the position of the upper-right pixel point in the adjacent block
- vy 5 Is the vertical component of the motion vector corresponding to the position of the upper-right pixel point in the adjacent block
- x 0 is the abscissa of the position of the upper-left pixel point in the current block
- y 0 is the position of the upper-left pixel point in the current block vertical Coordinates
- x 1 is the abscissa of the position of the upper-right pixel point in the current block
- y 1 is the ordinate of the position of the upper-right pixel point in the current block
- x 2 is the abscissa of the position of the lower-left pixel point in the current block
- y 2 is the vertical coordinate of the pixel position of the lower left corner in the current block
- x 4
- N is equal to 3 and K is equal to 2.
- the candidate motion vectors of the 2 control points of the current block are based on the 6 parameters adopted by the neighboring blocks of the current block. Affine transformation model.
- the candidate motion vectors of the two control points of the current block include the motion vector of the pixel position of the upper left corner in the current block and the position of the pixel point of the upper right corner in the current block.
- the decoder is configured to calculate a candidate motion vector of 2 control points of the current block according to the following formula:
- vx 0 is the horizontal component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vy 0 is the vertical component of the motion vector corresponding to the position of the upper-left pixel point in the current block
- vx 1 is the The horizontal component of the motion vector corresponding to the position of the upper-right pixel point in the current block
- vy 1 is the vertical component of the motion vector corresponding to the position of the upper-right pixel point in the current block
- vx 4 is the upper-left pixel in the adjacent block
- the horizontal component of the motion vector corresponding to the position of the point, vy 4 is the vertical component of the motion vector corresponding to the position of the upper left pixel point in the adjacent block
- vx 5 is the motion corresponding to the position of the upper right pixel point in the adjacent block
- the horizontal component of the vector, vy 5 is the vertical component of the motion vector corresponding to the pixel position of the upper right corner in the adjacent block
- the decoder is specifically configured to:
- the decoder is specifically configured to:
- the motion vector difference of K control points is obtained by analyzing the code stream
- An affine transformation model of 2 by K parameters of the current block is obtained according to the motion vectors of the K control points of the current block.
- the pre-decoder after determining the target candidate motion vectors of the K control points of the current block from the candidate motion vector list according to the index value, the pre-decoder further Used for:
- an embodiment of the present invention provides another device for decoding a video.
- the device includes:
- Memory for storing video data in the form of a stream
- the candidate motion vectors of K control points are obtained according to the 2N parameter affine transformation model used for the neighboring block of the current block, and the 2N parameter affine transformation model is based on the N neighboring blocks. Obtained by controlling the motion vector of the point, where N is an integer greater than or equal to 2 and less than or equal to 4, and K is an integer greater than or equal to 2 and less than or equal to 4; the adjacent block is a decoded adjacent to the current block space.
- An image block the current block includes a plurality of sub-blocks; determining target candidate motion vectors of K control points of the current block from the candidate motion vector list according to the index value; and according to the K numbers of the current block
- the target candidate motion vector of the control point is used to obtain the 6-parameter affine transformation model of the current block; according to the 6-parameter affine transformation model of the current block, the sub-blocks of the current block are obtained. Measuring the motion vector.
- an embodiment of the present invention provides a computer-readable storage medium having stored thereon instructions that, when executed, cause one or more processors to encode video data.
- the instructions cause the one or more processors to perform a method according to any possible embodiment of the first aspect.
- an embodiment of the present invention provides a computer-readable storage medium having stored thereon instructions that, when executed, cause one or more processors to encode video data.
- the instructions cause the one or more processors to perform a method according to any possible embodiment of the second aspect.
- an embodiment of the present invention provides a computer program including a program code that, when run on a computer, executes a method according to any possible embodiment of the first aspect.
- an embodiment of the present invention provides a computer program including a program code that, when run on a computer, performs a method according to any possible embodiment of the second aspect.
- the process of encoding and decoding the current block in the process of encoding and decoding the current block, it can be implemented in the parsing stage of the current block (such as the stage of constructing the candidate motion vector list of the AMVP mode or the Merge mode), using adjacent blocks
- the affine transformation models of the two can be different. Since the affine transformation model of the current block is more in line with the actual motion / actual requirements of the current block, implementing this solution can improve the coding efficiency and accuracy of encoding the current block, and meet user needs.
- the decoding end can uniformly use the 6-parameter affine transformation model to predict the image block during the reconstruction phase of the image block, so that the embodiment of the present invention reconstructs the current block.
- the process strikes a good balance between model complexity and modeling capabilities. Therefore, the implementation of this solution can improve the coding efficiency and accuracy of prediction of the current block, and meet user needs.
- FIG. 1 is a block diagram of an example structure of a video decoding system for implementing an embodiment of the present invention
- FIG. 2A is a block diagram of an example structure of a video encoder for implementing an embodiment of the present invention
- 2B is a block diagram of an example structure of a video decoder for implementing an embodiment of the present invention
- FIG. 3 is a block diagram of an example of a video decoding device for implementing an embodiment of the present invention.
- FIG. 4 is a block diagram of an example of an encoding device or a decoding device for implementing an embodiment of the present invention
- FIG. 5 is a schematic diagram of a scenario operation on the current block
- FIG. 6 is a schematic diagram of another scenario operation on the current block
- FIG. 7 is a schematic diagram of another scenario operation on the current block
- FIG. 9 is a flowchart of a motion vector prediction method according to an embodiment of the present invention.
- FIG. 10 is a schematic diagram of another scenario operation on the current block
- 11A is a schematic diagram of a current block and a motion compensation unit of the current block according to an embodiment of the present invention
- 11B is a schematic diagram of another current block and a motion compensation unit of the current block according to an embodiment of the present invention.
- FIG. 12 is a flowchart of another motion vector prediction method according to an embodiment of the present invention.
- FIG. 13 is a flowchart of another motion vector prediction method according to an embodiment of the present invention.
- the technical solutions involved in the embodiments of the present invention may not only be applied to existing video coding standards (such as H.264, HEVC and other standards), but also to future video coding standards (such as H.266 standard).
- Video coding generally refers to processing a sequence of pictures that form a video or a video sequence.
- picture In the field of video coding, the terms “picture”, “frame” or “image” can be used as synonyms.
- Video encoding as used herein means video encoding or video decoding.
- Video encoding is performed on the source side and typically involves processing (e.g., by compressing) the original video picture to reduce the amount of data required to represent the video picture, thereby storing and / or transmitting more efficiently.
- Video decoding is performed on the destination side and usually involves inverse processing relative to the encoder to reconstruct the video picture.
- the “encoding” of a video picture involved in the embodiment should be understood as “encoding” or “decoding” of a video sequence.
- the combination of the encoding part and the decoding part is also called codec (encoding and decoding).
- the video sequence includes a series of pictures.
- the pictures are further divided into slices, and the slices are divided into blocks.
- Video encoding is encoded in blocks.
- the concept of blocks is further expanded.
- MB macroblock
- the macroblock can be further divided into multiple prediction blocks (partitions) that can be used for predictive coding.
- HEVC high-performance video coding
- basic concepts such as coding unit (CU), prediction unit (PU), and transformation unit (TU) are used. Functionally, Divided a variety of block units, and used a new tree-based description.
- a CU can be divided into smaller CUs according to a quad tree, and smaller CUs can be further divided to form a quad tree structure.
- a CU is a basic unit for dividing and encoding a coded image.
- the PU can correspond to the prediction block and is the basic unit of prediction coding.
- the CU is further divided into multiple PUs according to the division mode.
- TU can correspond to a transform block and is a basic unit for transforming prediction residuals.
- no matter CU, PU or TU they all belong to the concept of block (or image block).
- a CTU is split into multiple CUs by using a quad-tree structure represented as a coding tree.
- a decision is made at the CU level whether to use inter-picture (temporal) or intra-picture (spatial) prediction to encode a picture region.
- Each CU can be further split into one, two, or four PUs according to the PU split type.
- the same prediction process is applied in a PU, and related information is transmitted to the decoder on the basis of the PU.
- a CU may be partitioned into a transform unit (TU) according to other quad-tree structures similar to a coding tree for a CU.
- quad-tree and binary-tree (QTBT) split frames are used to split coded blocks.
- the CU can be a square or rectangular shape.
- the image block to be encoded in the currently encoded image may be referred to as the current block, for example, in encoding, it means the block currently being encoded; in decoding, it means the block currently being decoded.
- the decoded image block in the reference image used to predict the current block is referred to as a reference block, that is, the reference block is a block that provides a reference signal for the current block, where the reference signal represents a pixel value within the image block.
- a block in the reference image that provides a prediction signal for the current block may be a prediction block, where the prediction signal represents a pixel value or a sampling value or a sampling signal within the prediction block. For example, after traversing multiple reference blocks, the best reference block is found. This best reference block will provide prediction for the current block. This block can be called a prediction block.
- FIG. 1 is a block diagram of a video decoding system according to an example described in the embodiment of the present invention.
- video coder generally refers to both video encoders and video decoders.
- video coding or “coding” may generally refer to video encoding or video decoding.
- the video encoder 100 and the video decoder 200 of the video coding system are used to predict a current coded image according to various method examples described in any of a variety of new inter prediction modes proposed by the embodiments of the present invention.
- the motion information of the block or its sub-blocks makes the predicted motion vector to the greatest extent close to the motion vector obtained by using the motion estimation method, so that the motion vector difference is not transmitted during encoding, thereby further improving the encoding and decoding performance.
- the video decoding system includes a source device 10 and a destination device 20.
- the source device 10 generates encoded video data. Therefore, the source device 10 may be referred to as a video encoding device.
- the destination device 20 may decode the encoded video data generated by the source device 10. Therefore, the destination device 20 may be referred to as a video decoding device.
- Various implementations of the source device 10, the destination device 20, or both may include one or more processors and a memory coupled to the one or more processors.
- the memory may include, but is not limited to, RAM, ROM, EEPROM, flash memory, or any other medium that can be used to store the desired program code in the form of instructions or data structures accessible by a computer, as described herein.
- the source device 10 and the destination device 20 may include various devices including desktop computers, mobile computing devices, notebook (e.g., laptop) computers, tablet computers, set-top boxes, telephone handsets, such as so-called “smart” phones, etc. Cameras, televisions, cameras, display devices, digital media players, video game consoles, on-board computers, or the like.
- the destination device 20 may receive the encoded video data from the source device 10 via the link 30.
- the link 30 may include one or more media or devices capable of moving the encoded video data from the source device 10 to the destination device 20.
- the link 30 may include one or more communication media enabling the source device 10 to directly transmit the encoded video data to the destination device 20 in real time.
- the source device 10 may modulate the encoded video data according to a communication standard, such as a wireless communication protocol, and may transmit the modulated video data to the destination device 20.
- the one or more communication media may include wireless and / or wired communication media, such as a radio frequency (RF) spectrum or one or more physical transmission lines.
- RF radio frequency
- the one or more communication media may form part of a packet-based network, such as a local area network, a wide area network, or a global network (eg, the Internet).
- the one or more communication media may include a router, a switch, a base station, or other devices that facilitate communication from the source device 10 to the destination device 20.
- the encoded data may be output from the output interface 140 to the storage device 40.
- the encoded data can be accessed from the storage device 40 through the input interface 240.
- the storage device 40 may include any of a variety of distributed or locally accessed data storage media, such as a hard drive, Blu-ray disc, DVD, CD-ROM, flash memory, volatile or non-volatile memory, Or any other suitable digital storage medium for storing encoded video data.
- the storage device 40 may correspond to a file server or another intermediate storage device that may hold the encoded video produced by the source device 10.
- the destination device 20 may access the stored video data from the storage device 40 via streaming or download.
- the file server may be any type of server capable of storing encoded video data and transmitting the encoded video data to the destination device 20.
- Example file servers include a web server (eg, for a website), an FTP server, a network attached storage (NAS) device, or a local disk drive.
- the destination device 20 can access the encoded video data through any standard data connection, including an Internet connection.
- This may include a wireless channel (e.g., a Wi-Fi connection), a wired connection (e.g., DSL, cable modem, etc.), or a combination of both suitable for accessing encoded video data stored on a file server.
- the transmission of the encoded video data from the storage device 40 may be a streaming transmission, a download transmission, or a combination of the two.
- the motion vector prediction technology of the embodiment of the present invention can be applied to video encoding and decoding to support a variety of multimedia applications, such as air television broadcasting, cable television transmission, satellite television transmission, streaming video transmission (e.g., via the Internet), for storage Encoding of video data on a data storage medium, decoding of video data stored on a data storage medium, or other applications.
- a video coding system may be used to support one-way or two-way video transmission to support applications such as video streaming, video playback, video broadcasting, and / or video telephony.
- the video decoding system illustrated in FIG. 1 is only an example, and the techniques of the embodiments of the present invention can be applied to video decoding settings (for example, video encoding or video decoding) that do not necessarily include any data communication between the encoding device and the decoding device. ).
- data is retrieved from local storage, streamed over a network, and so on.
- the video encoding device may encode the data and store the data to a memory, and / or the video decoding device may retrieve the data from the memory and decode the data.
- encoding and decoding are performed by devices that do not communicate with each other, but only encode data to and / or retrieve data from memory and decode data.
- the source device 10 includes a video source 120, a video encoder 100, and an output interface 140.
- the output interface 140 may include a regulator / demodulator (modem) and / or a transmitter.
- Video source 120 may include a video capture device (e.g., a video camera), a video archive containing previously captured video data, a video feed interface to receive video data from a video content provider, and / or a computer for generating video data Graphics systems, or a combination of these sources of video data.
- the video encoder 100 may encode video data from the video source 120.
- the source device 10 transmits the encoded video data directly to the destination device 20 via the output interface 140.
- the encoded video data may also be stored on the storage device 40 for later access by the destination device 20 for decoding and / or playback.
- the destination device 20 includes an input interface 240, a video decoder 200, and a display device 220.
- the input interface 240 includes a receiver and / or a modem.
- the input interface 240 may receive encoded video data via the link 30 and / or from the storage device 40.
- the display device 220 may be integrated with the destination device 20 or may be external to the destination device 20. Generally, the display device 220 displays decoded video data.
- the display device 220 may include various display devices, such as a liquid crystal display (LCD), a plasma display, an organic light emitting diode (OLED) display, or other types of display devices.
- LCD liquid crystal display
- OLED organic light emitting diode
- video encoder 100 and video decoder 200 may each be integrated with an audio encoder and decoder, and may include a suitable multiplexer-demultiplexer unit Or other hardware and software to handle encoding of both audio and video in a common or separate data stream.
- the MUX-DEMUX unit may conform to the ITU H.223 multiplexer protocol, or other protocols such as the User Datagram Protocol (UDP), if applicable.
- UDP User Datagram Protocol
- Video encoder 100 and video decoder 200 may each be implemented as any of a variety of circuits, such as one or more microprocessors, digital signal processors (DSPs), application specific integrated circuits (ASICs), Field Programmable Gate Array (FPGA), discrete logic, hardware, or any combination thereof. If the embodiments of the present invention are implemented partially in software, the device may store instructions for the software in a suitable non-volatile computer-readable storage medium, and may use one or more processors to execute all of the hardware in hardware. The instructions thus implement the techniques of the embodiments of the present invention. Any of the foregoing (including hardware, software, a combination of hardware and software, etc.) may be considered as one or more processors. Each of video encoder 100 and video decoder 200 may be included in one or more encoders or decoders, any of which may be integrated as a combined encoder in a corresponding device / Decoder (codec).
- codec device / Decoder
- Embodiments of the invention may generally refer to video encoder 100 as “signaling” or “transmitting” certain information to another device, such as video decoder 200.
- the terms “signaling” or “transmitting” may generally refer to the transmission of syntax elements and / or other data used to decode compressed video data. This transfer can occur in real time or almost real time. Alternatively, this communication may occur over a period of time, such as when a syntax element is stored in a coded bitstream to a computer-readable storage medium at the time of encoding, and the decoding device may then after the syntax element is stored in this medium. retrieve the syntax element at any time.
- the video encoder 100 and the video decoder 200 may operate according to a video compression standard such as High Efficiency Video Coding (HEVC) or an extension thereof, and may conform to the HEVC test model (HM).
- HEVC High Efficiency Video Coding
- HM HEVC test model
- the video encoder 100 and video decoder 200 may also operate according to other industry standards, such as the ITU-T H.264, H.265 standards, or extensions of such standards.
- the technology of the embodiments of the present invention is not limited to any particular codec standard.
- the video encoder 100 is configured to encode syntax elements related to a current image block to be encoded into a digital video output bit stream (referred to as a bit stream or code stream), which will be used between the current image block frames.
- the syntax element of prediction is referred to as inter prediction data for short.
- the inter prediction data includes, for example, indication information of an inter prediction mode.
- the inter prediction mode in the embodiment of the present invention includes an AMVP mode based on an affine transformation model and an affine transformation model. At least one of the Merge modes.
- the inter prediction data may further include an index value (or an index number) of a candidate motion vector list corresponding to the AMVP mode, and Motion vector difference (MVD) of the control point of the current block; if the inter prediction data includes indication information of a Merge mode based on an affine transformation model, the inter prediction data may further include candidates corresponding to the Merge mode The index value (or index number) of the motion vector list.
- the inter prediction data in the above example may further include indication information of an affine transformation model (the number of model parameters) of the current block.
- the video encoder 100 may be configured to execute the embodiment of FIG. 13 described later to implement the motion vector prediction method described in the present invention at the encoding end.
- the video decoder 200 is configured to decode a syntax element related to the image block to be decoded from the bit stream (S401).
- the syntax element used for inter prediction of the current image block is referred to as an inter frame for short.
- the prediction data and the inter prediction data include, for example, indication information of an inter prediction mode.
- the inter prediction mode in the embodiment of the present invention includes at least one of an AMVP mode based on an affine transformation model and a Merge mode based on an affine transformation model.
- the inter prediction data may further include an index value (or an index number) of a candidate motion vector list corresponding to the AMVP mode, and Motion vector difference (MVD) of the control point of the current block; if the inter prediction data includes indication information of a Merge mode based on an affine transformation model, the inter prediction data may further include candidates corresponding to the Merge mode The index value (or index number) of the motion vector list.
- the inter prediction data in the above example may further include indication information of an affine transformation model (the number of model parameters) of the current block.
- the video decoder 200 may be configured to execute the embodiments shown in FIG. 9 or FIG. 12 described later, so as to implement the application of the motion vector prediction method described in the present invention at the decoding end.
- FIG. 2A is a block diagram of a video encoder 100 according to an example described in the embodiment of the present invention.
- the video encoder 100 is configured to output a video to the post-processing entity 41.
- the post-processing entity 41 represents an example of a video entity that can process encoded video data from the video encoder 100, such as a media-aware network element (MANE) or a stitching / editing device.
- the post-processing entity 41 may be an instance of a network entity.
- the post-processing entity 41 and the video encoder 100 may be parts of a separate device, while in other cases, the functionality described with respect to the post-processing entity 41 may be performed by the same device including the video encoder 100 carried out.
- the post-processing entity 41 is an example of the storage device 40 of FIG. 1.
- the video encoder 100 includes a prediction processing unit 108, a filter unit 106, a decoded image buffer (DPB) 107, a summer 112, a transformer 101, a quantizer 102, and an entropy encoder 103.
- the prediction processing unit 108 includes an inter predictor 110 and an intra predictor 109.
- the video encoder 100 further includes an inverse quantizer 104, an inverse transformer 105, and a summer 111.
- the filter unit 106 is intended to represent one or more loop filters, such as a deblocking filter, an adaptive loop filter (ALF), and a sample adaptive offset (SAO) filter.
- the filter unit 106 is shown as an in-loop filter in FIG. 2A, in other implementations, the filter unit 106 may be implemented as a post-loop filter.
- the video encoder 100 may further include a video data memory and a segmentation unit (not shown in the figure).
- the video data memory may store video data to be encoded by the components of the video encoder 100.
- the video data stored in the video data storage may be obtained from the video source 120.
- the DPB 107 may be a reference image memory that stores reference video data used by the video encoder 100 to encode video data in an intra-frame or inter-frame decoding mode.
- Video data memory and DPB 107 can be formed by any of a variety of memory devices, such as dynamic random access memory (DRAM), synchronous resistive RAM (MRAM), resistive RAM (RRAM) including synchronous DRAM (SDRAM), Or other types of memory devices.
- Video data storage and DPB 107 can be provided by the same storage device or separate storage devices.
- the video data memory may be on-chip with other components of video encoder 100, or off-chip relative to those components.
- the video encoder 100 receives video data and stores the video data in a video data memory.
- the segmentation unit divides the video data into several image blocks, and these image blocks can be further divided into smaller blocks, such as image block segmentation based on a quad-tree structure or a binary tree structure. This segmentation may also include segmentation into slices, tiles, or other larger units.
- Video encoder 100 typically illustrates components that encode image blocks within a video slice to be encoded. The slice can be divided into multiple image patches (and possibly into a collection of image patches called slices).
- the intra predictor 109 within the prediction processing unit 108 may perform intra predictive encoding of the current image block with respect to one or more neighboring blocks in the same frame or slice as the current block to be encoded to remove spatial redundancy.
- the inter predictor 110 within the prediction processing unit 108 may perform inter predictive encoding of the current image block with respect to one or more prediction blocks in the one or more reference images to remove temporal redundancy.
- the inter predictor 110 may be configured to determine an inter prediction mode for encoding a current image block.
- the inter predictor 110 may use rate-distortion analysis to calculate rate-distortion values for various inter-prediction modes in a set of candidate inter-prediction modes and select an inter-frame having the best rate-distortion characteristics from among them. Forecasting mode.
- Rate distortion analysis generally determines the amount of distortion (or error) between the coded block and the original uncoded block that was coded to produce the coded block, and the bit rate used to generate the coded block (that is, , Number of bits).
- the inter predictor 110 may determine that the inter prediction mode with the lowest code rate distortion cost of encoding the current image block in the candidate inter prediction mode set is the inter prediction mode used for inter prediction of the current image block.
- the inter-predictive encoding process will be described in detail below, especially in the various inter-prediction modes for non-directional or directional sports fields in the embodiments of the present invention, predicting one or more sub-blocks in the current image block (specifically, It is a process of motion information of each sub-block or all sub-blocks).
- the inter predictor 110 is configured to predict motion information (such as a motion vector) of one or more sub-blocks in the current image block based on the determined inter prediction mode, and use the motion information (such as the motion vector) of one or more sub-blocks in the current image block. Motion vector) to obtain or generate a prediction block of the current image block.
- the inter predictor 110 may locate a prediction block pointed to by the motion vector in one of the reference image lists.
- the inter predictor 110 may also generate syntax elements associated with the image blocks and video slices for use by the video decoder 200 when decoding the image blocks of the video slices.
- the inter predictor 110 uses the motion information of each sub-block to perform a motion compensation process to generate a prediction block of each sub-block, thereby obtaining a prediction block of the current image block. It should be understood that the The inter predictor 110 performs motion estimation and motion compensation processes.
- the inter predictor 110 may provide information indicating the selected inter prediction mode of the current image block to the entropy encoder 103 so that the entropy encoder 103 encodes the instruction.
- Information on the selected inter prediction mode may include inter prediction data related to the current image block in the transmitted bit stream.
- the inter prediction data includes, for example, indication information of an inter prediction mode.
- the inter-prediction mode includes at least one of an AMVP mode based on an affine transformation model and a Merge mode based on an affine transformation model.
- the inter prediction data may further include an index value (or an index number) of a candidate motion vector list corresponding to the AMVP mode, and Motion vector difference (MVD) of the control point of the current block; if the inter prediction data includes indication information of a Merge mode based on an affine transformation model, the inter prediction data may further include candidates corresponding to the Merge mode The index value (or index number) of the motion vector list.
- the inter prediction data in the above example may further include indication information of an affine transformation model (the number of model parameters) of the current block.
- the inter predictor 110 may be configured to perform the related steps of the embodiment of FIG. 13 described later to implement the application of the motion vector prediction method described in the present invention at the encoding end.
- the intra predictor 109 may perform intra prediction on the current image block.
- the intra predictor 109 may determine an intra prediction mode used to encode the current block.
- the intra-predictor 109 may use rate-distortion analysis to calculate rate-distortion values for various intra-prediction modes to be tested, and select an intra-prediction with the best rate-distortion characteristics from the test modes. mode.
- the intra predictor 109 may provide information indicating the selected intra prediction mode of the current image block to the entropy encoder 103 so that the entropy encoder 103 encodes the instruction Information on the selected intra prediction mode.
- the video encoder 100 forms a residual image block by subtracting the prediction block from the current image block to be encoded.
- the summer 112 represents one or more components that perform this subtraction operation.
- the residual video data in the residual block may be included in one or more TUs and applied to the transformer 101.
- the transformer 101 transforms the residual video data into a residual transform coefficient using a transform such as a discrete cosine transform (DCT) or a conceptually similar transform.
- the transformer 101 may transform the residual video data from a pixel value domain to a transform domain, such as a frequency domain.
- DCT discrete cosine transform
- the transformer 101 may send the obtained transform coefficients to a quantizer 102.
- a quantizer 102 quantizes the transform coefficients to further reduce the bit rate.
- the quantizer 102 may then perform a scan of a matrix containing the quantized transform coefficients.
- the entropy encoder 103 may perform scanning.
- the entropy encoder 103 After quantization, the entropy encoder 103 entropy encodes the quantized transform coefficients. For example, the entropy encoder 103 can perform context-adaptive variable-length coding (CAVLC), context-adaptive binary arithmetic coding (CABAC), syntax-based context-adaptive binary arithmetic coding (SBAC), and probability interval segmentation entropy (PIPE ) Coding or another entropy coding method or technique.
- CAVLC context-adaptive variable-length coding
- CABAC context-adaptive binary arithmetic coding
- SBAC syntax-based context-adaptive binary arithmetic coding
- PIPE probability interval segmentation entropy Coding or another entropy coding method or technique.
- the encoded bitstream may be transmitted to the video decoder 200, or archived for later transmission or retrieved by the video decoder 200.
- the entropy encoder 103 may also perform entrop
- the inverse quantizer 104 and the inverse changer 105 respectively apply inverse quantization and inverse transform to reconstruct the residual block in the pixel domain, for example, for later use as a reference block of a reference image.
- the summer 111 adds the reconstructed residual block to a prediction block generated by the inter predictor 110 or the intra predictor 109 to generate a reconstructed image block.
- the filter unit 106 may be adapted to reconstructed image blocks to reduce distortion, such as block artifacts. This reconstructed image block is then stored as a reference block in the decoded image buffer 107 and can be used by the inter predictor 110 as a reference block to inter-predict subsequent video frames or blocks in the image.
- the video encoder 100 can directly quantize the residual signal without processing by the transformer 101 and correspondingly without the inverse transformer 105; or, for some image blocks Or image frames, the video encoder 100 does not generate residual data, and accordingly does not need to be processed by the transformer 101, quantizer 102, inverse quantizer 104, and inverse transformer 105; or, the video encoder 100 may convert the reconstructed image
- the blocks are directly stored as reference blocks without being processed by the filter unit 106; alternatively, the quantizer 102 and the inverse quantizer 104 in the video encoder 100 may be merged together.
- the video encoder 100 is configured to implement a motion vector prediction method described in the embodiments described later.
- FIG. 2B is a block diagram of a video decoder 200 according to an example described in the embodiment of the present invention.
- the video decoder 200 includes an entropy decoder 203, a prediction processing unit 208, an inverse quantizer 204, an inverse transformer 205, a summer 211, a filter unit 206, and a decoded image buffer 207.
- the prediction processing unit 208 may include an inter predictor 210 and an intra predictor 209.
- video decoder 200 may perform a decoding process that is substantially reciprocal to the encoding process described with respect to video encoder 100 from FIG. 2A.
- video decoder 200 receives from video encoder 100 an encoded video bitstream representing image blocks of the encoded video slice and associated syntax elements.
- the video decoder 200 may receive video data from the network entity 42, optionally, the video data may also be stored in a video data storage (not shown in the figure).
- the video data memory may store video data, such as an encoded video bitstream, to be decoded by components of the video decoder 200.
- the video data stored in the video data storage can be obtained, for example, from the storage device 40, from a local video source such as a camera, via a wired or wireless network of video data, or by accessing a physical data storage medium.
- the video data memory can be used as a decoded image buffer (CPB) for storing encoded video data from the encoded video bitstream. Therefore, although the video data storage is not shown in FIG. 2B, the video data storage and the DPB 207 may be the same storage, or may be separately provided storages. Video data memory and DPB 207 can be formed by any of a variety of memory devices, such as: dynamic random access memory (DRAM) including synchronous DRAM (SDRAM), magnetoresistive RAM (MRAM), and resistive RAM (RRAM) , Or other types of memory devices. In various examples, the video data memory may be integrated on a chip with other components of the video decoder 200 or provided off-chip relative to those components.
- DRAM dynamic random access memory
- SDRAM synchronous DRAM
- MRAM magnetoresistive RAM
- RRAM resistive RAM
- the video data memory may be integrated on a chip with other components of the video decoder 200 or provided off-chip relative to those components.
- the network entity 42 may be, for example, a server, a MANE, a video editor / splicer, or other such device for implementing one or more of the techniques described above.
- the network entity 42 may or may not include a video encoder, such as video encoder 100.
- the network entity 42 may implement some of the techniques described in the embodiments of the present invention.
- the network entity 42 and the video decoder 200 may be part of separate devices, while in other cases, the functionality described with respect to the network entity 42 may be performed by the same device including the video decoder 200.
- the network entity 42 may be an example of the storage device 40 of FIG. 1.
- the entropy decoder 203 of the video decoder 200 entropy decodes the bit stream to generate quantized coefficients and some syntax elements.
- the entropy decoder 203 forwards the syntax elements to the prediction processing unit 208.
- Video decoder 200 may receive syntax elements at a video slice level and / or an image block level.
- the intra predictor 209 of the prediction processing unit 208 may be based on the signaled intra prediction mode and the previously decoded block from the current frame or image. Data to generate prediction blocks for image blocks of the current video slice.
- the inter predictor 210 of the prediction processing unit 208 may determine, based on the syntax elements received from the entropy decoder 203, the An inter prediction mode in which a current image block of a video slice is decoded, and based on the determined inter prediction mode, the current image block is decoded (for example, inter prediction is performed).
- the inter predictor 210 may determine whether to use the new inter prediction mode to predict the current image block of the current video slice. If the syntax element indicates that the new inter prediction mode is used to predict the current image block, based on A new inter prediction mode (e.g., a new inter prediction mode specified by a syntax element or a default new inter prediction mode) predicts the current image block of the current video slice or a sub-block of the current image block. Motion information, thereby obtaining or generating a predicted block of the current image block or a sub-block of the current image block using the predicted motion information of the current image block or a sub-block of the current image block through a motion compensation process.
- a new inter prediction mode e.g., a new inter prediction mode specified by a syntax element or a default new inter prediction mode
- the motion information here may include reference image information and motion vectors, where the reference image information may include but is not limited to unidirectional / bidirectional prediction information, a reference image list number, and a reference image index corresponding to the reference image list.
- a prediction block may be generated from one of reference pictures within one of the reference picture lists.
- the video decoder 200 may construct a reference picture list, that is, a list 0 and a list 1, based on the reference pictures stored in the DPB 207.
- the reference frame index of the current image may be included in one or more of the reference frame list 0 and list 1.
- the inter predictor 210 here performs a motion compensation process. In the following, the inter prediction process for using the motion information of the reference block to predict the motion information of the current image block or a sub-block of the current image block under various new inter prediction modes will be explained in detail.
- the inter predictor 210 may use the syntax element (S401) decoded from the bitstream to be related to the image block currently to be decoded to predict the image block currently to be decoded, which will be used for the current image block frame
- the syntax element of inter prediction is referred to as inter prediction data for short.
- the inter prediction data includes, for example, indication information of an inter prediction mode.
- the inter prediction mode in the embodiment of the present invention includes an AMVP mode based on an affine transformation model and an affine transformation. At least one of the Merge modes of the model.
- the inter prediction data may further include an index value (or an index number) of a candidate motion vector list corresponding to the AMVP mode, and Motion vector difference (MVD) of the control point of the current block; if the inter prediction data includes indication information of a Merge mode based on an affine transformation model, the inter prediction data may further include candidates corresponding to the Merge mode The index value (or index number) of the motion vector list.
- the inter prediction data in the above example may further include indication information of an affine transformation model (the number of model parameters) of the current block.
- the inter predictor 210 may be configured to execute the related steps of the embodiments in FIG. 9 or FIG. 12 described later, so as to implement the application of the motion vector prediction method described in the present invention at the decoding end.
- the inverse quantizer 204 inverse quantizes, that is, dequantizes, the quantized transform coefficients provided in the bitstream and decoded by the entropy decoder 203.
- the inverse quantization process may include using a quantization parameter calculated by the video encoder 100 for each image block in the video slice to determine the degree of quantization that should be applied and similarly to determine the degree of inverse quantization that should be applied.
- the inverse transformer 205 applies an inverse transform to transform coefficients, such as an inverse DCT, an inverse integer transform, or a conceptually similar inverse transform process in order to generate a residual block in the pixel domain.
- the video decoder 200 works by comparing the residual block from the inverse transformer 205 with the corresponding prediction generated by the inter predictor 210 The blocks are summed to get the reconstructed block, that is, the decoded image block.
- the summer 211 represents a component that performs this summing operation.
- a loop filter in the decoding loop or after the decoding loop
- the filter unit 206 may represent one or more loop filters, such as a deblocking filter, an adaptive loop filter (ALF), and a sample adaptive offset (SAO) filter.
- the filter unit 206 is shown as an in-loop filter in FIG. 2B, in other implementations, the filter unit 206 may be implemented as a post-loop filter.
- the filter unit 206 is adapted to reconstruct a block to reduce block distortion, and the result is output as a decoded video stream.
- a decoded image block in a given frame or image may also be stored in a decoded image buffer 207, and the decoded image buffer 207 stores a reference image for subsequent motion compensation.
- the decoded image buffer 207 may be part of a memory, which may also store the decoded video for later presentation on a display device, such as the display device 220 of FIG. 1, or may be separate from such memory.
- the video decoder 200 may generate an output video stream without being processed by the filter unit 206; or, for certain image blocks or image frames, the entropy decoder 203 of the video decoder 200 does not decode the quantized coefficients, and accordingly It does not need to be processed by the inverse quantizer 204 and the inverse transformer 205.
- the video decoder 200 is configured to implement the motion vector prediction method described in the following embodiments.
- FIG. 3 is a schematic structural diagram of a video decoding device 400 (such as a video encoding device 400 or a video decoding device 400) according to an embodiment of the present invention.
- the video coding device 400 is adapted to implement various embodiments described herein.
- the video coding device 400 may be a video decoder (such as video decoder 200 of FIG. 1) or a video encoder (such as video encoder 100 of FIG. 1).
- the video decoding device 400 may be one or more components in the video decoder 200 of FIG. 1 or the video encoder 100 of FIG. 1 described above.
- the video decoding device 400 includes an entry port 410 and a receiving unit (Rx) 420 for receiving data, a processor, a logic unit or a central processing unit (CPU) 430 for processing data, and a transmitter unit for transmitting data (Tx) 440 and exit port 450, and a memory 460 for storing data.
- the video decoding device 400 may further include a photoelectric conversion component and an electro-optical (EO) component coupled with the entrance port 410, the receiver unit 420, the transmitter unit 440, and the exit port 450, for an exit or entrance of an optical signal or an electric signal.
- EO electro-optical
- the processor 430 is implemented by hardware and software.
- the processor 430 may be implemented as one or more CPU chips, cores (eg, multi-core processors), FPGAs, ASICs, and DSPs.
- the processor 430 is in communication with the ingress port 410, the receiver unit 420, the transmitter unit 440, the egress port 450, and the memory 460.
- the processor 430 includes a decoding module 470 (eg, an encoding module 470 or a decoding module 470).
- the encoding / decoding module 470 implements the embodiments disclosed herein to implement the chroma block prediction method provided by the embodiments of the present invention.
- the encoding / decoding module 470 implements, processes, or provides various encoding operations.
- the function of the video decoding device 400 is substantially improved through the encoding / decoding module 470, and the transition of the video decoding device 400 to different states is affected.
- the encoding / decoding module 470 is implemented with instructions stored in the memory 460 and executed by the processor 430.
- the memory 460 includes one or more magnetic disks, tape drives, and solid-state hard disks, and can be used as an overflow data storage device for storing programs when these programs are selectively executed, and for storing instructions and data read during program execution.
- the memory 460 may be volatile and / or non-volatile, and may be a read-only memory (ROM), a random access memory (RAM), a random content-addressable memory (TCAM), and / or a static state. Random access memory (SRAM).
- the processing result for a certain link may be further processed and output to the next link, for example, in interpolation filtering, motion vector derivation or loop After filtering and other steps, the results of the corresponding steps are further clipped or shifted.
- the motion vector of the control point of the current image block derived from the motion vector of the adjacent affine coding block may be further processed, which is not limited in this application.
- the value range of the motion vector is restricted so that it is within a certain bit width. Assuming that the bit width of the allowed motion vector is bitDepth, the range of the motion vector is -2 ⁇ (bitDepth-1) to 2 ⁇ (bitDepth-1) -1, where the " ⁇ " symbol represents the power. If bitDepth is 16, the value ranges from -32768 to 32767. If bitDepth is 18, the value ranges from -131072 to 131071. Constraints can be implemented in two ways:
- ux (vx + 2 bitDepth )% 2 bitDepth
- the value of vx is -32769, and the value obtained by the above formula is 32767. Because in the computer, the value is stored in two's complement form, and the two's complement of -32769 is 1,0111,1111,1111,1111 (17 bits). The computer treats the overflow as discarding the upper bits, so the value of vx For 0111, 1111, 1111, 1111, it is 32767, which is consistent with the result obtained by formula processing.
- vx Clip3 (-2 bitDepth-1 , 2 bitDepth-1 -1, vx)
- vy Clip3 (-2 bitDepth-1 , 2 bitDepth-1 -1, vy)
- Clip3 is to clamp the value of z to the interval [x, y]:
- FIG. 4 is a schematic block diagram of an implementation manner of an encoding device or a decoding device (referred to as a decoding device 1200) according to an embodiment of the present invention.
- the decoding device 1200 may include a processor 1210, a memory 1230, and a bus system 1250.
- the processor and the memory are connected through a bus system, the memory is used to store instructions, and the processor is used to execute the instructions stored in the memory.
- the memory of the encoding device stores program code, and the processor may call the program code stored in the memory to perform various video encoding or decoding methods described in the embodiments of the present invention, especially video encoding or decoding in various new inter prediction modes. Decoding method, and method for predicting motion information in various new inter prediction modes. To avoid repetition, it will not be described in detail here.
- the processor 1210 may be a Central Processing Unit (“CPU”), and the processor 1210 may also be another general-purpose processor, a digital signal processor (DSP), or a dedicated integration. Circuits (ASICs), off-the-shelf programmable gate arrays (FPGAs) or other programmable logic devices, discrete gate or transistor logic devices, discrete hardware components, etc.
- a general-purpose processor may be a microprocessor or the processor may be any conventional processor or the like.
- the memory 1230 may include a read only memory (ROM) device or a random access memory (RAM) device. Any other suitable type of storage device may also be used as the memory 1230.
- the memory 1230 may include code and data 1231 accessed by the processor 1210 using the bus 1250.
- the memory 1230 may further include an operating system 1233 and an application program 1235.
- the application program 1235 includes at least the processor 1210 to perform at least the video encoding or decoding method described in the embodiment of the present invention (especially the motion vector prediction method described in the embodiment of the present invention).
- the application program 1235 may include applications 1 to N, which further includes a video encoding or decoding application (referred to as a video decoding application) that executes the video encoding or decoding method described in the embodiment of the present invention.
- the bus system 1250 may include a data bus, a power bus, a control bus, and a status signal bus. However, for the sake of clarity, various buses are marked as the bus system 1250 in the figure.
- the decoding device 1200 may further include one or more output devices, such as a display 1270.
- the display 1270 may be a tactile display that incorporates the display with a tactile unit operatively sensing a touch input.
- the display 1270 may be connected to the processor 1210 via a bus 1250.
- inter prediction modes In order to better understand the technical solutions of the embodiments of the present invention, the inter prediction modes, non-translational motion models, inherited control point motion vector prediction methods, and constructed control point motion vector prediction methods according to the embodiments of the present invention are further described below.
- Inter prediction mode In HEVC, two inter prediction modes are used, which are advanced motion vector prediction (AMVP) mode and merge mode.
- AMVP advanced motion vector prediction
- the AMVP mode For the AMVP mode, it first traverses the spatially or temporally adjacent coded blocks of the current block (denoted as neighboring blocks), and builds a candidate motion vector list (also referred to as a motion information candidate list) based on the motion information of each neighboring block. Then, the optimal motion vector is determined from the candidate motion vector list by the rate distortion cost, and the candidate motion information with the lowest rate distortion cost is used as the motion vector predictor (MVP) of the current block. Among them, the positions of the neighboring blocks and their traversal order are all predefined.
- the rate-distortion cost is calculated by formula (1), where J represents the rate-distortion cost RD Cost, and SAD is the sum of the absolute error between the predicted pixel value and the original pixel value obtained after motion estimation using the candidate motion vector prediction value (sum of absolute differences (SAD), where R is the code rate and ⁇ is the Lagrangian multiplier.
- the encoding end passes the index value of the selected motion vector prediction value in the candidate motion vector list and the reference frame index value to the decoding end. Further, a motion search is performed in the neighborhood centered on the MVP to obtain the actual motion vector of the current block, and the encoder transmits the difference between the MVP and the actual motion vector (motion vector difference) to the decoder.
- the motion information of the current block in the spatial or time-domain adjacent coded blocks is used to construct a candidate motion vector list, and then the optimal motion information is determined from the candidate motion vector list as the current block's The motion information, and then pass the index value of the position of the optimal motion information in the candidate motion vector list (referred to as merge index, the same applies hereinafter) to the decoding end.
- merge index the index value of the position of the optimal motion information in the candidate motion vector list
- the spatial and temporal candidate motion information of the current block is shown in Figure 5.
- the spatial motion candidate information comes from the spatially adjacent 5 blocks (A0, A1, B0, B1, and B2).
- the motion information of the neighboring block is not added to the candidate motion vector list.
- the time-domain candidate motion information of the current block is obtained after scaling the MV of the corresponding position block in the reference frame according to the reference frame and the picture order count (POC) of the current frame.
- POC picture order count
- the positions of the neighboring blocks of the Merge mode and their traversal order are also predefined, and the positions of the neighboring blocks and their traversal order may be different in different modes.
- all pixels in the coding block use the same motion information (that is, the motion of all pixels in the coding block is consistent), and then motion compensation is performed according to the motion information to obtain the predicted value of the pixels of the coding block. .
- motion compensation is performed according to the motion information to obtain the predicted value of the pixels of the coding block.
- not all pixels in a coded block have the same motion characteristics. Using the same motion information may cause inaccurate motion compensation predictions, which may increase residual information.
- the existing video coding standards use block-matched motion estimation based on translational motion models.
- non-translational motion objects such as rotating objects. Roller coasters rotating in different directions, fireworks and some special effects in movies, especially moving objects in UGC scenes, if they are coded, if the block motion compensation technology based on translational motion models in the current coding standard is used, The encoding efficiency will be greatly affected. Therefore, non-translational motion models, such as affine transformation models, are generated to further improve the encoding efficiency.
- AMVP modes can be divided into AMVP modes based on translational models and AMVP modes based on non-translational models;
- Merge modes can be divided into Merge modes based on translational models and non-translational movement models.
- Merge mode can be divided into Merge modes based on translational models and non-translational movement models.
- Non-translational motion model prediction refers to the use of the same motion model at the codec side to derive the motion information of each sub-motion compensation unit in the current block, and perform motion compensation based on the motion information of the sub-motion compensation unit to obtain the prediction block, thereby improving prediction effectiveness.
- the sub motion compensation unit involved in the embodiment of the present invention may be a pixel or a pixel block of size N 1 ⁇ N 2 divided according to a specific method, where N 1 and N 2 are both positive integers and N 1 It may be equal to N 2 or not equal to N 2 .
- non-translational motion models are 4-parameter affine transformation models or 6-parameter affine transformation models. In possible application scenarios, there are also 8-parameter bilinear models. Each will be described below.
- the 4-parameter affine transformation model can be represented by the motion vector of two pixels and their coordinates relative to the top left vertex pixel of the current block.
- the pixels used to represent the parameters of the motion model are called control points. If the upper-left vertex (0,0) and upper-right vertex (W, 0) pixels are used as control points, the motion vectors (vx0, vy0) and (vx1, vy1) of the upper-left vertex and upper-right vertex control points of the current block are determined first.
- the motion information of each sub-motion compensation unit in the current block is obtained according to the following formula (3), where (x, y) is the coordinates of the sub-motion compensation unit relative to the top left vertex pixel of the current block, and W is the width of the current block.
- the 6-parameter affine transformation model is shown in the following formula (4):
- the 6-parameter affine transformation model can be represented by the motion vector of three pixels and its coordinates relative to the top left vertex pixel of the current block. If the upper left vertex (0,0), upper right vertex (W, 0), and lower left vertex (0, H) pixels are used as control points, the motion vectors of the upper left vertex, upper right vertex, and lower left vertex control point of the current block are determined respectively.
- the 8-parameter bilinear model is shown in the following formula (6):
- the 8-parameter bilinear model can be represented by the motion vector of four pixels and its coordinates with respect to the top left vertex pixel of the current coding block. If the top left vertex (0,0), top right vertex (W, 0), bottom left vertex (0, H), and bottom right fixed point (W, H) are used as control points, then the top left vertex, top right of the current coding block are determined first.
- the motion vectors (vx0, vy0), (vx1, vy1), (vx2, vy2), and (vx3, vy3) of the control points of the vertices, lower left vertices, and lower right vertices are then derived according to the following formula (7)
- the motion information of each sub motion compensation unit where (x, y) is the coordinates of the top left pixel of the sub motion compensation unit relative to the current coding block, and W and H are the width and height of the current coding block, respectively.
- the coding block predicted by the affine transformation model can also be called an affine coding block.
- the affine transformation model is directly related to the motion information of the control points of the affine coding block.
- the AMVP mode based on the affine transformation model or the Merge mode based on the affine transformation model can be used to obtain the motion information of the control points of the affine coding block.
- the motion information of the control points of the current coding block can be obtained by the inherited control point motion vector prediction method or the constructed control point motion vector prediction method.
- the inherited control point motion vector prediction method refers to using an affine transformation model of an adjacent affine-coded block of the current block to determine a candidate control point motion vector of the current block.
- the number of parameters (such as 4 parameters, 6 parameters, 8 parameters, etc.) of the affine transformation model of the affine coding block is consistent with the number of parameters of the affine transformation model of the current block.
- the adjacent position blocks are not limited to A1, B1, B0, A0, and B2.
- the adjacent position block may be a pixel, or a pixel block of a preset size divided according to a specific method, for example, a 4x4 pixel block, a 4x2 pixel block, or other sizes. Pixel blocks are not limited.
- the affine coding block is a coded block adjacent to the current block (also referred to as an adjacent affine coding block) which is predicted by using an affine transformation model during the encoding stage.
- the affine code block where A1 is located is a 4-parameter affine code block (that is, the affine code block is predicted using a 4-parameter affine transformation model), then the motion vector of the upper left vertex (x4, y4) of the affine code block (vx4, vy4), the motion vector (vx5, vy5) of the upper right vertex (x5, y5).
- the combination of the motion vector (vx0, vy0) of the upper left vertex (x0, y0) of the current block and the motion vector (vx1, vy1) of the upper right vertex (x1, y1) obtained based on the affine coding block where A1 is located as above is the current Candidate control point motion vector for the block.
- the motion vector (vx4) of the upper left vertex (x4, y4) of the affine coding block is obtained.
- vy4 the motion vector (vx5, vy5) of the upper right vertex (x5, y5), and the motion vector (vx6, vy6) of the lower left vertex (x6, y6).
- the combination of the motion vectors (vx2, vy2) of the vertices (x2, y2) is the candidate control point motion vector of the current block.
- the constructed control point motion vector prediction method refers to combining the motion vectors of the neighboring coded blocks around the control points of the current block as the motion vectors of the control points of the current affine coding block, without considering the neighboring neighboring coded Whether the block is an affine-coded block.
- the control point motion vector prediction methods constructed are different, which are described below respectively.
- the motion vector of the block A2, B2, or B3 adjacent to the top left vertex can be used as the top left vertex of the current block.
- the candidate motion vector of the motion vector of; the motion vector of the upper right vertex adjacent to the coded block B1 or B0 block is used as the candidate motion vector of the upper right vertex of the current block.
- the candidate motion vectors of the upper left vertex and the upper right vertex are combined to form a plurality of two-tuples.
- the motion vectors of two coded blocks included in the tuple can be used as candidate control point motion vectors of the current block.
- the two-tuple can be seen in the following (13A):
- v A2 represents the motion vector of A2
- v B1 represents the motion vector of B1
- v B0 represents the motion vector of B0
- v B2 represents the motion vector of B2
- v B3 represents the motion vector of B3.
- the motion vector of the block A2, B2, or B3 adjacent to the top-left vertex can be used as the top-left vertex of the current block.
- candidate motion vector of the motion vector of the motion vector use the motion vector of the top right vertex adjacent coded block B1 or B0 block as the motion vector of the motion vector of the top right vertex of the current block, and use the sitting vertex adjacent coded block A0 or A1
- the motion vector serves as a candidate motion vector for the motion vector of the lower left vertex of the current block.
- the above candidate motion vectors of the upper left vertex, the upper right vertex, and the lower left vertex are combined to form multiple triples.
- the motion vectors of the three coded blocks included in the triple can be used as candidate control point motion vectors for the current block.
- the multiple triples can be seen in the following formulas (13B) and (13C):
- v A2 indicates the motion vector of A2
- v B1 indicates the motion vector of B1
- v B0 indicates the motion vector of B0
- v B2 indicates the motion vector of B2
- v B3 indicates the motion vector of B3
- v A0 indicates the motion vector of A0
- v A1 represents the motion vector of A1.
- FIG. 7 is only used as an example. Other methods of combining control point motion vectors may also be applied to the embodiments of the present invention, and details are not described herein.
- the following describes a method for predicting a control point motion vector based on the construction of a Merge mode based on an affine transformation model in an embodiment of the present invention.
- the motion vectors of the upper left vertex and the upper right vertex of the current block are determined by using the motion information of the coded blocks adjacent to the current coded block. It should be noted that FIG. 8 is only used as an example.
- A0, A1, A2, B0, B1, B2, and B3 are the spatially adjacent positions of the current block and are used to predict CP1, CP2, or CP3;
- T is the temporally adjacent positions of the current block and used to predict CP4.
- the coordinates of CP1, CP2, CP3, and CP4 are (0,0), (W, 0), (H, 0), and (W, H), where W and H are the width and height of the current block. Then for each control point of the current block, its motion information is obtained in the following order:
- the check sequence is B2-> A2-> B3. If B2 is available, the motion information of B2 is used. Otherwise, detect A2, B3. If motion information is not available at all three locations, CP1 motion information cannot be obtained.
- the check sequence is B0-> B1; if B0 is available, CP2 uses the motion information of B0. Otherwise, detect B1. If motion information is not available at both locations, CP2 motion information cannot be obtained.
- the detection sequence is A0-> A1;
- X can be obtained to indicate that the block including the position of X (X is A0, A1, A2, B0, B1, B2, B3, or T) has been encoded and adopts the inter prediction mode; otherwise, the X position is not available. It should be noted that other methods for obtaining motion information of the control points may also be applicable to the embodiments of the present invention, and details are not described herein.
- the motion information of the control points of the current block is combined to obtain the structured control point motion information.
- a 4-parameter affine transformation model is used in the current block, the motion information of the two control points of the current block is combined to form a two-tuple, which is used to construct a 4-parameter affine transformation model.
- the combination of the two control points can be ⁇ CP1, CP4 ⁇ , ⁇ CP2, CP3 ⁇ , ⁇ CP1, CP2 ⁇ , ⁇ CP2, CP4 ⁇ , ⁇ CP1, CP3 ⁇ , ⁇ CP3, CP4 ⁇ .
- Affine CP1, CP2
- the motion information of the three control points of the current block is combined to form a triple, which is used to construct a 6-parameter affine transformation model.
- the combination of the three control points can be ⁇ CP1, CP2, CP4 ⁇ , ⁇ CP1, CP2, CP3 ⁇ , ⁇ CP2, CP3, CP4 ⁇ , ⁇ CP1, CP3, CP4 ⁇ .
- a 6-parameter affine transformation model constructed using a triplet composed of CP1, CP2, and CP3 control points can be described as Affine (CP1, CP2, CP3).
- a quadruple formed by combining the motion information of the four control points of the current block is used to construct an 8-parameter bilinear model.
- An 8-parameter bilinear model constructed using a quaternion of CP1, CP2, CP3, and CP4 control points is denoted as Bilinear (CP1, CP2, CP3, CP4).
- a tuple is a combination of motion information of four control points (or four coded blocks) referred to as a quadruple.
- CurPoc represents the POC number of the current frame
- DesPoc represents the POC number of the reference frame of the current block
- SrcPoc represents the POC number of the reference frame of the control point
- MV s represents the motion vector obtained by scaling
- MV represents the motion vector of the control point.
- control points can also be converted into a control point at the same position.
- the 4-parameter affine transformation model obtained by combining ⁇ CP1, CP4 ⁇ , ⁇ CP2, CP3 ⁇ , ⁇ CP2, CP4 ⁇ , ⁇ CP1, CP3 ⁇ , ⁇ CP3, CP4 ⁇ is converted to ⁇ CP1, CP2 ⁇ or ⁇ CP1, CP2, CP3 ⁇ .
- the conversion method is to substitute the motion vector of the control point and its coordinate information into the above formula (2) to obtain the model parameters, and then substitute the coordinate information of ⁇ CP1, CP2 ⁇ into the above formula (3) to obtain its motion vector.
- the conversion can be performed according to the following formulas (15)-(23), where W represents the width of the current block, H represents the height of the current block, and in formulas (15)-(23), (vx 0 , vy 0) denotes a motion vector CP1, (vx 1, vy 1) CP2 represents a motion vector, (vx 2, vy 2) represents the motion vector of CP3, (vx 3, vy 3) denotes the motion vector of CP4.
- ⁇ CP1, CP3 ⁇ conversion ⁇ CP1, CP2 ⁇ or ⁇ CP1, CP2, CP3 ⁇ can be realized by the following formula (16):
- the conversion from ⁇ CP2, CP4 ⁇ to ⁇ CP1, CP2 ⁇ can be realized by the following formula (20), and the conversion from ⁇ CP2, CP4 ⁇ to ⁇ CP1, CP2, CP3 ⁇ can be realized by the formulas (20) and (21):
- the 6-parameter affine transformation model of ⁇ CP1, CP2, CP4 ⁇ , ⁇ CP2, CP3, CP4 ⁇ , ⁇ CP1, CP3, CP4 ⁇ is converted into a control point ⁇ CP1, CP2, CP3 ⁇ to represent it.
- the conversion method is to substitute the motion vector of the control point and its coordinate information into the above formula (4) to obtain the model parameters, and then substitute the coordinate information of ⁇ CP1, CP2, CP3 ⁇ into the formula (5) above to obtain its motion vector.
- the conversion can be performed according to the following formulas (24)-(26), where W represents the width of the current block, H represents the height of the current block, and in formulas (24)-(26), (vx 0 , vy 0 ) Indicates a motion vector of CP1, (vx 1 , vy 1 ) indicates a motion vector of CP2, (vx 2 , vy 2 ) indicates a motion vector of CP3, and (vx 3 , vy 3 ) indicates a motion vector of CP4.
- the candidate motion vector list is empty at this time, add the candidate motion information of the control point to the candidate motion vector list; otherwise, iterate through the motion information in the candidate motion vector list and check the candidate motion vectors. Whether the same motion information as the candidate motion information of the control point exists in the list. If there is no motion information in the candidate motion vector list that is the same as the candidate motion information of the control point, the candidate motion information of the control point is added to the candidate motion vector list.
- a preset sequence is as follows: Affine (CP1, CP2, CP3) ⁇ Affine (CP1, CP2, CP4) ⁇ Affine (CP1, CP3, CP4) ⁇ Affine (CP2, CP3, CP4) ⁇ Affine (CP2, CP3, CP4) ⁇ Affine (CP1, CP2) ⁇ Affine (CP1, CP3) ⁇ Affine (CP2, CP3) ⁇ Affine (CP1, CP4) ⁇ Affine (CP2, CP4) ⁇ Affine (CP3, CP4), a total of 10 combinations.
- the combination is considered to be unavailable. If a combination is available, determine the reference frame index of the combination (when two control points are selected, the smallest reference frame index is selected as the reference frame index of the combination; when it is greater than two control points, the reference frame index with the most occurrences is selected first. If there are multiple occurrences of multiple reference frame indexes, the smallest reference frame index is selected as the combined reference frame index), and the motion vector of the control point is scaled. If the motion information of all the control points after scaling is consistent, the combination is illegal.
- the embodiment of the present invention may also fill the candidate motion vector list.
- the length of the candidate motion vector list at this time is shorter than the maximum list length (such as MaxAffineNumMrgCand). Fill until the length of the list is equal to the maximum list length.
- It can be filled by a method of supplementing zero motion vectors, or by a method of combining and weighted average of motion information of existing candidates in an existing list. It should be noted that other methods for obtaining candidate motion vector list filling can also be applied to the embodiments of the present invention, and details are not described herein.
- the non-translational motion model used in the same image sequence is fixed, and the number of parameters of the affine transformation model used for different blocks in the image is the same, that is, affine
- the number of parameters of the affine transformation model used by the coding block is consistent with the number of parameters of the affine transformation model used by the current block. Therefore, the number of control points of the affine coding block and the position of the control point in the affine coding block, Consistent with the number of control points in the current block and the position of the control points in the current block.
- the current block also uses a 4-parameter affine transformation model, and the decoder obtains the motion vector of each sub-block in the current block according to the 4-parameter affine transformation model of the current block. Information to achieve reconstruction of each sub-block.
- the current block also uses an 8-parameter bilinear model, and the decoder obtains the motion of each sub-block in the current block according to the 8-parameter bilinear model of the current block.
- Vector information so as to achieve the reconstruction of each sub-block.
- the affine motion of different blocks in the image may be different (that is, the affine motion of the current block may be different from the affine motion of the affine coded block).
- the affine transformation model for parsing the current block (such as building a list of candidate motion vectors) and reconstruction will cause the coding efficiency and accuracy of the prediction of the current block to be not high, and it is still difficult to meet user needs in some scenarios.
- the embodiment of the present invention improves the inherited control point motion vector prediction method described above, including two improvement schemes: the first one Improvement plan and second improvement plan.
- the first improvement scheme may also be referred to as a first motion model prediction method based on a motion model
- the second improvement scheme may also be referred to as a second motion model prediction method based on a motion model. The following are described separately:
- the first motion vector prediction method based on the motion model refers to that different blocks in an image sequence are not limited to the affine transformation model used for different blocks, that is, different blocks can use different affine transformation models.
- the affine transformation model used in the current block can be predefined, or it can be selected from a variety of affine transformation models according to the actual motion or actual needs of the affine transformation model of the current block.
- the neighboring block of the current block also called the affine coded block at the encoding end and the affine decoded block at the decoding end
- uses a 2 by N parameter affine transformation model and the 2 by K used by the current block Parameter affine transformation model, and N ⁇ K.
- the motion vectors (candidate motion vectors) of the K control points of the current block are obtained through interpolation calculation.
- the process of determining the candidate motion vector of the control point of the current block is described below using A1 as an example shown in FIG. 10.
- the determination process is mainly described from the perspective of the decoding end.
- the adjacent block where A1 is located is an affine decoding block.
- the implementation of the encoding end can be deduced by analogy, that is, if the neighboring block of the current block at the encoding end is an affine encoding block, the implementation situation will not be described herein again.
- the motion vector (vx4) of the upper left vertex (x4, y4) of the affine decoding block is obtained.
- vy4 the motion vector (vx5, vy5) of the upper right vertex (x5, y5)
- the 6-parameter affine transformation model consisting of the motion vectors of the above 3 control points of the affine decoding block is calculated by interpolation according to the following 6-parameter affine transformation model formulas (27) and (28), so as to obtain the upper-left vertex of the current block (x0 , y0) motion vector (vx0, vy0), motion vector (vx1, vy1) of the upper right vertex (x1, y1) of the current block:
- the motion vector of the upper-left vertex (x4, y4) of the affine decoding block (x4, y4) is obtained ( vx4, vy4), the motion vector (vx5, vy5) of the upper right vertex (x5, y5).
- the motion vectors of the two control points of the affine decoding block are obtained: the motion vector value (vx4, vy4) of the upper left control point (x4, y4) and the motion vector value (vx5, vy5) of the upper right control point (x5, y5).
- a 4-parameter affine transformation model composed of 2 control points of the affine decoding block is calculated by interpolation according to the following 4-parameter affine transformation model formulas (29), (30), and (31), so as to obtain the upper-left vertex of the current block (x0 , y0) motion vector (vx0, vy0), motion vector (vx1, vy1) of the upper right vertex (x1, y1) of the current block, and motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block:
- the current block may also use the same model parameter number of the neighboring block. number.
- the 4-parameter affine transformation model composed of the motion vectors of the above 2 control points of the affine decoding block is calculated by interpolation according to the following 4-parameter affine transformation model formulas (32) and (33), so as to obtain the upper-left vertex of the current block (x0 , y0) motion vector (vx0, vy0), motion vector (vx1, vy1) of the upper right vertex (x1, y1) of the current block:
- the motion vector of the upper left vertex (x4, y4) of the affine decoding block (x4, y4) is obtained ( vx4, vy4), the motion vector (vx5, vy5) of the upper right vertex (x5, y5), and the motion vector (vx6, vy6) of the lower left vertex (x6, y6).
- a 6-parameter affine transformation model composed of the motion vectors of the above 3 control points of the affine decoding block is calculated by interpolation according to the following 6-parameter affine transformation model formulas (34), (35), and (36) to obtain the current block Motion vector (vx0, vy0) of the upper left vertex (x0, y0), motion vector (vx1, vy1) of the upper right vertex (x1, y1) of the current block, motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block ):
- the first motion vector prediction method based on the motion model of the present invention can implement the affine transformation model of the neighboring block to construct the current block itself during the analysis phase of the current block (such as the stage of constructing the candidate motion vector list).
- Affine transformation model, and the affine transformation model of the two can be different. Since the affine transformation model of the current block is more in line with the actual motion situation / actual requirements of the current block, the implementation of this solution can improve the coding efficiency and accuracy of the prediction of the current block to meet user needs.
- the second motion vector prediction method based on the motion model refers to that different blocks in an image sequence are not limited to the affine transformation model used by different blocks, and different blocks can use the same or different affine transformation models. That is to say, if the neighboring block of the current block (also called the affine coded block at the encoding end and the affine decoded block at the decoding end) uses a 2 by N parameter affine transformation model, and the current block The 2 ⁇ K parametric affine transformation model is adopted. Then, N may be equal to K, and N may not be equal to K.
- the control point motion vector prediction method described in "3)" above, or the first motion model based on "5)” described above may be used.
- Motion vector prediction method to obtain the control points of the current block (such as 2 control points, or 3 control points, or 4 control points, etc.).
- a 6-parameter affine transformation model is uniformly used to obtain the motion vector information of each sub-block in the current block, thereby achieving the reconstruction of each sub-block.
- the following also uses A1 shown in FIG. 6 as an example to describe the process of determining the candidate motion vector of the control point of the current block (described from the perspective of the decoding end), and so on in other cases.
- the current block uses a 4-parameter affine transformation model during the analysis phase
- the neighboring block may use a 4-parameter affine transformation model
- it may also use other parameter affine models.
- two current blocks are obtained.
- the motion vector of the control point for example, the motion vector value (vx4, vy4) of the upper left control point (x4, y4) and the motion vector value (vx5, vy5) of the upper right control point (x5, y5) of the current block.
- a 6-parameter affine transformation model needs to be constructed according to the motion vectors of the 2 control points of the current block.
- the following formula (40) is used to obtain the third Motion vector values of three control points, and the motion vector value of the third control point is, for example, the motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block:
- W represents the width of the current block
- H represents the height of the current block
- the motion vector (vx0, vy0) of the upper left control point (x0, y0) of the current block the motion vector (vx1, vy1) of the upper right control point (x1, y1), and the motion vector of the lower left vertex (x2, y2) ( vx2, vy2) to obtain the 6-parameter affine model of the current block reconstruction phase.
- the formula of the 6-parameter affine model is shown in the following formula (37):
- Implementing the second motion vector prediction method based on the motion model of the present invention can implement a 6-parameter affine transformation model to predict the current block uniformly during the reconstruction stage of the current block. Because the more parameters of the motion model describing the affine motion of the current block, the higher the accuracy, the higher the computational complexity.
- the 6-parameter affine transformation model constructed in the reconstruction phase of this solution can describe the affine transformation of image blocks such as translation, scaling, rotation, etc., and achieves a good balance between model complexity and modeling capabilities. Therefore, the implementation of this solution can improve the coding efficiency and accuracy of prediction of the current block, and meet user needs.
- first improvement scheme and the second improvement scheme may also be implemented together.
- the first motion vector prediction method based on the motion model described in "5)” above can be used.
- the motion vectors of the 2 control points of the current block and then according to the second motion model prediction method based on the motion model described in "6)" above, the motion vectors of the 2 control points are unified to The 6-parameter affine transformation model is used to subsequently reconstruct each sub-block of the current block.
- the first motion vector based on the motion model described in "5)” above can be used to predict the motion vector.
- Method to obtain the motion vectors of the 3 control points of the current block, and then according to the formula (32) in the second motion model prediction method based on the motion model described in "6)" above, according to the 3 The motion vectors of the control points are combined into a 6-parameter affine transformation model, and subsequent reconstruction of each sub-block of the current block is realized.
- the comprehensive implementation scheme may also be other embodiments, which are not described in detail here.
- the AMVP mode (Affine AMVP mode) based on the affine transformation model and the Merge mode (Affine Merge mode) based on the affine transformation model are further described below.
- a first motion vector prediction method based on a motion model and / or a control point motion vector prediction method constructed may be used to construct an AMVP mode based on the AMVP mode.
- Candidate motion vector list (or control point motion vector prediction value candidate list).
- the inherited control point motion vector prediction method and / or the constructed control point motion vector prediction method may be used to construct a candidate motion vector list based on the AMVP mode (or a control point motion vector prediction value candidate list).
- the predicted value of the control point motion vector in the list may include 2 (if the current block is a 4-parameter affine transformation model) candidate control point motion vectors, or 3 (if the current block is a 6-parameter affine transformation model) Case) Candidate control point motion vector, or includes 4 (such as the case where the current block is an 8-parameter bilinear model) candidate control point motion vector.
- the candidate list of control point motion vector prediction values can also be pruned and sorted according to a specific rule, and it can be truncated or filled to a specific number.
- the encoder uses each control point motion vector prediction value in the control point motion vector prediction value candidate list by using the above formula (3) or (5) or (7) Obtain the motion vector of each sub-motion compensation unit in the current coding block, and then obtain the pixel value of the corresponding position in the reference frame pointed by the motion vector of each sub-motion compensation unit, as its predicted value, perform motion compensation using the affine transformation model .
- control point motion vector prediction value is used as the search starting point to perform a motion search within a certain search range to obtain control point motion vectors (CPMV), and calculate the control point motion vector and control point motion vector.
- CPMV control point motion vectors
- the encoder passes the index value indicating the position of the control point motion vector prediction value in the control point motion vector prediction value candidate list and the CPMVD encoded input code stream to the decoding end.
- the decoder (such as the aforementioned video decoder 200) parses and obtains the index value and the control point motion vector difference (CPMVD) in the code stream, and determines the control point motion from the control point motion vector prediction value candidate list according to the index value.
- Vector predictive value control point motion vector predictor, CPMVP
- the inherited control point motion vector prediction method and / or the constructed control point motion vector prediction method may be used to construct a candidate motion vector list (or control point) for the Merge mode.
- Motion vector fusion candidate list may be used to construct a candidate motion vector list for Merge mode (or control point motion vector fusion).
- control point motion vector fusion candidate list can be pruned and sorted according to a specific rule, and it can be truncated or filled to a specific number.
- the encoder uses each control point motion vector in the fusion candidate list to obtain each sub-motion in the current encoding block by formula (3) or (5) or (7)
- the motion vector of the compensation unit pixel point or pixel block of size M ⁇ N divided by a specific method
- the pixel value of the position in the reference frame pointed to by the motion vector of each sub-motion compensation unit is used as its prediction value.
- Affine motion compensation Calculate the average of the difference between the original value and the predicted value of each pixel in the current coding block, and select the control point motion vector corresponding to the smallest average value of the difference as the current coding block's 2 or 3 or 4 control points Motion vector.
- the index value indicating the position of the control point motion vector in the candidate list is encoded into a code stream and sent to the decoding end.
- a decoder (such as the aforementioned video decoder 200) parses an index value and determines a control point motion vector (CPMV) from a control point motion vector fusion candidate list according to the index value.
- CPMV control point motion vector
- At least one means one or more, and “multiple” means two or more.
- “And / or” describes the association relationship of related objects, and indicates that there can be three kinds of relationships, for example, A and / or B can indicate: A exists alone, A and B exist simultaneously, and B alone exists, where A, B can be singular or plural.
- the character “/” generally indicates that the related objects are an "or” relationship.
- “At least one or more of the following" or similar expressions refers to any combination of these items, including any combination of single or plural items. For example, at least one (a), a, b, or c can be expressed as: a, b, c, ab, ac, bc, or abc, where a, b, and c can be single or multiple .
- an embodiment of the present invention provides a motion vector prediction method.
- the method may be executed by a video decoder 200.
- the video decoder 200 may be implemented by a video decoder.
- the inter predictor 210 of 200 is executed.
- the video decoder 200 may perform part or all of the following steps according to a video data stream having multiple video frames to predict the motion information of each sub-block in the current decoded block (referred to as the current block) of the current video frame and perform motion compensation.
- the method includes, but is not limited to, the following steps:
- Step 601 Parse the bitstream to determine the inter prediction mode of the current decoded block.
- the video decoder 200 on the decoding end may parse the syntax elements in the code stream transmitted from the encoding end to obtain instruction information for indicating the inter prediction mode, so as to determine the inter prediction mode of the current block according to the instruction information. .
- steps 602a to 606a are performed subsequently.
- step 602b-step 605b is subsequently performed.
- Step 602a Construct a candidate motion vector list of the AMVP mode of the affine transformation model.
- a first motion vector prediction method based on a motion model may be used to obtain a candidate motion vector of a control point of a current block to be added to a candidate motion vector list corresponding to an AMVP mode.
- the first motion vector prediction method based on the motion model and the control point motion vector prediction method constructed can also be used, and the candidate motion vectors of the control points of the current block are separately added to the AMVP mode correspondingly. List of candidate motion vectors.
- the candidate motion vector list of the AMVP mode may be a two-tuple list, and the two-tuple list includes one or more two-tuples for constructing a 4-parameter affine transformation model.
- the candidate motion vector list of the AMVP mode may be a triple list, and the triple list includes one or more triples for constructing a 6-parameter affine transformation model.
- the candidate motion vector list of the AMVP mode may be a list of quads, and the list of quads includes one or more quads used to construct the 8-parameter bilinear model.
- the candidate motion vector 2-tuple / triple-tuple / quaternion list can be pruned and sorted according to a specific rule, and it can be truncated or filled to a specific number.
- the first motion vector prediction method based on a motion model for example, taking FIG. 10 as an example, it can traverse the adjacent position blocks around the current block in the order of A1 ⁇ B1 ⁇ B0 ⁇ A0 ⁇ B2 in FIG. 10 to find adjacent positions.
- the affine decoding block where the block is located (such as the affine decoding block where A1 is located in FIG. 10), uses the control points of the affine decoding block to construct the affine transformation model of the affine decoding block, and then uses the affine decoding block of the affine decoding block.
- the transformation model derives candidate motion vectors (such as candidate motion vector binary / triad / quad) for the control points of the current block, and adds them to the candidate motion vector list corresponding to the AMVP mode. It should be noted that other search sequences may also be applicable to the embodiments of the present invention, and details are not described herein.
- both the encoding end and the decoding end can first use the and Affine decoded blocks with the same number of parameters in the current block model obtain candidate motion vectors for the control points of the current block and add them to the candidate motion vector list corresponding to the AMVP mode. Then, an affine decoding block with a different number of parameters from the current block model is used to obtain candidate motion vectors for the control points of the current block, and added to the candidate motion vector list corresponding to the AMVP mode.
- the parameter model of the current decoding block is a 4-parameter affine transformation model.
- the affine decoding block where B1 is located uses a 4-parameter affine transformation model.
- the A1 affine decoding block uses a 6-parameter affine transformation model.
- the motion vector of the two control points of the current block can be derived by using the affine decoding block where B1 is located and added to the list, and then the motion vectors of the two control points of the current block can be derived by using the affine decoding block where A1 is located and added. To the list.
- the parameter model of the current decoding block is a 6-parameter affine transformation model. After traversing neighboring blocks around the current block, it is determined that the affine decoding block where A1 is located uses the 6-parameter affine transformation model, and the affine where B1 is located The decoding block uses a 4-parameter affine transformation model. Then, the motion vector of the three control points of the current block can be derived by using the affine decoding block where A1 is located and added to the list, and then the motion vectors of the three control points of the current block can be derived by using the affine decoding block where B1 is located and added. To the list.
- the affine transformation model used in different blocks is not limited, that is, the number of parameters of the affine transformation model used in the current block may be different from the affine decoding block, or may be the same as the affine decoding block.
- the affine transformation model adopted by the current block may be determined by analyzing the code stream, that is, in this case, the code stream includes indication information of the affine transformation model of the current block; in one embodiment, the current The affine transformation model used by the block may be pre-configured; in one embodiment, the affine transformation model used by the current block may be selected from a variety of affine transformation models according to the actual motion situation or actual needs of the current block. from.
- the flag information (flag) of the affine transformation model is stored in advance at the decoding end locally, and the flag is used to indicate the affine transformation model that is actually used when the affine decoding block performs its own sub-block prediction.
- the decoding end when the decoding end recognizes the flag of the affine decoding block, it is determined that the number of model parameters of the affine transformation model actually used by the affine decoding block and the affine transformation model used by the current block are different (or The same), trigger the decoder to use the affine transformation model actually adopted by the affine decoding block to derive the candidate motion vector of the control point of the current block.
- the decoding end recognizes the flag of the affine decoding block, the number of model parameters of the affine transformation model actually used by the affine decoding block and the affine transformation model used by the current block is determined.
- the affine decoding block uses a 6-parameter affine transformation model, then, the decoder obtains the motion vectors of the three control points of the affine decoding block: the motion vector (vx4, vy4) of the upper left vertex (x4, y4) , The motion vector (vx5, vy5) of the upper right vertex (x5, y5), and the motion vector (vx6, vy6) of the lower left vertex (x6, y6).
- the candidate motion vectors of the upper-left vertex and upper-right vertex control points of the current block are derived according to the 6-parameter affine transformation model formulas (27) and (28), respectively.
- the decoder when the 4-block affine transformation model is used in the current block, if the decoder recognizes the flag of the affine decoding block, the model parameters of the affine transformation model actually used by the affine decoding block and the affine transformation model used by the current block are determined.
- the affine decoding block also adopts a 4-parameter affine transformation model, then, the decoder obtains the motion vectors of the two control points of the affine decoding block: the motion vector value of the upper left control point (x4, y4) ( vx4, vy4) and the motion vector value (vx5, vy5) of the upper right control point (x5, y5).
- a 4-parameter affine transformation model consisting of two control points of the affine decoding block is used to derive the candidate motion vectors of the upper-left vertex and upper-right vertex control points of the current block according to the 4-parameter affine transformation model formulas (32) and (33), respectively.
- affine decoding may not be required.
- the flag of the block's affine transformation model may not be required.
- the decoder determines the affine transformation model used by the current block
- the decoder obtains the control of a specific number of affine decoded blocks (the specific number is the same as or different from the number of control points of the current block).
- Point a specific number of control points of the affine decoding block are used to form an affine transformation model, and the affine transformation model is used to derive a candidate motion vector of the control point of the current block.
- the decoder does not need to judge the affine transformation model actually used by the affine decoding block (the affine transformation model actually used by the affine decoding block may be 4 parameters or 6 parameters or 8 parameters Affine transformation model), and directly obtain the motion vector of the two control points of the affine decoding block: the motion vector value (vx4, vy4) of the upper left control point (x4, y4) and the upper right control point (x5, y5) Motion vector value (vx5, vy5).
- the motion vectors of the control points of the upper left vertex and upper right vertex of the current block are derived according to the 4-parameter affine model formulas (32) and (33), respectively.
- Step 603a Determine the optimal motion vector prediction value of the control point according to the index value.
- an index value of the candidate motion vector list is obtained by analyzing the code stream, and an optimal control point motion vector prediction value is determined from the candidate motion vector list constructed in the foregoing step 602a according to the index value.
- the affine motion model used in the current block is a 4-parameter affine motion model
- an index value is obtained by analysis, and an optimal motion vector prediction value of two control points is determined from the candidate motion vector two-tuple list according to the index value.
- the index value is obtained by analysis, and the optimal motion vector prediction value of 3 control points is determined from the candidate motion vector triple list according to the index value.
- the index value is obtained by analysis, and the optimal motion vector prediction value of 4 control points is determined from the candidate motion vector quad list according to the index value.
- Step 604a Determine the actual motion vector of the control point according to the motion vector difference.
- the motion vector difference of the control point is obtained by analyzing the code stream, and then the motion vector of the control point is obtained according to the motion vector difference of the control point and the optimal control point motion vector prediction value determined in the foregoing step 603a.
- the affine motion model used by the current block is a 4-parameter affine motion model.
- the difference between the motion vector of the two control points of the current block is obtained from the code stream.
- the upper left position can be obtained from the code stream by decoding.
- the motion vector difference value and the motion vector prediction value of each control point are respectively added to obtain the actual motion vector value of the control point, that is, the motion vector values of the upper left position control point and the upper right position control point of the current block are obtained.
- the current block affine motion model is a 6-parameter affine motion model.
- the motion vector difference of the three control points of the current block is obtained from the code stream.
- the upper left control point and the upper right are decoded from the code stream.
- the motion vector difference value and the motion vector prediction value of each control point are respectively added to obtain the actual motion vector value of the control point, that is, the motion vector values of the upper left control point, the upper right control point, and the lower left control point of the current block are obtained.
- embodiments of the present invention may also be other affine motion models and other control point positions, and details are not described herein.
- Step 605a Obtain a motion vector value of each sub-block of the current block according to the affine transformation model adopted by the current block.
- Position pixel motion information represents the motion information of all pixels in the motion compensation unit. Assuming that the size of the motion compensation unit is MxN, the preset position pixels can be the center point of the motion compensation unit (M / 2, N / 2), the upper left pixel (0,0), and the upper right pixel (M-1,0 ), Or pixels at other locations.
- the following description uses the center point of the motion compensation unit as an example, and FIG. 11A and FIG. 11B.
- FIG. 11A exemplarily shows a current block and a motion compensation unit of the current block.
- Each small box in the figure represents a motion compensation unit, and each movement compensation unit in the figure has a size of 4x4.
- the gray point in the motion compensation unit indicates the center point of the motion compensation unit.
- V0 represents the motion vector of the upper-left control point of the current block
- V1 represents the motion vector of the upper-right control point of the current block
- V2 represents the motion vector of the lower-left control point of the current block.
- FIG. 11B exemplarily shows another current block and a motion compensation unit of the current block.
- Each small box in the figure represents a motion compensation unit, and the size of each motion compensation unit in the figure is 8x8.
- the gray point in each motion compensation unit represents the center point of the motion compensation unit.
- V0 represents the motion vector of the upper left control point of the current block
- V1 represents the motion vector of the upper right control point of the current block
- V2 represents the motion vector of the lower left control point of the current block.
- the coordinates of the center point of the motion compensation unit relative to the top left pixel of the current block can be calculated using the following formula (38):
- (x (i, j) , y (i, j) ) Represents the coordinates of the center point of the (i, j) th motion compensation unit relative to the upper left control point pixel of the current affine decoding block.
- the affine motion model used in the current affine decoding block is a 6-parameter affine motion model, substituting (x (i, j) , y (i, j) ) into the aforementioned 6-parameter affine motion model formula (37) to obtain
- the motion vector of the center point of each motion compensation unit is used as the motion vector of all the pixels in the motion compensation unit (vx (i, j) , vy (i, j) ):
- the affine motion model used in the current affine decoding block is a 4 affine motion model
- substitute (x (i, j) , y (i, j) ) into the 4-parameter affine motion model formula (39) and obtain each
- the motion vector of the center point of the motion compensation unit is used as the motion vector (vx (i, j) , vy (i, j) ) of all pixels in the motion compensation unit:
- Step 606a Perform motion compensation for each sub-block according to the determined motion vector value of the sub-block to obtain a pixel prediction value of the sub-block.
- Step 602b Construct a candidate motion vector list of the Merge mode of the affine transformation model.
- a first motion vector prediction method based on a motion model may also be used to obtain a candidate motion vector of a control point of a current block to be added to a candidate motion vector list corresponding to a Merge mode.
- the first motion vector prediction method based on the motion model and the control point motion vector prediction method based on the structure can also be used.
- the candidate motion vectors of the control points of the current block are added to the Merge mode respectively. List of candidate motion vectors.
- the candidate motion vector list may be a two-tuple list, and the two-tuple list includes one or more for constructing 4 A two-tuple of parametric affine transformation models.
- the candidate motion vector list may be a triple list, and the triple list includes one or more triples for constructing a 6-parameter affine transformation model.
- the candidate motion vector list may be a quaternion list, and the quaternary list includes one or more quaternions used to construct the 8-parameter bilinear model.
- the candidate motion vector 2-tuple / triple-tuple / quaternion list can be pruned and sorted according to a specific rule, and it can be truncated or filled to a specific number.
- the first motion vector prediction method based on a motion model for example, taking FIG. 10 as an example, it can traverse the adjacent position blocks around the current block in the order of A1 ⁇ B1 ⁇ B0 ⁇ A0 ⁇ B2 in FIG. 10 to find The affine decoding block where the adjacent position block is located, uses the control points of the affine decoding block to construct the affine transformation model of the affine decoding block, and then uses the affine transformation model of the affine decoding block to derive the control point of the current block.
- Candidate motion vectors (such as candidate motion vector tuples / triads / quads) are added to the candidate motion vector list corresponding to the Merge mode. It should be noted that other search sequences may also be applicable to the embodiments of the present invention, and details are not described herein.
- the candidate motion information of the control point is added to the candidate list; otherwise, the motion information in the candidate motion vector list is sequentially traversed in order to check the candidate motion vector list. Whether there is the same motion information as the candidate motion information of the control point. If there is no motion information in the candidate motion vector list that is the same as the candidate motion information of the control point, the candidate motion information of the control point is added to the candidate motion vector list.
- judging whether two candidate motion information are the same requires judging whether their forward and backward reference frames and the horizontal and vertical components of each forward and backward motion vector are the same. Only when all the above elements are different, the two motion information are considered different.
- the candidate list is constructed, otherwise the next neighboring position block is traversed.
- the 6-parameter affine transformation model is used for different blocks in the image.
- the motion vectors of the three control points of the affine decoding block where A1 is located the motion vector value (vx4, vy4) of the upper left control point (x4, y4) and the upper right control point (x5, y5) Motion vector value (vx5, vy5) and motion vector (vx6, vy6) of the lower left vertex (x6, y6).
- Step 603b Determine a motion vector value of the control point according to the index value.
- an index value of the candidate motion vector list is obtained by analyzing the code stream, and an actual motion vector of the control point is determined from the candidate motion vector list constructed in the foregoing step 602b according to the index value.
- the affine motion model used in the current block is a 4-parameter affine motion model
- an index value is obtained by analysis, and the motion vector values of the two control points are determined from the candidate motion vector two-tuple list according to the index values.
- the affine motion model used in the current block is a 6-parameter affine motion model
- an index value is obtained by analysis, and the motion vector values of the three control points are determined from the candidate motion vector triplet list according to the index values.
- the index value is obtained by analysis, and the motion vector values of the four control points are determined from the candidate motion vector quaternion list according to the index value.
- Step 604b Obtain a motion vector value of each sub-block according to the affine transformation model adopted by the current block.
- Step 605a For detailed implementation of this step, reference may be made to the description of step 605a above. For brevity of the description, details are not described herein again.
- Step 605b Each sub-block performs motion compensation according to a corresponding motion vector value to obtain a pixel prediction value of the sub-block.
- the decoder uses the first motion vector prediction method based on the motion model in the prediction process of the current block, which can implement the analysis phase of the current block (such as the construction of the AMVP mode or the Merge mode).
- Stage of the candidate motion vector list using the affine transformation model of the neighboring block to construct the affine transformation model for the current block itself, and the affine transformation model of the two may be different or the same. Since the affine transformation model of the current block is more in line with the actual motion situation / actual requirements of the current block, the implementation of this solution can improve the coding efficiency and accuracy of the prediction of the current block to meet user needs.
- an embodiment of the present invention provides another motion vector prediction method.
- the method may be performed by the video decoder 200. Specifically, the method may be decoded by a video.
- the inter predictor 210 of the decoder 200 is executed.
- the video decoder 200 may perform part or all of the following steps according to a video data stream having multiple video frames to predict the motion information of each sub-block in the current decoded block (referred to as the current block) of the current video frame and perform motion compensation. As shown in FIG. 12, the method includes but is not limited to the following steps:
- Step 701 Parse the bitstream to determine the inter prediction mode of the current decoded block.
- the video decoder 200 on the decoding end may parse the syntax elements in the code stream transmitted from the encoding end to obtain instruction information for indicating the inter prediction mode, so as to determine the inter prediction mode of the current block according to the instruction information. .
- steps 702a to 706a are performed subsequently.
- step 702b-step 705b is subsequently performed.
- Step 702a Construct a candidate motion vector list of the AMVP mode of the affine transformation model.
- the affine transformation model used for different blocks of an image in an image sequence is not limited, that is, different blocks may use the same or different affine transformation models.
- the inherited control point motion vector prediction method can be used to obtain the candidate motion vectors of the control points of the current block to be added to the candidate motion vector list corresponding to the AMVP mode.
- the first motion model-based motion vector prediction method may be used to obtain a candidate motion vector of a control point of a current block to be added to a candidate motion vector list corresponding to an AMVP mode.
- a control point motion vector prediction method is constructed to obtain a candidate motion vector of a control point of a current block and add it to a candidate motion vector list corresponding to an AMVP mode.
- any two of the inherited control point motion vector prediction method, the second motion model-based motion vector prediction method, or the constructed control point motion vector prediction method may also be used to obtain the current block.
- the candidate motion vectors of the control points are added to the candidate motion vector list corresponding to the AMVP mode.
- the inherited control point motion vector prediction method, the second motion model-based motion vector prediction method, and the constructed control point motion vector prediction method may also be used to obtain control point candidates for the current block.
- the motion vectors are added to the candidate motion vector list corresponding to the AMVP mode.
- the candidate motion vector list of the AMVP mode may be a list of two-tuples, and the list of two-tuples includes one or more Two-tuple.
- the candidate motion vector list of the AMVP mode may be a triple list, and the triple list includes one or more triples for constructing a 6-parameter affine transformation model.
- the candidate motion vector list of the AMVP mode may be a list of quads, and the list of quads includes one or more quads used to construct the 8-parameter bilinear model.
- the candidate motion vector 2-tuple / triple-tuple / quaternion list can also be pruned and sorted according to a specific rule, and it can be truncated or filled to a specific number.
- Step 703a Determine the optimal motion vector prediction value of the control point according to the index value. For specific content, reference may be made to the related description in step 603a of the foregoing FIG. 9 embodiment, and details are not described herein again.
- Step 704a Determine the motion vector values of the three control points of the current block according to the motion vector difference.
- the motion vector difference of the control point is obtained by analyzing the code stream, and then the motion vector of the control point is obtained according to the motion vector difference of the control point and the optimal control point motion vector prediction value determined in the foregoing step 703a. Then, based on the obtained motion vectors of the control points, the motion vector values of the three control points of the current block are determined.
- the candidate motion vector list constructed by the decoder in step 702a is a two-tuple list.
- the index value is parsed, and two control points (i.e., the two-tuple) are determined from the candidate motion vector list according to the index value.
- Motion vector prediction (MVP) Motion vector prediction
- step 704a the motion vector difference (MVD) of the two control points of the current block is decoded from the code stream, and the motion vector values (MV) of the two control points are obtained according to the MVP and MVD of the two control points, respectively.
- the motion vector values of the two control points are, for example, the motion vector values (vx0, vy0) of the upper left control point (x0, y0) of the current block, and the motion vector values (vx1) of the upper right control point (x1, y1) of the current block. , vy1). Then, according to the motion vector values of the two control points of the current block, a 4-parameter affine transformation model is formed, and the 4-parameter affine transformation model formula (40) is used to obtain the motion vector value of the third control point.
- the motion vector value of the control points is, for example, the motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block. In this way, the motion vector values of the top left vertex, top right vertex, and bottom left vertex of the current block are determined.
- the candidate motion vector list constructed by the decoder in step 702a is a triple list.
- the index value is parsed, and three control points (i.e., ternary) are determined from the candidate motion vector list according to the index value. Group) of motion vector predictions (MVP).
- MVP motion vector predictions
- the motion vector difference (MVD) of the three control points of the current block is decoded from the code stream, and the motion vector values (MV) of the three control points are obtained according to the MVP and MVD of the three control points, respectively.
- the motion vector values of the three control points are, for example, the motion vector values (vx0, vy0) of the upper left control point (x0, y0) of the current block, and the motion vector values of the upper right control point (x1, y1) of the current block (vx1, vy1 ), And the motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block.
- the motion vector values of the top left vertex, top right vertex, and bottom left vertex of the current block are determined.
- the candidate motion vector list constructed by the decoder in step 702a is a quadruple list.
- the index value is parsed, and four control points (that is, quaternary) are determined from the candidate motion vector list according to the index value. Group) of motion vector predictions (MVP).
- MVP motion vector predictions
- step 704a the motion vector difference (MVD) of the four control points of the current block is obtained by decoding from the code stream, and the motion vector values (MV) of the four control points are obtained according to the MVP and MVD of the four control points, respectively.
- the motion vector values of the four control points are, for example: the motion vector value (vx0, vy0) of the upper left control point (x0, y0) of the current block, and the motion vector value (vx1, vy1) of the upper right control point (x1, y1) of the current block ), The motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block, and the motion vector (vx3, vy3) of the lower right vertex (x3, vy3) of the current block. Then, the decoding end may only use the motion vector values of the three control points: the upper left vertex, the upper right vertex, and the lower left vertex of the current block.
- Step 705a According to the three control points of the current block, a 6-parameter affine transformation model is used to obtain the motion vector value of each sub-block.
- a 6-parameter affine transformation model can be formed based on the motion vector values of the 3 control points of the current block.
- the projective transformation model obtains the motion vector value of each sub-block.
- the motion vector values of the three control points are, for example, the motion vector value (vx0, y0) of the upper left control point (x0, y0) of the current block, and the motion vector value of the upper right control point (x1, y1) of the current block. Value (vx1, vy1), and the motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block.
- the coordinates of the preset position pixels of each sub-block (or each motion compensation unit) in the current block with respect to the upper-left vertex (or other reference point) of the current block (x (i, j) , y (i, j ) ) Substituting into the above formula (37), the motion vector value of each sub-block can be obtained.
- the preset position pixel point may be the center point of each sub-block (or each motion compensation unit), and the center point of each sub-block (or each motion compensation unit) relative to the coordinates of the upper-left vertex pixel of the current block (x (i, j) , y (i, j) ) can be calculated using formula (38).
- formula (38) For specific content, reference may also be made to the related descriptions of the embodiment in FIG. 11A and the embodiment in FIG. 11B, and details are not described herein again.
- Step 706a Each sub-block performs motion compensation according to a corresponding motion vector value to obtain a pixel prediction value of the sub-block.
- Step 702b Construct a candidate motion vector list of the affine-transformed Merge mode.
- the affine transformation model used for different blocks of an image in an image sequence is not limited, that is, different blocks may use the same or different affine transformation models.
- the inherited control point motion vector prediction method can be used to obtain the candidate motion vectors of the control points of the current block to be added to the candidate motion vector list corresponding to the Merge mode.
- a first motion model-based motion vector prediction method may be used to obtain a candidate motion vector of a control point of a current block to be added to a candidate motion vector list corresponding to a Merge mode.
- a control point motion vector prediction method is constructed to obtain a candidate motion vector of a control point of a current block and add it to a candidate motion vector list corresponding to a Merge mode.
- any two of the inherited control point motion vector prediction method, the second motion model-based motion vector prediction method, or the constructed control point motion vector prediction method may also be used to obtain the current block.
- the candidate motion vectors of the control points are added to the candidate motion vector list corresponding to the Merge mode, respectively.
- the inherited control point motion vector prediction method, the second motion model-based motion vector prediction method, and the constructed control point motion vector prediction method may also be used to obtain control point candidates for the current block.
- the motion vectors are added to the candidate motion vector list corresponding to the Merge mode, respectively.
- the candidate motion vector list established by the decoding end may be a candidate motion vector two-tuple / three-tuple / quaternion list.
- the candidate motion vector 2-tuple / triple-tuple / quaternion list can be pruned and sorted according to a specific rule, and it can be truncated or filled to a specific number.
- Step 703b Obtain a motion vector value of the control point according to the index value.
- the index value of the candidate motion vector list is obtained by analyzing the code stream, and the actual motion vector of the control point is determined from the candidate motion vector list constructed in the foregoing step 702b according to the index value.
- this step reference may also be made to the related description of step 603b in the embodiment of FIG. 9, and details are not described herein again.
- Step 704b Determine the motion vector values of the three control points of the current block according to the obtained motion vectors of the control points.
- the decoder obtains the motion vector values of two control points (ie, a tuple) in step 703b.
- the motion vector values of the two control points are, for example, the motion of the upper left control point (x0, y0) of the current block.
- a 4-parameter affine transformation model is formed, and the 4-parameter affine transformation model formula (31) is used to obtain the motion vector value of the third control point.
- the motion vector value of the control points is, for example, the motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block. In this way, the motion vector values of the top left vertex, top right vertex, and bottom left vertex of the current block are determined.
- the decoder obtains the motion vector values of 3 control points (ie, triples) in step 703b.
- the motion vector values of the 3 control points are, for example, the upper left control point (x0, y0) of the current block.
- the motion vector values of the top left vertex, top right vertex, and bottom left vertex of the current block are determined.
- the decoder obtains the motion vector values of the four control points (that is, the quads) in step 703b.
- the motion vector values of the four control points are, for example, the upper left control point (x0, y0) of the current block.
- Motion vector value (vx0, vy0) motion vector value (vx1, vy1) of the upper right control point (x1, y1) of the current block, motion vector (vx2, vy2) of the lower left vertex (x2, y2) of the current block, and the current block
- the decoding end may only use the motion vector values of the three control points: the upper left vertex, the upper right vertex, and the lower left vertex of the current block.
- Step 705b According to the three control points of the current block, a 6-parameter affine transformation model is used to obtain the motion vector value of each sub-block.
- a 6-parameter affine transformation model is used to obtain the motion vector value of each sub-block.
- Step 706b Each sub-block performs motion compensation according to a corresponding motion vector value to obtain a pixel prediction value of the sub-block.
- the decoder uses a second motion vector prediction method based on the motion model in the prediction process of the current block, which can implement the parameters of the affine transformation model used by the current block during the analysis phase.
- the number can be different or the same as that of the neighboring blocks.
- a 6-parameter affine transformation model is used to predict the current block.
- the 6-parameter affine transformation model constructed in the reconstruction phase of this solution can describe the affine transformation of the image block such as translation, scaling, rotation, etc., and achieves a good balance between model complexity and modeling capabilities. Therefore, the implementation of this solution can improve the coding efficiency and accuracy of prediction of the current block, and meet user needs.
- FIG. 13 shows a flowchart of another motion vector prediction method according to an embodiment of the present invention.
- the method may be performed by the video encoder 100.
- the method may be performed by the inter predictor 110 of the video encoder 100.
- the video encoder 100 may perform part or all of the following steps according to a video data stream having multiple video frames to encode a current encoding block (referred to as a current block) of a current video frame.
- the method includes, but is not limited to, the following steps:
- multiple inter prediction modes may also be preset.
- the multiple intra prediction modes include, for example, the AMVP mode based on the affine motion model described above and Based on the merge mode of the affine motion model, the encoder traverses the multiple inter prediction modes to determine the inter prediction mode that is optimal for the current block prediction.
- only one inter prediction mode may be preset, that is, in this case, the encoding end directly determines that the default inter prediction mode is currently used.
- the default The inter-prediction mode is AMVP mode based on affine motion model or merge mode based on affine motion model.
- steps 802a to 804a are performed subsequently.
- steps 802b to 804b are performed subsequently.
- the coding end adopts a design solution of the first motion vector prediction method based on a motion model. Then, for specific implementation of this step, reference may be made to the description of step 602a in the foregoing embodiment of FIG.
- the coding end adopts a design scheme of a second motion vector prediction method based on a motion model. Then, for specific implementation of this step, reference may be made to the description of step 702a in the foregoing embodiment of FIG. 12, and details are not described herein again.
- the encoding end may use the control point motion vector prediction value in the candidate motion vector list (such as the candidate motion vector binary / triple / quad) by using formula (3) or (5) or ( 7) Obtain the motion vector of each sub motion compensation unit in the current block, and then obtain the pixel value of the corresponding position in the reference frame pointed by the motion vector of each sub motion compensation unit, as its predicted value, perform the motion using the affine motion model make up. Calculate the average of the difference between the original value and the predicted value of each pixel in the current coding block, select the control point motion vector prediction value corresponding to the smallest average value as the optimal control point motion vector prediction value, and use it as the current block Motion vector predictions for 2 or 3 or 4 control points.
- the candidate motion vector list such as the candidate motion vector binary / triple / quad
- the encoder can use the optimal control point motion vector prediction value as the search starting point to perform a motion search within a certain search range to obtain control point motion vectors (CPMV) and calculate the control point motion vector. And the control point motion vector prediction (CPMVD). Then, the encoding end encodes the index value indicating the position of the control point motion vector prediction in the candidate motion vector list and the CPMVD code into the code. In addition, the indication information of the inter prediction mode can also be coded into a code stream for subsequent transmission to the decoding end.
- CPMV control point motion vectors
- the encoding end encodes the index value indicating the position of the control point motion vector prediction in the candidate motion vector list and the CPMVD code into the code.
- the indication information of the inter prediction mode can also be coded into a code stream for subsequent transmission to the decoding end.
- the encoding end may encode the instruction information indicating the affine transformation model (number of parameters) used by the current block into a code stream, and then pass it to the decoding end, so that the decoding end determines the current block according to the instruction information.
- the encoding end adopts a design solution of the first motion vector prediction method based on a motion model. Then, for specific implementation of this step, reference may be made to the description of step 602b in the foregoing embodiment of FIG. 9, and details are not described herein again.
- the coding end adopts a design scheme of a second motion vector prediction method based on a motion model. Then, for specific implementation of this step, reference may be made to the description of step 702b in the foregoing embodiment of FIG. 12, and details are not described herein again.
- the encoding end may use the control point motion vector (such as the candidate motion vector binary / triad / quad) in the candidate motion vector list by formula (3) or (5) or (7)
- the motion vector of each sub motion compensation unit in the current coding block is obtained, and then the pixel value of the position in the reference frame pointed to by the motion vector of each sub motion compensation unit is used as its prediction value to perform affine motion compensation.
- the optimal control The point motion vector is the motion vector of the 2 or 3 or 4 control points of the current coding block.
- the encoding end may encode an index value indicating the position of the control point motion vector in the candidate list into a code stream, and the indication information of the inter prediction mode is encoded into the code stream for subsequent transmission to the decoding end.
- the encoding end may encode the instruction information indicating the affine transformation model (number of parameters) used by the current block into a code stream, and then pass it to the decoding end, so that the decoding end determines the current block according to the instruction information.
- the above embodiment only describes the process of encoding and code stream sending by the encoding end. According to the foregoing description, those skilled in the art understand that the encoding end can also implement other methods described in the embodiments of the present invention in other links.
- the specific implementation of the reconstruction process of the current block can refer to the related method described above at the decoding end (as shown in the embodiment of FIG. 9 or FIG. 12), which will not be described again here.
- the encoding end implements the design scheme of the first motion vector prediction method based on the motion model during the encoding process of the current block, which can be implemented in the analysis phase of the current block (for example, in the stage of constructing the candidate motion vector list of the AMVP mode or the Merge mode), the affine transformation model of the neighboring block is used to build the affine transformation model for the current block itself, and the affine transformation models of the two can be different or different. the same. Since the affine transformation model of the current block is more in line with the actual motion / actual requirements of the current block, implementing this solution can improve the coding efficiency and accuracy of encoding the current block, and meet user needs.
- the encoder refers to the design scheme of the second motion vector prediction method based on the motion model for implementation, which is beneficial to the decoder in the image block.
- the 6-parameter affine transformation model is used to predict the image blocks. Therefore, the implementation of this solution can improve the coding efficiency and accuracy of prediction of the current block, and meet user needs.
- Computer-readable media may include computer-readable storage media, which corresponds to tangible media, such as data storage media, or communication media including any medium that facilitates transfer of a computer program from one place to another (e.g., according to a communication protocol) .
- computer-readable media may generally correspond to (1) tangible computer-readable storage media that is non-transitory, or (2) a communication medium such as a signal or carrier wave.
- a data storage medium may be any available medium that can be accessed by one or more computers or one or more processors to retrieve instructions, codes, and / or data structures used to implement the techniques described in embodiments of the present invention.
- the computer program product may include a computer-readable medium.
- such computer-readable storage media may include RAM, ROM, EEPROM, CD-ROM or other optical disk storage devices, magnetic disk storage devices or other magnetic storage devices, flash memory, or may be used to store instructions or data structures Any other medium in the form of the required program code and accessible by a computer. Also, any connection is properly termed a computer-readable medium. For example, if coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave are used to transmit instructions from a website, server, or other remote source, then coaxial cable Wire, fiber optic cable, twisted pair, DSL or wireless technologies such as infrared, radio and microwave are included in the definition of media.
- DSL digital subscriber line
- the computer-readable storage media and data storage media do not include connections, carrier waves, signals, or other temporary media, but are instead directed to non-transitory tangible storage media.
- magnetic and optical discs include compact discs (CDs), laser discs, optical discs, digital versatile discs (DVDs), and Blu-ray discs, where magnetic discs typically reproduce data magnetically, and optical discs use lasers to reproduce optical data. Combinations of the above should also be included within the scope of computer-readable media.
- DSPs digital signal processors
- ASICs application specific integrated circuits
- FPGAs field programmable logic arrays
- processor may refer to any of the aforementioned structures or any other structure suitable for implementing the techniques described herein.
- functions described by the various illustrative logical blocks, modules, and steps described herein may be provided within dedicated hardware and / or software modules configured for encoding and decoding, or Into the combined codec.
- the techniques can be fully implemented in one or more circuits or logic elements.
- embodiments of the present invention may be implemented in a variety of devices or devices, including a wireless handset, an integrated circuit (IC), or a group of ICs (eg, a chipset).
- IC integrated circuit
- Various components, modules, or units are described in the embodiments of the present invention to emphasize the functional aspects of the apparatus for performing the disclosed technology, but they do not necessarily need to be implemented by different hardware units.
- the various units may be combined in a codec hardware unit in combination with suitable software and / or firmware, or through interoperable hardware units (including one or more processors as described above) provide.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Description
Claims (16)
- 一种运动矢量预测方法,其特征在于,所述方法包括:解析码流获得候选运动矢量列表的索引值;构造所述候选运动矢量列表;其中,所述候选运动矢量列表包括当前块的K个控制点的候选运动矢量;所述K个控制点的候选运动矢量是根据所述当前块的相邻块采用的2乘N个参数的仿射变换模型而得到的,所述2乘N个参数的仿射变换模型基于所述相邻块的N个控制点的运动矢量而得到,其中,N为大于等于2且小于等于4的整数,K为大于等于2且小于等于4的整数,并且,N不等于K;所述相邻块为与所述当前块空间邻近的已解码图像块,所述当前块包括多个子块;根据所述索引值,从所述候选运动矢量列表中确定所述K个控制点的目标候选运动矢量;根据所述K个控制点的目标候选运动矢量,得到所述当前块中各个子块的预测运动矢量。
- 根据权利要求1所述的方法,其特征在于,N等于2且K等于3,相应的,所述当前块的3个控制点的候选运动矢量是根据所述当前块的相邻块采用的4参数的仿射变换模型而得到的。
- 根据权利要求2所述的方法,其特征在于,所述当前块的3个控制点的候选运动矢量包括所述当前块内左上角像素点位置的运动矢量、所述当前块内右上角像素点位置的运动矢量和所述当前块内左下角像素点位置的运动矢量;所述当前块的3个控制点的候选运动矢量是根据所述当前块的相邻块采用的4参数的仿射变换模型而得到,包括根据如下公式计算出所述当前块的3个控制点的候选运动矢量:其中,vx 0为所述当前块内左上角像素点位置对应的运动矢量的水平分量,vy 0为所述当前块内左上角像素点位置对应的运动矢量的竖直分量;vx 1为所述当前块内右上角像素点位置对应的运动矢量的水平分量,vy 1为所述当前块内右上角像素点位置对应的运动矢量的竖直分量;vx 2为所述当前块内右上角像素点位置对应的运动矢量的水平分量,vy 2为所述当前块内右上角像素点位置对应的运动矢量的竖直分量;vx 4为所述相邻块内左上角像素点位置对应的运动矢量的水平分量,vy 4为所述相邻块内左上角像素点位置对应的运动矢量 的竖直分量;vx 5为所述相邻块内右上角像素点位置对应的运动矢量的水平分量,vy 5为所述相邻块内右上角像素点位置对应的运动矢量的竖直分量;x 0为所述当前块内左上角像素点位置横坐标,y 0为所述当前块内左上角像素点位置纵坐标;x 1为所述当前块内右上角像素点位置横坐标,y 1为所述当前块内右上角像素点位置纵坐标;x 2为所述当前块内左下角像素点位置横坐标,y 2为所述当前块内左下角像素点位置纵坐标;x 4为所述相邻块内左上角像素点位置横坐标,y 4为所述当前块内左上角像素点位置纵坐标;x 5为所述相邻块内右上角像素点位置横坐标。
- 根据权利要求1所述的方法,其特征在于,N等于3且K等于2,相应的,所述当前块的2个控制点的候选运动矢量是根据所述当前块的相邻块采用的6参数的仿射变换模型而得到的。
- 根据权利要求4所述的方法,其特征在于,所述当前块的2个控制点的候选运动矢量包括所述当前块内左上角像素点位置的运动矢量和所述当前块内右上角像素点位置的运动矢量;所述当前块的2个控制点的候选运动矢量是根据所述当前块的相邻块采用的6参数的仿射变换模型而得到,包括根据如下公式计算出所述当前块的2个控制点的候选运动矢量:其中,vx 0为所述当前块内左上角像素点位置对应的运动矢量的水平分量,vy 0为所述当前块内左上角像素点位置对应的运动矢量的竖直分量;vx 1为所述当前块内右上角像素点位置对应的运动矢量的水平分量,vy 1为所述当前块内右上角像素点位置对应的运动矢量的竖直分量;vx 4为所述相邻块内左上角像素点位置对应的运动矢量的水平分量,vy 4为所述相邻块内左上角像素点位置对应的运动矢量的竖直分量;vx 5为所述相邻块内右上角像素点位置对应的运动矢量的水平分量,vy 5为所述相邻块内右上角像素点位置对应的运动矢量的竖直分量;vx 6为所述相邻块内左下角像素点位置对应的运动矢量的水平分量,vy 6为所述相邻块内左下角像素点位置对应的运动矢量的竖直分量;x 0为所述当前块内左上角像素点位置横坐标,y 0为所述当前块内左上角像素点位置纵坐标;x 1为所述当前块内右上角像素点位置横坐标,y 1为所述当前块内右上角像素点位置纵坐标;x 4为所述相邻块内左上角像素点位置横坐标,y 4为所述当前块内左上角像素点位置纵坐标;x 5为所述相邻块内右上角像素点位置横坐标,y 6为所述相邻块内左下角像素点位置纵坐标。
- 根据权利要求1-5任一项所述的方法,其特征在于,所述根据所述K个控制点的目标候选运动矢量,得到所述当前块中各个子块的预测运动矢量,包括:根据所述K个控制点的目标候选运动矢量,得到所述当前块的2乘K个参数的仿射变换模型;根据所述2乘K个参数的仿射变换模型,得到所述当前块中各个子块的预测运动矢量。
- 根据权利要求6所述的方法,其特征在于,所述根据所述K个控制点的目标候选运动矢量,得到所述2乘K个参数的仿射变换模型,包括:根据所述K个控制点的目标候选运动矢量,以及所述K个控制点的运动矢量差值,得到所述K个控制点的运动矢量;其中,所述K个控制点的运动矢量差值是通过解析所述码流得到的;根据所述K个控制点的运动矢量,获得所述当前块的2乘K个参数的仿射变换模型。
- 根据权利要求1-5任一项所述的方法,其特征在于,所述根据所述索引值,从所述候选运动矢量列表中确定所述当前块的K个控制点的目标候选运动矢量之后,所述方法还包括:根据所述当前块的K个控制点的目标候选运动矢量,获得所述当前块的6参数的仿射变换模型;相应的,所述根据所述K个控制点的目标候选运动矢量,得到所述当前块中各个子块的预测运动矢量,包括:根据所述当前块的6参数的仿射变换模型,得到所述当前块中各个子块的预测运动矢量。
- 一种解码设备,其特征在于,所述设备包括:存储单元,用于存储码流形式的视频数据;熵解码单元,用于解析所述码流获得候选运动矢量列表的索引值;预测处理单元,用于构造所述候选运动矢量列表;其中,所述候选运动矢量列表包括当前块的K个控制点的候选运动矢量;所述当前块的K个控制点的候选运动矢量是根据所述当前块的相邻块采用的2乘N个参数的仿射变换模型而得到的,所述2乘N个参数的仿射变换模型基于所述相邻块的N个控制点的运动矢量而得到,其中,N为大于等于2且小于等于4的整数,K为大于等于2且小于等于4的整数,并且,N不等于K;所述相邻块为与所述当前块空间邻近的已解码图像块,所述当前块包括多个子块;根据所述索引值,从所述候选运动矢量列表中确定所述当前块的K个控制点的目标候选运动矢量;根据所述当前块的K个控制点的目标候选运动矢量,得到所述当前块中各个子块的预测运动矢量。
- 根据权利要求9所述的设备,其特征在于,N等于2且K等于3,相应的,所述当前块的3个控制点的候选运动矢量是根据所述当前块的相邻块采用的4参数的仿射变换模型而得到的。
- 根据权利要求10所述的设备,其特征在于,所述当前块的3个控制点的候选运动矢量包括所述当前块内左上角像素点位置的运动矢量、所述当前块内右上角像素点位置的 运动矢量和所述当前块内左下角像素点位置的运动矢量;所述预测处理单元用于根据如下公式计算出所述当前块的3个控制点的候选运动矢量:其中,vx 0为所述当前块内左上角像素点位置对应的运动矢量的水平分量,vy 0为所述当前块内左上角像素点位置对应的运动矢量的竖直分量;vx 1为所述当前块内右上角像素点位置对应的运动矢量的水平分量,vy 1为所述当前块内右上角像素点位置对应的运动矢量的竖直分量;vx 2为所述当前块内右上角像素点位置对应的运动矢量的水平分量,vy 2为所述当前块内右上角像素点位置对应的运动矢量的竖直分量;vx 4为所述相邻块内左上角像素点位置对应的运动矢量的水平分量,vy 4为所述相邻块内左上角像素点位置对应的运动矢量的竖直分量;vx 5为所述相邻块内右上角像素点位置对应的运动矢量的水平分量,vy 5为所述相邻块内右上角像素点位置对应的运动矢量的竖直分量;x 0为所述当前块内左上角像素点位置横坐标,y 0为所述当前块内左上角像素点位置纵坐标;x 1为所述当前块内右上角像素点位置横坐标,y 1为所述当前块内右上角像素点位置纵坐标;x 2为所述当前块内左下角像素点位置横坐标,y 2为所述当前块内左下角像素点位置纵坐标;x 4为所述相邻块内左上角像素点位置横坐标,y 4为所述当前块内左上角像素点位置纵坐标;x 5为所述相邻块内右上角像素点位置横坐标。
- 根据权利要求9所述的设备,其特征在于,N等于3且K等于2,相应的,所述当前块的2个控制点的候选运动矢量是根据所述当前块的相邻块采用的6参数的仿射变换模型而得到的。
- 根据权利要求12所述的设备,其特征在于,所述当前块的2个控制点的候选运动矢量包括所述当前块内左上角像素点位置的运动矢量和所述当前块内右上角像素点位置的运动矢量;所述预测处理单元用于根据如下公式计算出所述当前块的2个控制点的候选运动矢量:其中,vx 0为所述当前块内左上角像素点位置对应的运动矢量的水平分量,vy 0为所述当前块内左上角像素点位置对应的运动矢量的竖直分量;vx 1为所述当前块内右上角像素点位置对应的运动矢量的水平分量,vy 1为所述当前块内右上角像素点位置对应的运动矢量的竖直分量;vx 4为所述相邻块内左上角像素点位置对应的运动矢量的水平分量,vy 4为所述相邻块内左上角像素点位置对应的运动矢量的竖直分量;vx 5为所述相邻块内右上角像素点位置对应的运动矢量的水平分量,vy 5为所述相邻块内右上角像素点位置对应的运动矢量的竖直分量;vx 6为所述相邻块内左下角像素点位置对应的运动矢量的水平分量,vy 6为所述相邻块内左下角像素点位置对应的运动矢量的竖直分量;x 0为所述当前块内左上角像素点位置横坐标,y 0为所述当前块内左上角像素点位置纵坐标;x 1为所述当前块内右上角像素点位置横坐标,y 1为所述当前块内右上角像素点位置纵坐标;x 4为所述相邻块内左上角像素点位置横坐标,y 4为所述当前块内左上角像素点位置纵坐标;x 5为所述相邻块内右上角像素点位置横坐标,y 6为所述相邻块内左下角像素点位置纵坐标。
- 根据权利要求9-13任一项所述的设备,其特征在于,所述预测处理单元具体用于:根据所述当前块的K个控制点的目标候选运动矢量,得到所述当前块的2乘K个参数的仿射变换模型;根据所述当前块的2乘K个参数的仿射变换模型,得到所述当前块中各个子块的预测运动矢量。
- 根据权利要求14所述的设备,其特征在于,所述预测处理单元具体用于:根据所述当前块的K个控制点的目标候选运动矢量,以及所述当前块的K个控制点的运动矢量差值,得到当前块的K个控制点的运动矢量;其中,所述当前块的K个控制点的运动矢量差值是通过解析所述码流得到的;根据所述当前块的K个控制点的运动矢量,获得所述当前块的2乘K个参数的仿射变换模型。
- 根据权利要求9-13任一项所述的设备,其特征在于,所述根据所述索引值,从所述候选运动矢量列表中确定所述当前块的K个控制点的目标候选运动矢量之后,所述预测处理单元还用于:根据所述当前块的K个控制点的目标候选运动矢量,获得所述当前块的6参数的仿射变换模型;根据所述当前块的6参数的仿射变换模型,得到所述当前块中各个子块的预测运动矢量。
Priority Applications (15)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
MX2021000171A MX2021000171A (es) | 2018-07-02 | 2018-11-22 | Método de predicción de vector de movimiento y aparato relacionado. |
CN202211258218.8A CN115695791A (zh) | 2018-07-02 | 2018-11-22 | 视频图像编码方法以及用于对视频数据进行编码的设备 |
KR1020217002027A KR102606146B1 (ko) | 2018-07-02 | 2018-11-22 | 모션 벡터 예측 방법 및 관련 장치 |
KR1020237040062A KR20230162152A (ko) | 2018-07-02 | 2018-11-22 | 모션 벡터 예측 방법 및 관련 장치 |
SG11202013202YA SG11202013202YA (en) | 2018-07-02 | 2018-11-22 | Motion vector prediction method and related apparatus |
CN202211226203.3A CN115733974A (zh) | 2018-07-02 | 2018-11-22 | 视频图像编码方法以及用于对视频数据进行编码的设备 |
CN201880002952.3A CN110876282B (zh) | 2018-07-02 | 2018-11-22 | 运动矢量预测方法以及相关装置 |
JP2020573324A JP7368396B2 (ja) | 2018-07-02 | 2018-11-22 | 動きベクトル予測方法及び関連する装置 |
EP18925643.1A EP3809704A4 (en) | 2018-07-02 | 2018-11-22 | METHOD AND RELATED DEVICE FOR MOTION VECTOR PREDICTION |
BR112020026992-1A BR112020026992A2 (pt) | 2018-07-02 | 2018-11-22 | Método de predição de vetor de movimento e aparelho relacionado |
US17/140,041 US11206408B2 (en) | 2018-07-02 | 2021-01-01 | Motion vector prediction method and related apparatus |
US17/525,944 US11683496B2 (en) | 2018-07-02 | 2021-11-14 | Motion vector prediction method and related apparatus |
US18/318,731 US12108048B2 (en) | 2018-07-02 | 2023-05-17 | Video image encoding method and related computer-readable medium and apparatus |
US18/318,730 US12120310B2 (en) | 2018-07-02 | 2023-05-17 | Motion vector prediction method and related apparatus |
JP2023176813A JP2023184560A (ja) | 2018-07-02 | 2023-10-12 | 動きベクトル予測方法及び関連する装置 |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201862693422P | 2018-07-02 | 2018-07-02 | |
US62/693,422 | 2018-07-02 | ||
US201862699733P | 2018-07-18 | 2018-07-18 | |
US62/699,733 | 2018-07-18 |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US17/140,041 Continuation US11206408B2 (en) | 2018-07-02 | 2021-01-01 | Motion vector prediction method and related apparatus |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2020006969A1 true WO2020006969A1 (zh) | 2020-01-09 |
Family
ID=69060695
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/CN2018/116984 WO2020006969A1 (zh) | 2018-07-02 | 2018-11-22 | 运动矢量预测方法以及相关装置 |
Country Status (9)
Country | Link |
---|---|
US (4) | US11206408B2 (zh) |
EP (1) | EP3809704A4 (zh) |
JP (2) | JP7368396B2 (zh) |
KR (2) | KR102606146B1 (zh) |
CN (3) | CN115695791A (zh) |
BR (1) | BR112020026992A2 (zh) |
MX (4) | MX2021000171A (zh) |
SG (1) | SG11202013202YA (zh) |
WO (1) | WO2020006969A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2022078150A1 (zh) * | 2020-10-18 | 2022-04-21 | 腾讯科技(深圳)有限公司 | 候选运动信息列表确定方法、装置、电子设备及存储介质 |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI835864B (zh) * | 2018-09-23 | 2024-03-21 | 大陸商北京字節跳動網絡技術有限公司 | 簡化的空時運動矢量預測 |
US11418793B2 (en) * | 2018-10-04 | 2022-08-16 | Qualcomm Incorporated | Adaptive affine motion vector coding |
WO2020125754A1 (en) * | 2018-12-21 | 2020-06-25 | Beijing Bytedance Network Technology Co., Ltd. | Motion vector derivation using higher bit-depth precision |
CN112055207B (zh) * | 2020-08-06 | 2024-05-31 | 浙江大华技术股份有限公司 | 时域运动矢量预测方法、设备及存储介质 |
US11425368B1 (en) * | 2021-02-17 | 2022-08-23 | Adobe Inc. | Lossless image compression using block based prediction and optimized context adaptive entropy coding |
CN114979627A (zh) * | 2021-02-24 | 2022-08-30 | 华为技术有限公司 | 视频编码中的运动矢量(mv)约束和变换约束 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102934440A (zh) * | 2010-05-26 | 2013-02-13 | Lg电子株式会社 | 用于处理视频信号的方法和设备 |
CN103402045A (zh) * | 2013-08-20 | 2013-11-20 | 长沙超创电子科技有限公司 | 一种基于分区匹配和仿射模型相结合的图像去旋稳像方法 |
CN103561263A (zh) * | 2013-11-06 | 2014-02-05 | 北京牡丹电子集团有限责任公司数字电视技术中心 | 基于运动矢量约束和加权运动矢量的运动补偿预测方法 |
CN104539966A (zh) * | 2014-09-30 | 2015-04-22 | 华为技术有限公司 | 图像预测方法及相关装置 |
CN106375770A (zh) * | 2011-01-21 | 2017-02-01 | Sk电信有限公司 | 视频解码方法 |
CN106454378A (zh) * | 2016-09-07 | 2017-02-22 | 中山大学 | 一种基于变形运动模型的帧率上转换视频编码方法及系统 |
CN106878749A (zh) * | 2010-12-28 | 2017-06-20 | 太阳专利托管公司 | 图像解码方法、图像解码装置 |
Family Cites Families (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102883163B (zh) * | 2012-10-08 | 2014-05-28 | 华为技术有限公司 | 用于运动矢量预测的运动矢量列表建立的方法、装置 |
WO2016008157A1 (en) * | 2014-07-18 | 2016-01-21 | Mediatek Singapore Pte. Ltd. | Methods for motion compensation using high order motion model |
CN106303543B (zh) * | 2015-05-15 | 2018-10-30 | 华为技术有限公司 | 视频图像编码和解码的方法、编码设备和解码设备 |
CN107925758B (zh) | 2015-08-04 | 2022-01-25 | Lg 电子株式会社 | 视频编译系统中的帧间预测方法和设备 |
US10582215B2 (en) * | 2015-08-07 | 2020-03-03 | Lg Electronics Inc. | Inter prediction method and apparatus in video coding system |
CN108600749B (zh) * | 2015-08-29 | 2021-12-28 | 华为技术有限公司 | 图像预测的方法及设备 |
GB2561507B (en) | 2016-01-07 | 2021-12-22 | Mediatek Inc | Method and apparatus for affine merge mode prediction for video coding system |
WO2017156705A1 (en) * | 2016-03-15 | 2017-09-21 | Mediatek Inc. | Affine prediction for video coding |
US10560712B2 (en) * | 2016-05-16 | 2020-02-11 | Qualcomm Incorporated | Affine motion prediction for video coding |
EP3449630B1 (en) | 2016-05-28 | 2024-07-10 | Mediatek Inc. | Method and apparatus of current picture referencing for video coding |
US10631002B2 (en) | 2016-09-30 | 2020-04-21 | Qualcomm Incorporated | Frame rate up-conversion coding mode |
US10448010B2 (en) | 2016-10-05 | 2019-10-15 | Qualcomm Incorporated | Motion vector prediction for affine motion models in video coding |
US10873744B2 (en) * | 2017-01-03 | 2020-12-22 | Lg Electronics Inc. | Method and device for processing video signal by means of affine prediction |
US10701390B2 (en) * | 2017-03-14 | 2020-06-30 | Qualcomm Incorporated | Affine motion information derivation |
US10602180B2 (en) * | 2017-06-13 | 2020-03-24 | Qualcomm Incorporated | Motion vector prediction |
-
2018
- 2018-11-22 WO PCT/CN2018/116984 patent/WO2020006969A1/zh unknown
- 2018-11-22 SG SG11202013202YA patent/SG11202013202YA/en unknown
- 2018-11-22 MX MX2021000171A patent/MX2021000171A/es unknown
- 2018-11-22 BR BR112020026992-1A patent/BR112020026992A2/pt unknown
- 2018-11-22 CN CN202211258218.8A patent/CN115695791A/zh active Pending
- 2018-11-22 KR KR1020217002027A patent/KR102606146B1/ko active IP Right Grant
- 2018-11-22 CN CN201880002952.3A patent/CN110876282B/zh active Active
- 2018-11-22 JP JP2020573324A patent/JP7368396B2/ja active Active
- 2018-11-22 EP EP18925643.1A patent/EP3809704A4/en not_active Withdrawn
- 2018-11-22 KR KR1020237040062A patent/KR20230162152A/ko active IP Right Grant
- 2018-11-22 CN CN202211226203.3A patent/CN115733974A/zh active Pending
-
2021
- 2021-01-01 US US17/140,041 patent/US11206408B2/en active Active
- 2021-01-06 MX MX2022013782A patent/MX2022013782A/es unknown
- 2021-01-06 MX MX2022013784A patent/MX2022013784A/es unknown
- 2021-01-06 MX MX2022013781A patent/MX2022013781A/es unknown
- 2021-11-14 US US17/525,944 patent/US11683496B2/en active Active
-
2023
- 2023-05-17 US US18/318,731 patent/US12108048B2/en active Active
- 2023-05-17 US US18/318,730 patent/US12120310B2/en active Active
- 2023-10-12 JP JP2023176813A patent/JP2023184560A/ja active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102934440A (zh) * | 2010-05-26 | 2013-02-13 | Lg电子株式会社 | 用于处理视频信号的方法和设备 |
CN106878749A (zh) * | 2010-12-28 | 2017-06-20 | 太阳专利托管公司 | 图像解码方法、图像解码装置 |
CN106375770A (zh) * | 2011-01-21 | 2017-02-01 | Sk电信有限公司 | 视频解码方法 |
CN103402045A (zh) * | 2013-08-20 | 2013-11-20 | 长沙超创电子科技有限公司 | 一种基于分区匹配和仿射模型相结合的图像去旋稳像方法 |
CN103561263A (zh) * | 2013-11-06 | 2014-02-05 | 北京牡丹电子集团有限责任公司数字电视技术中心 | 基于运动矢量约束和加权运动矢量的运动补偿预测方法 |
CN104539966A (zh) * | 2014-09-30 | 2015-04-22 | 华为技术有限公司 | 图像预测方法及相关装置 |
CN106454378A (zh) * | 2016-09-07 | 2017-02-22 | 中山大学 | 一种基于变形运动模型的帧率上转换视频编码方法及系统 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2022078150A1 (zh) * | 2020-10-18 | 2022-04-21 | 腾讯科技(深圳)有限公司 | 候选运动信息列表确定方法、装置、电子设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
JP7368396B2 (ja) | 2023-10-24 |
MX2022013784A (es) | 2022-11-30 |
EP3809704A1 (en) | 2021-04-21 |
US12120310B2 (en) | 2024-10-15 |
CN110876282A (zh) | 2020-03-10 |
US12108048B2 (en) | 2024-10-01 |
CN115733974A (zh) | 2023-03-03 |
EP3809704A4 (en) | 2021-04-28 |
KR20210022101A (ko) | 2021-03-02 |
US11683496B2 (en) | 2023-06-20 |
US20220078443A1 (en) | 2022-03-10 |
CN115695791A (zh) | 2023-02-03 |
MX2022013782A (es) | 2022-11-30 |
MX2021000171A (es) | 2022-11-01 |
US11206408B2 (en) | 2021-12-21 |
JP2023184560A (ja) | 2023-12-28 |
CN110876282B (zh) | 2022-10-18 |
KR102606146B1 (ko) | 2023-11-23 |
US20210127116A1 (en) | 2021-04-29 |
US20230370607A1 (en) | 2023-11-16 |
SG11202013202YA (en) | 2021-01-28 |
US20230370606A1 (en) | 2023-11-16 |
BR112020026992A2 (pt) | 2021-04-06 |
MX2022013781A (es) | 2022-11-30 |
KR20230162152A (ko) | 2023-11-28 |
JP2021529483A (ja) | 2021-10-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2020006969A1 (zh) | 运动矢量预测方法以及相关装置 | |
TWI786790B (zh) | 視頻資料的幀間預測方法和裝置 | |
WO2020052304A1 (zh) | 基于仿射运动模型的运动矢量预测方法及设备 | |
WO2020088324A1 (zh) | 一种视频图像预测方法及装置 | |
WO2020088482A1 (zh) | 基于仿射预测模式的帧间预测的方法及相关装置 | |
CN117730535A (zh) | 视频编解码中用于仿射运动补偿预测的几何分割 | |
CN110876065A (zh) | 候选运动信息列表的构建方法、帧间预测方法及装置 | |
WO2023092256A1 (zh) | 一种视频编码方法及其相关装置 | |
CN112055970B (zh) | 候选运动信息列表的构建方法、帧间预测方法及装置 | |
WO2020007093A1 (zh) | 一种图像预测方法及装置 | |
CN110971899B (zh) | 一种确定运动信息的方法、帧间预测方法及装置 | |
CN110677645B (zh) | 一种图像预测方法及装置 | |
WO2020042724A1 (zh) | 帧间预测方法、装置以及视频编码器和视频解码器 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 18925643 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2020573324 Country of ref document: JP Kind code of ref document: A |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
REG | Reference to national code |
Ref country code: BR Ref legal event code: B01A Ref document number: 112020026992 Country of ref document: BR |
|
ENP | Entry into the national phase |
Ref document number: 20217002027 Country of ref document: KR Kind code of ref document: A |
|
ENP | Entry into the national phase |
Ref document number: 2018925643 Country of ref document: EP Effective date: 20210114 |
|
ENP | Entry into the national phase |
Ref document number: 112020026992 Country of ref document: BR Kind code of ref document: A2 Effective date: 20201230 |