US20150131739A1 - Method for encoding image, method for decoding image, image encoder, and image decoder - Google Patents
Method for encoding image, method for decoding image, image encoder, and image decoder Download PDFInfo
- Publication number
- US20150131739A1 US20150131739A1 US14/605,236 US201514605236A US2015131739A1 US 20150131739 A1 US20150131739 A1 US 20150131739A1 US 201514605236 A US201514605236 A US 201514605236A US 2015131739 A1 US2015131739 A1 US 2015131739A1
- Authority
- US
- United States
- Prior art keywords
- transform
- block
- motion vector
- prediction
- mode
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
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/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/60—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform 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/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/12—Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
-
- 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/46—Embedding additional information in the video signal during the compression process
-
- 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/103—Selection of coding mode or of prediction mode
-
- 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/12—Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
- H04N19/122—Selection of transform size, e.g. 8x8 or 2x4x8 DCT; Selection of sub-band transforms of varying structure or type
-
- 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/124—Quantisation
-
- 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/157—Assigned coding mode, i.e. the coding mode being predefined or preselected to be further used for selection of another element or parameter
-
- 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/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/18—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 a set of transform coefficients
-
- 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/189—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding
- H04N19/192—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding the adaptation method, adaptation tool or adaptation type being iterative or recursive
- H04N19/194—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding the adaptation method, adaptation tool or adaptation type being iterative or recursive involving only two passes
-
- 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/44—Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
-
- 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/44—Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
- H04N19/45—Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder performing compensation of the inverse transform mismatch, e.g. Inverse Discrete Cosine Transform [IDCT] mismatch
-
- 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
-
- 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
-
- 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
-
- 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/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/59—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial sub-sampling or interpolation, e.g. alteration of picture size or resolution
-
- 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/625—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding using discrete cosine transform [DCT]
-
- 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
-
- 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/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/91—Entropy coding, e.g. variable length coding [VLC] or arithmetic 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/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/96—Tree coding, e.g. quad-tree 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/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/146—Data rate or code amount at the encoder output
- H04N19/147—Data rate or code amount at the encoder output according to rate distortion criteria
Definitions
- the present invention relates to video encoding and decoding, and more particularly, to a method and an apparatus for transforming a signal in video encoding and decoding.
- HD high-definition
- UHD ultrahigh-definition
- high-efficiency video compression techniques may be utilized.
- Video compression technology include various techniques, such as an inter prediction technique of predicting pixel values included in a current picture from previous or subsequent pictures of the current picture, an intra prediction technique of predicting pixel values included in a current picture using pixel information in the current picture, a technique of transforming pixel information into a frequency domain by a predetermined unit and quantizing a transform coefficient, and an entropy encoding technique of assigning a short code to a value with a high appearance frequency and assigning a long code to a value with a low appearance frequency.
- Video data may be effectively compressed and transferred or stored using such video compression techniques.
- An aspect of the present invention is to provide a method and an apparatus for efficiently transforming video information.
- Another aspect of the present invention is to provide a method and an apparatus for performing first transform according to a prediction method and performing second transform on a low-frequency domain according to the first transform to improve efficiency in compression.
- Still another aspect of the present invention is to provide a method and an apparatus for performing first transform according to a shape of a partition and performing second transform on a low-frequency domain according to the first transform to improve efficiency in compression.
- An embodiment of the present invention provides a video encoding method including performing prediction for a current block, and transforming a residual generated by the prediction, wherein, in the transforming step, second transform is performed on a low-frequency domain after performing first transform on the residual, and determines a mode of the second transform based on a mode of the first transform.
- intra prediction may be performed for the current block, and the mode of the first transform may be determined as one of 2-directional (2D) transform, 1-directional (1D) vertical transform, 1D horizontal transform and non-transform based on a direction of a prediction mode of the intra prediction.
- the mode of the second transform may be the same as the mode of the first transform.
- inter prediction may be performed for the current block, and the mode of the first transform may be determined as one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform based on a shape of the current block.
- the mode of the second transform may be the same as the mode of the first transform.
- the mode of the first transform may be determined based on rate-distortion optimization.
- information indicating the determined mode of the first transform may be transmitted.
- the second transform may be discrete sine transform (DST) by a 4 ⁇ 4 block.
- Another embodiment of the present invention provides a video decoding method including performing inverse transform to generate a residual block for a current block, and performing prediction to generate a predicted block for the current block, wherein, in the performing inverse transform, second inverse transform on a low-frequency domain may be performed after performing first inverse transform on encoded residual information for the current block, and a mode of the second transform may be determined based on a mode of the first transform.
- intra prediction may be performed for the current block, and the mode of the first inverse transform may be determined as one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform based on a direction of a prediction mode of the intra prediction.
- the mode of the second inverse transform may be the same as the mode of the first inverse transform.
- inter prediction may be performed for the current block, and the mode of the inverse first transform is determined as one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform based on a shape of the current block.
- the mode of the second inverse transform may be the same as the mode of the first inverse transform.
- the first inverse transform may be performed according to a mode indicated by received information, and the received information indicates one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform as the mode of the first inverse transform.
- the mode of the second inverse transform may be the same as the mode of the first inverse transform.
- the second transform may be DST by a 4 ⁇ 4 block.
- Still another embodiment of the present invention provides a video encoding apparatus including a prediction module to perform prediction for a current block, and a transform module to transform a residual generated by the prediction, wherein the transform module performs second transform on a low-frequency domain after performing first transform on the residual and determines a mode of the second transform based on a mode of the first transform.
- Yet another embodiment of the present invention provides a video decoding method including an inverse transform module to generate a residual block for a current block by performing inverse transform, and a prediction module to generate a predicted block for the current block, wherein the inverse transform module performs second inverse transform on a low-frequency domain after performing first inverse transform on encoded residual information for the current block, and determines a mode of the second transform based on a mode of the first transform.
- residual information may be efficiently transformed and inverse-transformed.
- first transform may be performed according to a prediction method and second transform may be performed on a low-frequency domain according to the first transform, thereby improving efficiency in compression and transmission.
- first transform may be performed according to a partitioned shape and second transform may be performed on a low-frequency domain according to the first transform, thereby improving efficiency in compression and transmission.
- FIG. 1 is a block diagram illustrating a video encoding apparatus according to an exemplary embodiment of the present invention.
- FIG. 2 is a block diagram illustrating a video decoding apparatus according to an exemplary embodiment of the present invention.
- FIG. 3 schematically illustrates a prediction mode used for intra prediction.
- FIG. 4 schematically illustrates a transform skip mode (TMS).
- FIG. 5 is a flowchart schematically illustrating an encoding process adopting a transform skip mode and second transform according to the present invention.
- FIG. 6 schematically illustrates information on a neighboring block available in a skip mode, a merge mode, and an AMVP mode.
- FIG. 7 is a flowchart schematically illustrating a decoding process adopting a transform skip mode and second transform according to the present invention.
- first, second, etc. may be used to describe various elements, these elements should not be limited by these terms. These terms are used only to distinguish one element from another element. For example, a first element could be termed a second element and a second element could be termed a first element likewise without departing from the teachings of the present invention.
- the term “and/or” includes any and all combinations of a plurality of associated listed items.
- FIG. 1 is a block diagram illustrating a video encoding apparatus according to an exemplary embodiment of the present invention.
- the video encoding apparatus 100 includes a picture partitioning module 105 , a prediction module 110 , a transform module 115 , a quantization module 120 , a rearrangement module 125 , an entropy encoding module 130 , a dequantization module 135 , an inverse transform module 140 , a filter module 145 and a memory 150 .
- FIG. 1 Although elements illustrated in FIG. 1 are independently shown so as to represent different distinctive functions in the video encoding apparatus, such a configuration does not indicate that each element is constructed by a separate hardware constituent or software constituent. That is, the elements are independently arranged for convenience of description, wherein at least two elements may be combined into a single element, or a single element may be divided into a plurality of elements to perform functions. It is to be noted that embodiments in which some elements are integrated into one combined element and/or an element is divided into multiple separate elements are included in the scope of the present invention without departing from the essence of the present invention.
- Some elements may not be essential to the substantial functions in the invention and may be optional constituents for merely improving performance.
- the invention may be embodied by including only constituents essential to embodiment of the invention, except for constituents used to merely improve performance.
- the structure including only the essential constituents except for the optical constituents used to merely improve performance belongs to the scope of the invention.
- the picture partitioning module 105 may partition an input picture into at least one process unit.
- the process unit may be a prediction unit (PU), a transform unit (TU) or a coding unit (CU).
- the picture partitioning module 105 may partition one picture into a plurality of combinations of coding units, prediction units and transform units and select one combination of coding units, prediction units and transform units on the basis of a predetermined criterion (for example, a cost function), thereby encoding the picture.
- a predetermined criterion for example, a cost function
- one picture may be partitioned into a plurality of coding units.
- a recursive tree structure such as a quad tree structure may be used to partition a picture into coding units.
- a coding unit Being a picture or a coding unit of a maximum size as root, a coding unit may be partitioned into sub-coding units with as many child nodes as the partitioned coding units.
- a coding unit which is not partitioned any more in accordance with a predetermined constraint is to be a leaf node. That is, assuming that a coding unit may be partitioned into quadrates only, a single coding unit may be partitioned into at most four different coding units.
- a coding unit may be used to refer to not only a unit of encoding but also a unit of decoding.
- a prediction unit may be partitioned into at least one square or rectangular form with the same size in a coding unit or be partitioned such that a shape of partitioned prediction unit is different from a shape of other prediction unit in a coding unit.
- intra prediction may be performed without partitioning the coding unit into plural prediction units (N ⁇ N).
- the prediction module 110 may include an inter prediction module to perform inter prediction and an intra prediction module to perform intra prediction.
- the prediction module may determine which of inter prediction or intra prediction should be performed on a prediction unit, and may determine specific information (for example, intra prediction mode, motion vector, and reference picture, etc) according to the determined prediction method.
- a process unit on which prediction is performed may be different from a process unit for which a prediction method and specific information are determined.
- a prediction method and a prediction mode may be determined for each prediction unit, while prediction may be performed for each transform unit.
- a residual value (residual block) between a generated predicted block and an original block may be input to the transform module 115 .
- prediction mode information, motion vector information and the like used for prediction may be encoded along with the residual value by the entropy encoding module 130 and be transmitted to the decoding apparatus.
- the original block may be encoded and transmitted to the decoding apparatus without generating a predicted block through the prediction module 110 .
- the inter prediction module may predict for a prediction unit on the basis of information on at least one picture among a previous picture and a subsequent picture of a current picture.
- the inter prediction module may include a reference picture interpolation module, a motion prediction module, and a motion compensation module.
- the reference picture interpolation module may be supplied with reference picture information from the memory 150 and generate pixel information less than an integer pixel position unit (an integer pixel unit or a pixel unit) from a reference picture.
- an integer pixel position unit an integer pixel unit or a pixel unit
- a DCT-based 8-tap interpolation filter having a varying filter coefficient may be used to generate pixel information less than an integer pixel unit in a unit of 1 ⁇ 4 pixel position (a unit of 1 ⁇ 4 pixel).
- a DCT-based 4-tap interpolation filter having a varying filter coefficient may be used to generate pixel information less than an integer pixel unit in a unit of 1 ⁇ 8 pixel.
- the motion prediction module may perform motion prediction on the basis of the reference picture interpolated by the reference picture interpolation module.
- Various methods such as a full search-based block matching algorithm (FBMA), a three-step search (TSS) algorithm and a new three-step search (NTS) algorithm, may be used to calculate a motion vector.
- FBMA full search-based block matching algorithm
- TSS three-step search
- NTS new three-step search
- a motion vector has a motion vector value in a unit of 1 ⁇ 2 or 1 ⁇ 4 pixel on the basis of an interpolated pixel.
- the motion prediction module may perform a prediction on a current prediction unit using different motion prediction methods.
- Various methods such as skipping, merging, and advanced motion vector prediction (AMVP) etc, may be used as the motion prediction method.
- AMVP advanced motion vector prediction
- the intra prediction module may generate a prediction block based on information of reference pixel neighboring to a current block which is pixel information in a current picture.
- a block neighboring to a current prediction unit is a block having been subjected to inter prediction and a reference pixel is a pixel having been subjected to inter prediction
- reference pixel information included in the block having been subjected to inter prediction may be substituted with a reference pixel information in a block having been subjected to intra prediction. That is, when a reference pixel is not available, information on the unavailable reference pixel may be substituted with at least one reference pixel of the available reference pixels.
- a prediction mode of intra prediction includes a directional prediction mode in which information on a reference pixel is used according to a prediction direction and a non-directional prediction mode in which direction information is not used in performing prediction.
- a mode for predicting luma information and a mode for predicting chroma information may be different from each other.
- Intra prediction mode information used to obtain luma information or predicted luma signal information may be used to predict chroma information.
- intra prediction on the prediction unit may be performed based on left pixels, an upper-left pixel and upper pixels of the prediction unit.
- intra prediction may be performed using reference pixels based on the transform unit.
- Intra prediction with N ⁇ N partitioning may be performed only for a minimum coding unit.
- an adaptive intra smoothing (AIS) filter may be applied to reference pixels according to the prediction mode prior to generation of a predicted block.
- AIS adaptive intra smoothing
- the intra prediction mode of a current prediction unit may be predicted from an intra prediction mode of a prediction unit located neighboring to the current prediction unit.
- mode information predicted from a neighboring prediction unit when the current prediction unit and the neighboring prediction unit have the same intra prediction mode, information indicating that the current prediction unit and the neighboring prediction unit have the same prediction mode may be transmitted using predetermined flag information. If the current prediction unit and the neighboring prediction unit have different prediction modes, information on the prediction mode of the current block may be encoded by entropy encoding.
- a residual block including residual information which is on a difference between the predicted block and the original block of the prediction unit may be generated based on the prediction unit by the prediction module 110 .
- the generated residual block may be input to the transform module 115 .
- the transform module 115 may transform the residual block including the residual information of the prediction unit generated based on the original block by the prediction module 110 using a transform method such as Discrete Cosine Transform (DCT) or Discrete Sine Transform (DST).
- DCT Discrete Cosine Transform
- DST Discrete Sine Transform
- a transform method to be used to transform the residual block may be determined among DCT and DST on the basis of the intra prediction mode information of the prediction unit used to generate the residual block.
- the quantization module 120 may quantize values transformed into a frequency domain by the transform module 115 .
- a quantization parameter may change depending on a block or importance of a picture. Values output from the quantization module 120 may be provided to the dequantization module 135 and the rearrangement module 125 .
- the rearrangement module 125 may rearrange coefficients.
- the rearrangement module 125 may change a two-dimensional (2D) block of coefficients into a one-dimensional (1D) vector of coefficients through coefficient scanning. For example, the rearrangement module 125 may change a 2D block of coefficients into a 1D vector of coefficients using upright scanning. Vertical scanning of a 2D block of coefficients in a column direction and horizontal scanning of a 2D block of coefficients in a row direction may be used depending on a size of a transform unit and an intra prediction mode, instead of upright scanning. That is, a scanning method for use may be selected based on the size of the transform unit and the intra prediction mode among upright scanning, vertical scanning, and horizontal scanning.
- the entropy encoding module 130 may perform entropy encoding on the basis of the values obtained by the rearrangement module 125 .
- Various encoding methods such as exponential Golomb coding, context-adaptive variable length coding (CAVLC), and context-adaptive binary arithmetic coding (CABAC), may be used for entropy encoding.
- the entropy encoding module 130 may encode a variety of information, such as residual coefficient information and block type information on a coding unit, prediction mode information, partitioning unit information, prediction unit information, transfer unit information, motion vector information, reference frame information, block interpolation information and filtering information which may be obtained from the rearrangement module 125 and the prediction module 110 .
- the entropy encoding module 130 may entropy-encode coefficients of a coding unit input from the rearrangement module 125 .
- the dequantization module 135 and the inverse transform module 140 dequantize the values quantized by the quantization module 120 and inversely transform the values transformed by the transform module 115 .
- the residual generated by the dequantization module 135 and the inverse transform module 140 may be added to the predicted block, which is predicted by the motion vector prediction module, the motion compensation module, and the intra prediction module of the prediction module 110 , thereby generating a reconstructed block.
- the filter module 145 may include at least one of a deblocking filter, an offset correction module, and an adaptive loop filter (ALF).
- a deblocking filter may include at least one of a deblocking filter, an offset correction module, and an adaptive loop filter (ALF).
- ALF adaptive loop filter
- the deblocking filter 145 may remove block distortion generated at boundaries between blocks in a reconstructed picture. Whether to apply the deblocking filter to a current block may be determined on the basis of pixels included in several rows or columns of the block. When the deblocking filter is applied to a block, a strong filter or a weak filter may be applied depending on a required deblocking filtering strength. In addition, when horizontal filtering and vertical filtering are performed in applying the deblocking filter, the horizontal filtering and vertical filtering may be performed in parallel.
- the offset correction module may correct an offset of the deblocking filtered picture from the original picture by a pixel.
- a method of partitioning pixels of a picture into a predetermined number of regions, determining a region to be subjected to offset correction, and applying offset correction to the determined region or a method of applying offset correction in consideration of edge information on each pixel may be used to perform offset correction on a specific picture.
- the ALF may perform filtering based on a comparison result of the filtered reconstructed picture and the original picture. Pixels included in a picture may be partitioned into predetermined groups, a filter to be applied to each group may be determined, and differential filtering may be performed for each group. Information on whether to apply the ALF may be transferred by each coding unit (CU) and a shape and coefficient of an ALF to be applied to each block may vary.
- the ALF may have various types and a number of coefficients included in a corresponding filter may vary. Further, an ALF filter with the same form (fixed form) may be applied to a block regardless of characteristics of the block.
- the memory 150 may store a reconstructed block or picture output from the filter module 145 , and the stored reconstructed block or picture may be provided to the prediction module 110 when performing inter prediction.
- FIG. 2 is a block diagram illustrating a video decoding apparatus according an exemplary embodiment of the present invention.
- the video decoding apparatus 200 may include an entropy decoding module 210 , a rearrangement module 215 , a dequantization module 220 , an inverse transform module 225 , a prediction module 230 , a filter module 235 , and a memory 240 .
- the input bitstream may be decoded according to an inverse process of the video encoding process by the video encoding apparatus.
- the entropy decoding module 210 may perform entropy decoding according to an inverse process of the entropy encoding process by the entropy encoding module of the video encoding apparatus. For example, various methods, such as exponential Golomb coding, CAVLC and CABAC, may be used for entropy decoding, corresponding to the method used by the video encoding apparatus.
- various methods such as exponential Golomb coding, CAVLC and CABAC, may be used for entropy decoding, corresponding to the method used by the video encoding apparatus.
- the entropy decoding module 210 may decode information associated with intra prediction and inter prediction performed by the encoding apparatus.
- the rearrangement module 215 may perform rearrangement on the bitstream entropy-decoded by the entropy decoding module 210 on the basis of the rearrangement method of the encoding module.
- the rearrangement module 215 may reconstruct and rearrange coefficients expressed in a 1D vector form into coefficients in a 2D block.
- the rearrangement module 215 may be provided with information associated with coefficient scanning performed by the encoding module and may perform rearrangement using a method of inversely scanning the coefficients on the basis of scanning order by which scanning is performed by the encoding module.
- the dequantization module 220 may perform dequantization on the basis of a quantization parameter provided from the encoding apparatus and the rearranged coefficients of the block.
- the inverse transform module 225 may perform inverse DCT and inverse DST with respect to DCT and DST performed by the transform module, where the DCT and DST have been performed on the result of quantization by the video encoding apparatus.
- Inverse transform may be performed on the basis of a transform unit determined by the video encoding apparatus.
- the transform module of the video encoding apparatus may selectively perform DCT and DST depending on a plurality of information elements, such as a prediction method, a size of the current block and a prediction direction, etc, and the inverse transform module 225 of the video decoding apparatus may perform inverse transform on the basis of information on the transform performed by the transform module of the video encoding apparatus.
- the prediction module 230 may generate a predicted block on the basis of predicted block generation information provided from the entropy decoding module 210 and information on a previously-decoded block or picture provided from the memory 240 .
- intra prediction on the prediction unit is performed based on left pixels, an upper-left pixel and upper pixels of the prediction unit.
- intra prediction may be performed using reference pixels based on the transform unit.
- Intra prediction with N ⁇ N partitioning may be performed only for a minimum coding unit.
- the prediction module 230 includes a prediction unit determination module, an inter prediction module and an intra prediction module.
- the prediction unit determination module may receive a variety of information, such as prediction unit information input from the entropy decoding module, prediction mode information of an intra prediction method and motion prediction-related information on an inter prediction method. And the prediction unit determination module may determine a prediction unit in a current coding unit, and may determine which of the inter prediction and the intra prediction is performed on the prediction unit.
- the inter prediction module may perform inter prediction on a current prediction unit based on information of at least one picture among a previous picture and a subsequent picture of a current picture including the current prediction unit using information necessary for inter prediction for the current prediction unit provided from the video encoding apparatus.
- a motion prediction method for a prediction unit included in the coding unit is a skip mode, a merge mode or an AMVP mode.
- the intra prediction module may generate a predicted block on the basis of pixel information in a current picture.
- intra prediction may be performed based on intra prediction mode information on the prediction unit provided from the video encoding apparatus.
- the intra prediction module may include an AIS filter, a reference pixel interpolation module, and a DC filter.
- the AIS filter performs filtering on reference pixels of a current block, and whether to apply the AIS filter may be determined depending on a prediction mode for the current prediction unit.
- AIS filtering may be performed on the reference pixels of the current block using the prediction mode for the prediction unit and information on the AIS filter provided from the video encoding apparatus.
- the prediction mode for the current block is a mode not involving AIS filtering, the AIS filter may not be applied.
- the reference pixel interpolation module may generate reference pixels in a pixel unit of less than an integer position unit by interpolating the reference pixels.
- the prediction mode for the current prediction unit is a prediction mode of generating a predicted block without interpolating the reference pixels
- the reference pixels may not be interpolated.
- the DC filter may generate a predicted block through filtering when the prediction mode for the current block is the DC mode.
- the reconstructed block or picture may be provided to the filter module 235 .
- the filter module 235 may include a deblocking filter, an offset correction module, or an ALF.
- Information on whether the deblocking filter is applied to a corresponding block or picture and information on which of a strong filter and a weak filter is applied when the deblocking filter is used may be provided from the video encoding apparatus.
- the deblocking filter of the video decoding apparatus may be provided with information on the deblocking filtering from the video encoding apparatus and may perform deblocking filtering on a corresponding block.
- the offset correction module may perform offset correction on the reconstructed picture based on an offset correction type and offset value information applied to the picture in the encoding process.
- the ALF may be applied to a coding unit on the basis of information on whether the ALF is applied or not, and ALF coefficient information provided from the encoding apparatus.
- the ALF information may be included and provided in a specific parameter set.
- the memory 240 may store the reconstructed picture or block for use as a reference picture or a reference block, and may provide the reconstructed picture to an output module.
- coding unit is used as an encoding unit and may be also used as a unit of decoding (decoding unit).
- the transform modules of the encoding apparatus and the decoding apparatus may perform block-based transform, such as DST or DCT, on a residual block (transform block).
- block-based transform such as DST or DCT
- transform may be determined according to a prediction mode.
- FIG. 3 schematically illustrates a prediction mode used for intra prediction.
- intra prediction is carried out using two non-directional prediction modes and 32 directional prediction modes.
- the encoding apparatus and the decoding apparatus may perform intra prediction on a current block using a prediction mode selected among the two non-directional prediction modes, a planar mode and a DC mode, and the 32 directional prediction modes corresponding to directions shown in FIG. 3 .
- the encoding apparatus and the decoding apparatus may perform prediction on the current block to generate a predicted block based on samples located in a corresponding direction among neighboring samples to the current block.
- the encoding apparatus and the decoding apparatus may determine a transform method based on a prediction mode used to generate a predicted block.
- a transform skip mode is a method for enhancing encoding efficiency by performing all 2-dimensional (2D) transforms, skipping vertical transform or horizontal transform, or skipping both horizontal and vertical transforms.
- TS0 is a mode of performing 2D transform on a transform block.
- TS1 is a mode of performing transform on rows only in a transform block (transform on rows), and
- TS2 is a mode of performing transform on columns only in a transform block (transform on columns).
- TS3 is a mode of performing neither transform on rows (horizontal transform) nor transform on columns (vertical transform).
- a transform skip mode is a method of performing all 2D inverse transforms, skipping vertical inverse transform or horizontal inverse transform, or skipping both horizontal and vertical inverse transforms.
- TS0 is a mode of performing 2D inverse transform on a transform block.
- TS1 is a mode of performing inverse transform on rows only in a transform block (inverse transform on rows)
- TS2 is a mode of performing inverse transform on columns only in a transform block (inverse transform on columns).
- TS3 is a mode of performing neither inverse transform on rows (horizontal inverse transform) nor inverse transform on columns (vertical inverse transform).
- FIG. 4 schematically illustrates a transform skip mode.
- TS0 400 When TS0 400 is employed in the encoding apparatus, 2D transform is applied to on a transform block.
- horizontal transform may be performed before vertical transform or vertical transform may be performed before horizontal transform.
- TS1 420 When TS1 420 is employed, horizontal transform is performed on a transform block.
- TS2 440 When TS2 440 is employed, vertical transform is performed on a transform block.
- TS3 460 When TS3 460 is employed, neither horizontal transform nor vertical transform is performed on a transform block.
- TS0 400 When TS0 400 is employed in the decoding apparatus, 2D inverse transform is applied to on a transform block.
- horizontal inverse transform may be performed before vertical inverse transform or vertical inverse transform may be performed before horizontal inverse transform.
- TS1 420 When TS1 420 is employed, horizontal inverse transform is performed on a transform block.
- TS2 440 When TS2 440 is employed, vertical inverse transform is performed on a transform block.
- TS3 460 neither horizontal inverse transform nor vertical inverse transform is performed on a transform block.
- Table 1 illustrates a codeword allocated to each mode in transform skip modes.
- scaling may be carried out without changing or modifying a quantization matrix.
- Equation 1 illustrates an example of scaling to be performed by the encoding apparatus and decoding apparatus.
- Equation 1 x is a scaling target parameter, and y is a scaled parameter value.
- a shift operation factor (shift) may be adaptively determined in the encoding apparatus or be determined in advance.
- a scaling coefficient (scale) is dependent on a TU size and may be determined based on a TU size.
- Table 2 illustrates a scaling coefficient according to block (for example, TU) size.
- a scaling coefficient may be determined according to a block size (N ⁇ N), for example, a scaling coefficient for a 4 ⁇ 4 block is 128, a scaling coefficient for a 8 ⁇ 8 block is 181, a scaling coefficient for a 16 ⁇ 16 block is 256, and a scaling coefficient for a 32 ⁇ 32 block is 362.
- transform skip mode is applied based on an intra prediction mode in the foregoing description, the present invention is not limited thereto but transform skip mode may be also applied in inter prediction.
- a transform skip mode may be applied based on an intra prediction mode used when intra prediction is applied, while a transform skip mode may be applied based on a block shape when inter prediction is applied.
- Block shapes to which inter prediction may be applied are a 2N ⁇ 2N square block, a minimum size block of N ⁇ N, and asymmetric blocks of 2N ⁇ N, N ⁇ 2N, 2N ⁇ nU, 2N ⁇ nD, nL ⁇ 2N and nR ⁇ 2N, and a transform skip mode may be applied based on a block shape.
- Table 3 illustrates transform skip modes applicable in inter prediction.
- transform block after a transform block is transformed, another transform may be applied to a low-frequency domain, which is referred to, for convenience, as second transform.
- DST may be applied to a low frequency domain by each 4 ⁇ 4 block to enhance efficiency.
- the applied DST as second transform may be 2D DST, horizontal DST, or vertical DST according to the intra prediction modes illustrated in FIG. 3 .
- Table 4 illustrates DST types applicable according to the intra prediction modes.
- Table 4 illustrates that whether to perform horizontal DST or vertical DST is determined based on an intra prediction mode
- both vertical DST and horizontal DST may be applied by 4 ⁇ 4 blocks regardless of intra prediction modes.
- the second transform may be performed based on an applied transform skip mode.
- DST in the second transform may be performed as the same transform method as in a transform skip mode.
- a transform direction may be considered.
- 2D transform mode TS0 when the 2D transform mode TS0 is applied as a transform skip mode, 2D DST may be employed as second transform.
- horizontal transform TS1 when applied as a transform skip mode, horizontal DST may be employed as second transform.
- vertical transform TS2 When vertical transform TS2 is applied as a transform skip mode, vertical DST may be employed as second transform.
- TS3 is applied, that is, when neither horizontal transform nor vertical transform is applied, second transform may not be applied.
- Table 5 illustrates a second transform type (mode) according to a TSM.
- second transform in intra prediction has been illustrated, the present invention is not limited thereto but second transform may be applied in the same manner in inter prediction.
- the second transform may be also applied based on a transform skip mode applied to a corresponding block.
- 2D transform mode TS0 is applied as a transform skip mode
- 2D DST may be employed as second transform.
- horizontal transform TS1 is applied as a transform skip mode
- horizontal DST may be employed as second transform.
- vertical transform TS2 is applied as a transform skip mode
- vertical DST may be employed as second transform.
- TS3 is applied, that is, when neither horizontal transform nor vertical transform is applied, second transform may not be applied.
- FIG. 5 is a flowchart schematically illustrating an encoding process adopting a transform skip mode and second transform according to the present invention.
- the encoding apparatus may partition an input picture (S 510 ).
- the input picture may be partitioned into blocks, such as CUs, PUs and TUs.
- the encoding apparatus may perform prediction for a processing target block that is a current block (S 520 ).
- the encoding apparatus may perform inter prediction or intra prediction for the current block to generate a predicted block and generate a residual block based on the predicted block.
- the encoding apparatus may encode prediction information (S 530 ).
- the encoding apparatus may encode motion information when inter prediction is applied and encode information indicating an intra prediction mode when intra prediction is applied.
- the encoding apparatus may transform a residual signal and encode the transformed residual signal (S 540 ).
- the encoding apparatus may apply a transform skip mode to the residual signal and perform second transform based on the transform skip mode.
- the encoding apparatus may determine information to transmit (S 550 ).
- the encoding apparatus may determine through rate-distortion optimization (RDO) which to transmit among the residual block and transform coefficients.
- RDO rate-distortion optimization
- the encoding apparatus may scan the transform coefficients (S 560 ).
- the transform coefficients are rearranged by scanning.
- the encoding apparatus may entropy-encode the scanned transform coefficients (S 570 ).
- the encoding apparatus may transmit the entropy-encoded transform coefficients as a bitstream.
- the encoding apparatus may partition the input picture (S 510 ).
- the input picture is partitioned for encoding.
- a current picture or frame may be partitioned into coding units (CUs).
- CUs coding units
- One inter coding unit CU may include a plurality of inter prediction units PUs and have a plurality of prediction modes PreMode.
- the plurality of prediction modes may include a skip mode MODE_SKIP and an inter mode MODE_INTER.
- prediction may be performed for a block having a partition mode Part Mode of PART — 2N ⁇ 2N, without partitioning into smaller Prediction units PUs.
- prediction is performed using motion information on a neighboring block as motion information allocated to a PART — 2N ⁇ 2N prediction unit PU, and a residual signal is not transmitted.
- a coding unit may include four types of prediction unit partitions, for example, PART — 2N ⁇ 2N, PART — 2N ⁇ N, PART_N ⁇ 2N and PART_N ⁇ N.
- the encoding apparatus may signal that the prediction mode PreMode is the inter mode MODE_INTER and information Part Mode indicating which is a partition type among the four types to the decoding apparatus.
- prediction may be performed for a prediction unit to be currently encoded (current block).
- the encoding apparatus may perform prediction for the prediction target block that is the current block (S 520 ).
- the encoding apparatus may perform motion prediction for the current block using previous pictures. Or When inter prediction is performed for the current block or current prediction unit, the encoding apparatus may perform motion prediction for the current block using frames; or previous and subsequent pictures; or frames. Motion information including a motion vector and a reference picture list, etc. may be obtained through motion prediction.
- intra prediction is performed for the current block, the encoding apparatus may perform intra prediction for the current block using samples neighboring to the current block and derive an intra prediction mode.
- Information on the current prediction unit is not transmitted as it is but a differential value from a predicted value obtained from neighboring blocks may be transmitted so as to improve compression efficiency.
- prediction is performed using motion information on neighboring block as the motion information on the current block but the differential value is not transmitted.
- prediction is perform using motion information on neighboring block and a differential value (residual signal) is transmitted.
- FIG. 6 schematically illustrates information on a neighboring block available in the skip mode, the merge mode, and the AMVP mode.
- the encoding apparatus may construct a merging candidate list and an AMVP candidate list.
- the candidate lists may be constructed based on spatial candidate blocks A0, A1, B0, B1 and B2 neighboring to the current block 600 and a corresponding block in a collocated picture 610 as a temporal candidate block.
- the temporal candidate block may be any one of C0, C3, BR and H.
- candidates A (A0 ⁇ A1), B (B0 ⁇ B1 ⁇ B2) and the temporal candidate block may be considered in order.
- candidates may be considered with the same order as for the merging candidate list or the candidates may be considered in order of the temporal candidate block, A (A0 ⁇ A1) and B (B0 ⁇ B1 ⁇ B2).
- the encoding apparatus may perform prediction for the current block using motion information on the candidate blocks.
- Merge_flag merge flag
- the encoding apparatus derives AMVP candidates from motion information on blocks temporally and spatially neighboring the current block (for example, a PU).
- the encoding apparatus derives spatial motion vector predictor (MVP) candidates from the neighboring blocks (for example, Pus) to the current block.
- the neighboring blocks shown in FIG. 6 may be used to derive the spatial motion vector candidates.
- the encoding apparatus derives a temporal motion vector candidate of a collocated block using a reference picture index (RefIdxLX) obtained in a motion estimation process.
- the encoding apparatus makes an MVP list (mvpListLX).
- motion vectors may have priories in order of ⁇ circle around (1) ⁇ a motion vector of a temporal collocated block (mvLXCol), for example, the collocated block may be one of the corresponding blocks C0, C3, BR and H of FIG. 6 , ⁇ circle around (2) ⁇ motion vectors of neighboring blocks in the left side of the current block (mvLXA) and ⁇ circle around (3) ⁇ motion vectors of neighboring blocks in the upper side of the current block (mvLXB), among available motion vectors.
- the available blocks such as the collocated block, the neighboring blocks in the left side of the current block and the neighboring blocks in the upper side of the current block, are illustrated above in FIG. 6 .
- the encoding apparatus When a plurality of motion vectors has the same value, the encoding apparatus removes motion vectors other than a motion vector having a highest priority among the motion vectors having the same value from the MVP list. (v) The encoding apparatus set an optimal MVP among the motion vector candidates on the MVP list (mvListLX) as an MVP for the current block.
- the optimal MVP is a MVP of a candidate block minimizing a cost function.
- the encoding apparatus performs prediction using samples neighboring to the current block.
- the encoding apparatus may determine an optimal intra prediction mode using RDO.
- the encoding apparatus may generate a predicted block for the current block using a pixel value derived based on an average pixel value of neighboring samples or pixels values of neighboring samples regardless of neighboring samples' direction.
- the encoding apparatus may generate a predicted block for the current block using sample in direction indicated by an intra prediction mode for the current block.
- the encoding apparatus may encode the prediction information (S 530 ).
- the encoding apparatus In the merge mode, when a candidate having the same motion information as the current block (for example, a PU) among merging candidates, the encoding apparatus indicates that the current block is in the merge mode and transmits a merge flag indicating that the merge mode is used and a merge index (Merge_Idx) indicating which candidate is selected among the merging candidates.
- the encoding apparatus obtains a differential signal (residual signal) between the current block and a block predicted by the merge mode after motion compensation. When there is no residual signal to transmit, the encoding apparatus may transmit information indicating that a merge skip mode is applied.
- the encoding apparatus determines a candidate minimizing a cost function among AMVP candidates by comparing motion vector information of the AMVP candidates and motion vector information of the block to be currently encoded.
- the encoding apparatus obtain a differential value in motion information between the current block and the candidate minimizing the cost function, and a residual signal by motion compensation using the AMVP candidate.
- the encoding apparatus entropy-encodes a motion vector difference between a motion vector of the current block (for example, prediction unit) and the motion vector of the candidate (optimal predictor) minimizing the cost function.
- the encoding apparatus When intra prediction is applied, the encoding apparatus derives a residual signal as a difference between the current block and the predicted block generated using the intra prediction mode.
- the encoding apparatus may entropy-encode the residual signal.
- the encoding apparatus may also encode information indicating that the intra prediction mode is applied.
- the encoding apparatus may transform and encode the residual signal generated through prediction (S 540 ).
- the encoding apparatus may derive the residual signal by obtaining a difference between a pixel value of the current block and a pixel value of the predicted block with a pixel as a unit.
- the encoding apparatus may transform and encode the generated residual signal.
- available transforming and encoding kernels may be 2 ⁇ 2, 4 ⁇ 4, 8 ⁇ 8, 16 ⁇ 16, 32 ⁇ 32 and 64 ⁇ 64 block, among which a predetermined encoding kernel may be determined in advance as a kernel to be used for transform.
- the encoding apparatus may determine a transform skip mode based on a direction of an intra prediction mode.
- a transform skip mode is determined according to a direction of an intra prediction mode
- the encoding apparatus may determine a transform skip mode based on RDO and may signal information on the determined transform skip mode.
- number of transform skip mode candidates may be determined differently according to directions of intra prediction modes.
- information indicating transform skip modes may be encoded with different codewords based on directions of intra prediction modes.
- the encoding apparatus may determine a transform skip mode based on a shape of the current block (for example, prediction unit).
- a transform skip mode is determined based on a shape of the current block
- the encoding apparatus may determine a transform skip mode based on RDO and may signal information on the determined transform skip mode.
- number of transform skip mode candidates may be determined differently based on shapes of the current block.
- information indicating transform skip mode s may be encoded with different codewords based on shapes of the current block.
- the encoding apparatus may perform 2D transform, 1D transform (transform on columns and transform on rows) or transform bypassing according to a transform skip mode.
- the same transform skip mode as for a luma component may be applied to a chroma component.
- the encoding apparatus may perform second transform based on the applied transform skip mode.
- a second transform may be performed by applying DST to each 4 ⁇ 4 block.
- the encoding apparatus determines a type of the second transform based on the transform skip mode and applies the determined type of second transform to a low-frequency domain. For example, the encoding apparatus may perform DST on a low-frequency domain with a 4 ⁇ 4 block size.
- 2D DST is applied as second transform when the 2D transform mode TS0 is applied as a transform skip mode; horizontal DST is employed as second transform when horizontal transform TS1 is applied as a transform skip mode; vertical DST is applied as second transform when vertical transform TS2 is applied as transform skip mode; and second transform may not be applied when TS3 is applied, that is, when neither horizontal transform nor vertical transform is applied.
- a transform coefficient C for an n ⁇ n block may be determined by Equation 2.
- Equation 2 T is a transform matrix, and B is a residual block.
- the encoding apparatus quantizes transform coefficients.
- the encoding apparatus may determine the information to transmit (S 550 ).
- the encoding apparatus may determine which to transmit among the residual signal and transform coefficients through rate-distortion optimization (RDO). If the residual signal is small as prediction is properly done, the encoding apparatus may transmit the residual signal as it is. Alternatively, the encoding apparatus may transmit information which minimizes cost by comparing costs before and after transform and encoding.
- the encoding apparatus may signal a type of the determined information, that is, whether the determined information is the residual signal or transform coefficients.
- the encoding apparatus may scan the transform coefficients (S 560 ).
- the transform coefficients are rearranged by scanning.
- the encoding apparatus may entropy-encode the scanned transform coefficients (S 570 ).
- the encoding apparatus may transmit the entropy-encoded transform coefficients as a bitstream.
- FIG. 7 is a flowchart schematically illustrating a decoding process adopting a transform skip mode and second transform according to the present invention.
- the decoding apparatus entropy-decodes a bitstream received from the encoding apparatus (S 710 ).
- the decoding apparatus may perform entropy decoding using a corresponding method to entropy encoding used by the encoding apparatus.
- the decoding apparatus may inverse-transform the entropy decoded information (S 720 ).
- the decoding apparatus may scan inversely the entropy decoded information to generate a two-dimensional block.
- the decoding apparatus performs prediction for a current block (for example, a PU) (S 730 ).
- the decoding apparatus may generate a predicted block for the current block according to a prediction method used for the encoding apparatus.
- the decoding apparatus may generate a reconstructed signal for the current block (S 740 ).
- the decoding apparatus may add the predicted block and a residual block to reconstruct the current block.
- the decoding apparatus entropy-decodes the bitstream received from the encoding apparatus (S 710 ).
- the decoding apparatus may obtain, from the received bitstream, a block type of the current block and information on a prediction mode for the current block. For example, when variable length coding (VLC) is applied to the current block in entropy encoding, the block type may be obtained from a VLC table.
- VLC variable length coding
- the decoding apparatus may find out through an information type whether the transmitted information on the current block is a residual signals or transform coefficients.
- the decoding apparatus may obtain information on the residual signal or transform coefficient of the current block.
- the decoding apparatus may inverse-transform the entropy decoded information (S 720 ).
- the decoding apparatus may scan inversely the entropy decoded residual signal or transform coefficient to generate a two-dimensional block.
- the decoding apparatus may derive a transform skip mode based on an intra prediction mode and perform inverse transform according to the derived transform skip mode.
- a transform skip mode is determined regardless of an intra prediction mode (for example, determined based on RDO)
- the decoding apparatus may decode information, received from the encoding apparatus, indicating a transform skip mode and perform inverse transform process according to the transform skip mode.
- the decoding apparatus may derive a transform skip mode based on a shape of the current block (for example, prediction unit) and perform inverse transform according to the derived transform skip mode.
- a transform skip mode is determined regardless of a shape of the current block (for example, determined based on RDO)
- the decoding apparatus may decode information, received from the encoding apparatus, indicating a transform skip mode and perform inverse transform according to the received from the encoding apparatus.
- the same information as used for a luma component may be reused to determine transform skip mode for a chroma component.
- the decoding apparatus may perform second inverse transform based on the transform skip mode applied to the current block.
- Second inverse transform may be performed by applying inverse DST to each 4 ⁇ 4 block.
- the decoding apparatus determines a type of second inverse transform method based on the transform skip mode and applies the determined type of second inverse transform to a low-frequency domain. For example, the decoding apparatus may perform inverse DST on a low-frequency domain with a 4 ⁇ 4 block size.
- inverse 2D DST is applied as second inverse transform when inverse 2D transform TS0 is applied as a transform skip mode; inverse horizontal DST is applied as second inverse transform when inverse horizontal transform TS1 is applied as transform skip mode; inverse vertical DST is applied as second inverse transform when inverse vertical transform TS2 is applied as transform skip mode; and second inverse transform may not be applied when TS3 is applied as transform skip mode, that is, when neither inverse horizontal transform nor inverse vertical transform is applied.
- the decoding apparatus may generate a residual block based on the residual signal.
- the decoding apparatus may generate a transform coefficient block based on the transform coefficient.
- the decoding apparatus may dequantize and inverse-transform the transform coefficient block to derive the residual block.
- Equation 3 illustrates an example of inverse transform applied to the current transform coefficient block.
- Equation 3 each factor is the same as described above in Equation 2.
- the decoding apparatus performs prediction for the current block (for example, prediction unit) (S 730 ).
- the decoding apparatus may obtain a motion vector (mvLX) and a reference picture index through the merge mode when a merge flag has a value of 1.
- the decoding apparatus may derive merging candidates from blocks (for example, prediction units) neighboring to the current block (for example, prediction unit). Further, the decoding apparatus may derive the reference picture index (refIdxLX) so as to obtain a temporal merging candidate.
- the merging candidates have been illustrated in FIG. 6 .
- the decoding apparatus derives an available temporal motion vector predictor (MVP) value using the derived reference picture index.
- MVP temporal motion vector predictor
- the decoding apparatus may set a merge index (Merge_Idx) equal to 1. Otherwise, the decoding apparatus may set the merge index equal to an index value received from the encoding apparatus.
- the decoding apparatus may derive a motion vector (mvLX) of a merging candidate indicated by the merge index and the reference picture index (refIdxLX), and perform motion compensation using the derived motion vector and reference picture index.
- mvLX motion vector of a merging candidate indicated by the merge index and the reference picture index (refIdxLX)
- the decoding apparatus may derive a reference picture index (refIdxLX) of the current block (for example, prediction unit).
- the decoding apparatus may derive a motion vector predictor (MVP) value using the reference picture index.
- MVP motion vector predictor
- the decoding apparatus may derive spatial motion vector (MVP) candidates from the blocks (for example, prediction units) neighboring to the current block.
- the decoding apparatus may also derive a temporal motion vector predictor (MVP) of a collocated block indicated by the reference picture index.
- the decoding apparatus may construct an MVP list (mvpListLX).
- MVP list mvpListLX
- motion vectors may have priories in order of ⁇ circle around (1) ⁇ a motion vector of a temporal collocated block (mvLXCol), for example, the temporal collocated block may be one of the corresponding blocks C0, C3, BR and H of FIG.
- the decoding apparatus may remove motion vectors other than a motion vector having a highest priority among the motion vectors having the same value from the MVP list.
- the decoding apparatus may set mvpIdx equal to 1.
- the decoding apparatus may set mvpIdx equal to an index value received from the encoding apparatus.
- the decoding apparatus allocates a motion vector indicated by mvpIdx among the MVP candidates on mvpListLX as the motion vector predictor value mvpLX.
- the decoding apparatus may derive a motion vector for the current block using Equation 4.
- Equation 4 mvLX[0] is an x component of the motion vector for the current block, mvdLX[0] is an x component of a motion vector differential value for the current block, and mvpLX[0] is an x component of the motion vector predictor value for the current block.
- mvLX[1] is a y component of the motion vector for the current block, mvdLX[1] is a y component of the motion vector differential value for the current block, and mvpLX[1] is a y component of the motion vector predictor value for the current block.
- the decoding apparatus may generate a predicted block for the current block based on neighboring samples using an intra prediction mode for the current block.
- the decoding apparatus may generate the reconstructed signal for the current block (S 740 ).
- the decoding apparatus may generate the predicted block using the derived motion vector and add the predicted block and the residual block to reconstruct the current block.
- intra prediction the decoding apparatus also may add the predicted block and the residual block to reconstruct the current block as described.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- Discrete Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
Abstract
Description
- The present application is a Divisional of pending U.S. patent application Ser. No. 14/352,837 (filed on Apr. 18, 2014), which is a National Stage Patent Application of PCT International Patent Application No. PCT/KR2012/008563 (filed on Oct. 18, 2012) under 35 U.S.C. §371, which claims priority to Korean Patent Application No. 10-2011-0106624 (filed on Oct. 18, 2011), the teachings of which are incorporated herein in their entireties by reference.
- The present invention relates to video encoding and decoding, and more particularly, to a method and an apparatus for transforming a signal in video encoding and decoding.
- Recently, demands for high-resolution and high-quality videos, such as high-definition (HD) and ultrahigh-definition (UHD) videos, have increased in various fields of applications.
- As video data has higher resolution and higher quality, the amount of data more increases relative to existing video data. Accordingly, when video data is transferred using media such as existing wired and wireless broad band lines or is stored in existing storage media, transfer cost and storage cost increase.
- In order to solve these problems occurring with an increase in resolution and quality of video data, high-efficiency video compression techniques may be utilized.
- Video compression technology include various techniques, such as an inter prediction technique of predicting pixel values included in a current picture from previous or subsequent pictures of the current picture, an intra prediction technique of predicting pixel values included in a current picture using pixel information in the current picture, a technique of transforming pixel information into a frequency domain by a predetermined unit and quantizing a transform coefficient, and an entropy encoding technique of assigning a short code to a value with a high appearance frequency and assigning a long code to a value with a low appearance frequency.
- Video data may be effectively compressed and transferred or stored using such video compression techniques.
- An aspect of the present invention is to provide a method and an apparatus for efficiently transforming video information.
- Another aspect of the present invention is to provide a method and an apparatus for performing first transform according to a prediction method and performing second transform on a low-frequency domain according to the first transform to improve efficiency in compression.
- Still another aspect of the present invention is to provide a method and an apparatus for performing first transform according to a shape of a partition and performing second transform on a low-frequency domain according to the first transform to improve efficiency in compression.
- An embodiment of the present invention provides a video encoding method including performing prediction for a current block, and transforming a residual generated by the prediction, wherein, in the transforming step, second transform is performed on a low-frequency domain after performing first transform on the residual, and determines a mode of the second transform based on a mode of the first transform.
- In the performing step, intra prediction may be performed for the current block, and the mode of the first transform may be determined as one of 2-directional (2D) transform, 1-directional (1D) vertical transform, 1D horizontal transform and non-transform based on a direction of a prediction mode of the intra prediction. Here, the mode of the second transform may be the same as the mode of the first transform.
- In the performing step, inter prediction may be performed for the current block, and the mode of the first transform may be determined as one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform based on a shape of the current block. Here, the mode of the second transform may be the same as the mode of the first transform.
- In the transforming step, the mode of the first transform may be determined based on rate-distortion optimization. Here, information indicating the determined mode of the first transform may be transmitted.
- The second transform may be discrete sine transform (DST) by a 4×4 block.
- Another embodiment of the present invention provides a video decoding method including performing inverse transform to generate a residual block for a current block, and performing prediction to generate a predicted block for the current block, wherein, in the performing inverse transform, second inverse transform on a low-frequency domain may be performed after performing first inverse transform on encoded residual information for the current block, and a mode of the second transform may be determined based on a mode of the first transform.
- In the performing prediction, intra prediction may be performed for the current block, and the mode of the first inverse transform may be determined as one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform based on a direction of a prediction mode of the intra prediction. Here, the mode of the second inverse transform may be the same as the mode of the first inverse transform.
- In the performing prediction, inter prediction may be performed for the current block, and the mode of the inverse first transform is determined as one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform based on a shape of the current block. Here, the mode of the second inverse transform may be the same as the mode of the first inverse transform.
- In the performing the inverse transform, the first inverse transform may be performed according to a mode indicated by received information, and the received information indicates one of 2D transform, 1D vertical transform, 1D horizontal transform and non-transform as the mode of the first inverse transform. Here, the mode of the second inverse transform may be the same as the mode of the first inverse transform.
- The second transform may be DST by a 4×4 block.
- Still another embodiment of the present invention provides a video encoding apparatus including a prediction module to perform prediction for a current block, and a transform module to transform a residual generated by the prediction, wherein the transform module performs second transform on a low-frequency domain after performing first transform on the residual and determines a mode of the second transform based on a mode of the first transform.
- Yet another embodiment of the present invention provides a video decoding method including an inverse transform module to generate a residual block for a current block by performing inverse transform, and a prediction module to generate a predicted block for the current block, wherein the inverse transform module performs second inverse transform on a low-frequency domain after performing first inverse transform on encoded residual information for the current block, and determines a mode of the second transform based on a mode of the first transform.
- According to the present invention, residual information may be efficiently transformed and inverse-transformed.
- According to the present invention, first transform may be performed according to a prediction method and second transform may be performed on a low-frequency domain according to the first transform, thereby improving efficiency in compression and transmission.
- According to the present invention, first transform may be performed according to a partitioned shape and second transform may be performed on a low-frequency domain according to the first transform, thereby improving efficiency in compression and transmission.
-
FIG. 1 is a block diagram illustrating a video encoding apparatus according to an exemplary embodiment of the present invention. -
FIG. 2 is a block diagram illustrating a video decoding apparatus according to an exemplary embodiment of the present invention. -
FIG. 3 schematically illustrates a prediction mode used for intra prediction. -
FIG. 4 schematically illustrates a transform skip mode (TMS). -
FIG. 5 is a flowchart schematically illustrating an encoding process adopting a transform skip mode and second transform according to the present invention. -
FIG. 6 schematically illustrates information on a neighboring block available in a skip mode, a merge mode, and an AMVP mode. -
FIG. 7 is a flowchart schematically illustrating a decoding process adopting a transform skip mode and second transform according to the present invention. - The present invention may be changed and modified variously and be illustrated with reference to different exemplary embodiments, some of which will be described and shown in the drawings. However, these embodiments are not intended for limiting the invention but are construed as including includes all modifications, equivalents and replacements which belong to the spirit and technical scope of the invention. Like reference numerals in the drawings refer to like elements throughout.
- Although the terms first, second, etc. may be used to describe various elements, these elements should not be limited by these terms. These terms are used only to distinguish one element from another element. For example, a first element could be termed a second element and a second element could be termed a first element likewise without departing from the teachings of the present invention. The term “and/or” includes any and all combinations of a plurality of associated listed items.
- It will be understood that when an element is referred to as being “connected to” or “coupled to” another element, the element can be directly connected or coupled to another element or intervening elements. On the contrary, when an element is referred to as being “directly connected to” or “directly coupled to” another element, there are no intervening elements present.
- The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a,” “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “include” and/or “have,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
- Hereinafter, exemplary embodiments of the invention will be described in detail with reference to the accompanying drawings. Like reference numerals in the drawings refer to like elements throughout, and redundant descriptions of like elements will be omitted herein.
-
FIG. 1 is a block diagram illustrating a video encoding apparatus according to an exemplary embodiment of the present invention. - Referring to
FIG. 1 , the video encoding apparatus 100 includes apicture partitioning module 105, a prediction module 110, atransform module 115, aquantization module 120, arearrangement module 125, anentropy encoding module 130, adequantization module 135, aninverse transform module 140, afilter module 145 and amemory 150. - Although elements illustrated in
FIG. 1 are independently shown so as to represent different distinctive functions in the video encoding apparatus, such a configuration does not indicate that each element is constructed by a separate hardware constituent or software constituent. That is, the elements are independently arranged for convenience of description, wherein at least two elements may be combined into a single element, or a single element may be divided into a plurality of elements to perform functions. It is to be noted that embodiments in which some elements are integrated into one combined element and/or an element is divided into multiple separate elements are included in the scope of the present invention without departing from the essence of the present invention. - Some elements may not be essential to the substantial functions in the invention and may be optional constituents for merely improving performance. The invention may be embodied by including only constituents essential to embodiment of the invention, except for constituents used to merely improve performance. The structure including only the essential constituents except for the optical constituents used to merely improve performance belongs to the scope of the invention.
- The
picture partitioning module 105 may partition an input picture into at least one process unit. Here, the process unit may be a prediction unit (PU), a transform unit (TU) or a coding unit (CU). Thepicture partitioning module 105 may partition one picture into a plurality of combinations of coding units, prediction units and transform units and select one combination of coding units, prediction units and transform units on the basis of a predetermined criterion (for example, a cost function), thereby encoding the picture. - For example, one picture may be partitioned into a plurality of coding units. A recursive tree structure such as a quad tree structure may be used to partition a picture into coding units. Being a picture or a coding unit of a maximum size as root, a coding unit may be partitioned into sub-coding units with as many child nodes as the partitioned coding units. A coding unit which is not partitioned any more in accordance with a predetermined constraint is to be a leaf node. That is, assuming that a coding unit may be partitioned into quadrates only, a single coding unit may be partitioned into at most four different coding units.
- In the embodiments of the invention, a coding unit may be used to refer to not only a unit of encoding but also a unit of decoding.
- A prediction unit may be partitioned into at least one square or rectangular form with the same size in a coding unit or be partitioned such that a shape of partitioned prediction unit is different from a shape of other prediction unit in a coding unit.
- When a prediction unit to be subjected to intra prediction is generated based on a coding unit and the coding unit is not a minimum coding unit, intra prediction may be performed without partitioning the coding unit into plural prediction units (N×N).
- The prediction module 110 may include an inter prediction module to perform inter prediction and an intra prediction module to perform intra prediction. The prediction module may determine which of inter prediction or intra prediction should be performed on a prediction unit, and may determine specific information (for example, intra prediction mode, motion vector, and reference picture, etc) according to the determined prediction method. Here, a process unit on which prediction is performed may be different from a process unit for which a prediction method and specific information are determined. For example, a prediction method and a prediction mode may be determined for each prediction unit, while prediction may be performed for each transform unit. A residual value (residual block) between a generated predicted block and an original block may be input to the
transform module 115. Further, prediction mode information, motion vector information and the like used for prediction may be encoded along with the residual value by theentropy encoding module 130 and be transmitted to the decoding apparatus. When a specific encoding mode is used, the original block may be encoded and transmitted to the decoding apparatus without generating a predicted block through the prediction module 110. - The inter prediction module may predict for a prediction unit on the basis of information on at least one picture among a previous picture and a subsequent picture of a current picture. The inter prediction module may include a reference picture interpolation module, a motion prediction module, and a motion compensation module.
- The reference picture interpolation module may be supplied with reference picture information from the
memory 150 and generate pixel information less than an integer pixel position unit (an integer pixel unit or a pixel unit) from a reference picture. In the case of luma pixels, a DCT-based 8-tap interpolation filter having a varying filter coefficient may be used to generate pixel information less than an integer pixel unit in a unit of ¼ pixel position (a unit of ¼ pixel). In the case of chroma pixels, a DCT-based 4-tap interpolation filter having a varying filter coefficient may be used to generate pixel information less than an integer pixel unit in a unit of ⅛ pixel. - The motion prediction module may perform motion prediction on the basis of the reference picture interpolated by the reference picture interpolation module. Various methods, such as a full search-based block matching algorithm (FBMA), a three-step search (TSS) algorithm and a new three-step search (NTS) algorithm, may be used to calculate a motion vector. A motion vector has a motion vector value in a unit of ½ or ¼ pixel on the basis of an interpolated pixel. The motion prediction module may perform a prediction on a current prediction unit using different motion prediction methods. Various methods, such as skipping, merging, and advanced motion vector prediction (AMVP) etc, may be used as the motion prediction method.
- The intra prediction module may generate a prediction block based on information of reference pixel neighboring to a current block which is pixel information in a current picture. When a block neighboring to a current prediction unit is a block having been subjected to inter prediction and a reference pixel is a pixel having been subjected to inter prediction, reference pixel information included in the block having been subjected to inter prediction may be substituted with a reference pixel information in a block having been subjected to intra prediction. That is, when a reference pixel is not available, information on the unavailable reference pixel may be substituted with at least one reference pixel of the available reference pixels.
- A prediction mode of intra prediction includes a directional prediction mode in which information on a reference pixel is used according to a prediction direction and a non-directional prediction mode in which direction information is not used in performing prediction. A mode for predicting luma information and a mode for predicting chroma information may be different from each other. Intra prediction mode information used to obtain luma information or predicted luma signal information may be used to predict chroma information.
- When a prediction unit and a transform unit have the same size in performing intra prediction, intra prediction on the prediction unit may be performed based on left pixels, an upper-left pixel and upper pixels of the prediction unit. On the other hand, when a prediction unit and a transform unit have different sizes in performing intra prediction, intra prediction may be performed using reference pixels based on the transform unit. Intra prediction with N×N partitioning may be performed only for a minimum coding unit.
- In the intra prediction method, an adaptive intra smoothing (AIS) filter may be applied to reference pixels according to the prediction mode prior to generation of a predicted block. Different types of AIS filters may be applied to the reference pixels. In the intra prediction method, the intra prediction mode of a current prediction unit may be predicted from an intra prediction mode of a prediction unit located neighboring to the current prediction unit. In predicting for the prediction mode of the current prediction unit using mode information predicted from a neighboring prediction unit, when the current prediction unit and the neighboring prediction unit have the same intra prediction mode, information indicating that the current prediction unit and the neighboring prediction unit have the same prediction mode may be transmitted using predetermined flag information. If the current prediction unit and the neighboring prediction unit have different prediction modes, information on the prediction mode of the current block may be encoded by entropy encoding.
- A residual block including residual information which is on a difference between the predicted block and the original block of the prediction unit may be generated based on the prediction unit by the prediction module 110. The generated residual block may be input to the
transform module 115. - The
transform module 115 may transform the residual block including the residual information of the prediction unit generated based on the original block by the prediction module 110 using a transform method such as Discrete Cosine Transform (DCT) or Discrete Sine Transform (DST). A transform method to be used to transform the residual block may be determined among DCT and DST on the basis of the intra prediction mode information of the prediction unit used to generate the residual block. - The
quantization module 120 may quantize values transformed into a frequency domain by thetransform module 115. A quantization parameter may change depending on a block or importance of a picture. Values output from thequantization module 120 may be provided to thedequantization module 135 and therearrangement module 125. - For the quantized residual values, the
rearrangement module 125 may rearrange coefficients. - The
rearrangement module 125 may change a two-dimensional (2D) block of coefficients into a one-dimensional (1D) vector of coefficients through coefficient scanning. For example, therearrangement module 125 may change a 2D block of coefficients into a 1D vector of coefficients using upright scanning. Vertical scanning of a 2D block of coefficients in a column direction and horizontal scanning of a 2D block of coefficients in a row direction may be used depending on a size of a transform unit and an intra prediction mode, instead of upright scanning. That is, a scanning method for use may be selected based on the size of the transform unit and the intra prediction mode among upright scanning, vertical scanning, and horizontal scanning. - The
entropy encoding module 130 may perform entropy encoding on the basis of the values obtained by therearrangement module 125. Various encoding methods, such as exponential Golomb coding, context-adaptive variable length coding (CAVLC), and context-adaptive binary arithmetic coding (CABAC), may be used for entropy encoding. - The
entropy encoding module 130 may encode a variety of information, such as residual coefficient information and block type information on a coding unit, prediction mode information, partitioning unit information, prediction unit information, transfer unit information, motion vector information, reference frame information, block interpolation information and filtering information which may be obtained from therearrangement module 125 and the prediction module 110. - The
entropy encoding module 130 may entropy-encode coefficients of a coding unit input from therearrangement module 125. - The
dequantization module 135 and theinverse transform module 140 dequantize the values quantized by thequantization module 120 and inversely transform the values transformed by thetransform module 115. The residual generated by thedequantization module 135 and theinverse transform module 140 may be added to the predicted block, which is predicted by the motion vector prediction module, the motion compensation module, and the intra prediction module of the prediction module 110, thereby generating a reconstructed block. - The
filter module 145 may include at least one of a deblocking filter, an offset correction module, and an adaptive loop filter (ALF). - The
deblocking filter 145 may remove block distortion generated at boundaries between blocks in a reconstructed picture. Whether to apply the deblocking filter to a current block may be determined on the basis of pixels included in several rows or columns of the block. When the deblocking filter is applied to a block, a strong filter or a weak filter may be applied depending on a required deblocking filtering strength. In addition, when horizontal filtering and vertical filtering are performed in applying the deblocking filter, the horizontal filtering and vertical filtering may be performed in parallel. - The offset correction module may correct an offset of the deblocking filtered picture from the original picture by a pixel. A method of partitioning pixels of a picture into a predetermined number of regions, determining a region to be subjected to offset correction, and applying offset correction to the determined region or a method of applying offset correction in consideration of edge information on each pixel may be used to perform offset correction on a specific picture.
- The ALF may perform filtering based on a comparison result of the filtered reconstructed picture and the original picture. Pixels included in a picture may be partitioned into predetermined groups, a filter to be applied to each group may be determined, and differential filtering may be performed for each group. Information on whether to apply the ALF may be transferred by each coding unit (CU) and a shape and coefficient of an ALF to be applied to each block may vary. The ALF may have various types and a number of coefficients included in a corresponding filter may vary. Further, an ALF filter with the same form (fixed form) may be applied to a block regardless of characteristics of the block.
- The
memory 150 may store a reconstructed block or picture output from thefilter module 145, and the stored reconstructed block or picture may be provided to the prediction module 110 when performing inter prediction. -
FIG. 2 is a block diagram illustrating a video decoding apparatus according an exemplary embodiment of the present invention. - Referring to
FIG. 2 , the video decoding apparatus 200 may include anentropy decoding module 210, arearrangement module 215, adequantization module 220, aninverse transform module 225, a prediction module 230, afilter module 235, and amemory 240. - When a video bitstream is input from the video encoding apparatus, the input bitstream may be decoded according to an inverse process of the video encoding process by the video encoding apparatus.
- The
entropy decoding module 210 may perform entropy decoding according to an inverse process of the entropy encoding process by the entropy encoding module of the video encoding apparatus. For example, various methods, such as exponential Golomb coding, CAVLC and CABAC, may be used for entropy decoding, corresponding to the method used by the video encoding apparatus. - The
entropy decoding module 210 may decode information associated with intra prediction and inter prediction performed by the encoding apparatus. - The
rearrangement module 215 may perform rearrangement on the bitstream entropy-decoded by theentropy decoding module 210 on the basis of the rearrangement method of the encoding module. Therearrangement module 215 may reconstruct and rearrange coefficients expressed in a 1D vector form into coefficients in a 2D block. Therearrangement module 215 may be provided with information associated with coefficient scanning performed by the encoding module and may perform rearrangement using a method of inversely scanning the coefficients on the basis of scanning order by which scanning is performed by the encoding module. - The
dequantization module 220 may perform dequantization on the basis of a quantization parameter provided from the encoding apparatus and the rearranged coefficients of the block. - The
inverse transform module 225 may perform inverse DCT and inverse DST with respect to DCT and DST performed by the transform module, where the DCT and DST have been performed on the result of quantization by the video encoding apparatus. Inverse transform may be performed on the basis of a transform unit determined by the video encoding apparatus. The transform module of the video encoding apparatus may selectively perform DCT and DST depending on a plurality of information elements, such as a prediction method, a size of the current block and a prediction direction, etc, and theinverse transform module 225 of the video decoding apparatus may perform inverse transform on the basis of information on the transform performed by the transform module of the video encoding apparatus. - The prediction module 230 may generate a predicted block on the basis of predicted block generation information provided from the
entropy decoding module 210 and information on a previously-decoded block or picture provided from thememory 240. - Similarly to the operation of the video encoding apparatus as described above, when a prediction unit and a transform unit have the same size in performing intra prediction, intra prediction on the prediction unit is performed based on left pixels, an upper-left pixel and upper pixels of the prediction unit. On the other hand, when a prediction unit and a transform unit have different sizes in performing intra prediction, intra prediction may be performed using reference pixels based on the transform unit. Intra prediction with N×N partitioning may be performed only for a minimum coding unit.
- The prediction module 230 includes a prediction unit determination module, an inter prediction module and an intra prediction module. The prediction unit determination module may receive a variety of information, such as prediction unit information input from the entropy decoding module, prediction mode information of an intra prediction method and motion prediction-related information on an inter prediction method. And the prediction unit determination module may determine a prediction unit in a current coding unit, and may determine which of the inter prediction and the intra prediction is performed on the prediction unit. The inter prediction module may perform inter prediction on a current prediction unit based on information of at least one picture among a previous picture and a subsequent picture of a current picture including the current prediction unit using information necessary for inter prediction for the current prediction unit provided from the video encoding apparatus.
- In order to perform inter prediction, it may be determined on the basis of a coding unit whether a motion prediction method for a prediction unit included in the coding unit is a skip mode, a merge mode or an AMVP mode.
- The intra prediction module may generate a predicted block on the basis of pixel information in a current picture. When a prediction unit is a prediction unit on which intra prediction is performed, intra prediction may be performed based on intra prediction mode information on the prediction unit provided from the video encoding apparatus. The intra prediction module may include an AIS filter, a reference pixel interpolation module, and a DC filter. The AIS filter performs filtering on reference pixels of a current block, and whether to apply the AIS filter may be determined depending on a prediction mode for the current prediction unit. AIS filtering may be performed on the reference pixels of the current block using the prediction mode for the prediction unit and information on the AIS filter provided from the video encoding apparatus. When the prediction mode for the current block is a mode not involving AIS filtering, the AIS filter may not be applied.
- When the prediction mode for the prediction unit is a prediction mode of performing intra prediction on the basis of pixel values obtained by interpolating the reference pixels, the reference pixel interpolation module may generate reference pixels in a pixel unit of less than an integer position unit by interpolating the reference pixels. When the prediction mode for the current prediction unit is a prediction mode of generating a predicted block without interpolating the reference pixels, the reference pixels may not be interpolated. The DC filter may generate a predicted block through filtering when the prediction mode for the current block is the DC mode.
- The reconstructed block or picture may be provided to the
filter module 235. Thefilter module 235 may include a deblocking filter, an offset correction module, or an ALF. - Information on whether the deblocking filter is applied to a corresponding block or picture and information on which of a strong filter and a weak filter is applied when the deblocking filter is used may be provided from the video encoding apparatus. The deblocking filter of the video decoding apparatus may be provided with information on the deblocking filtering from the video encoding apparatus and may perform deblocking filtering on a corresponding block.
- The offset correction module may perform offset correction on the reconstructed picture based on an offset correction type and offset value information applied to the picture in the encoding process.
- The ALF may be applied to a coding unit on the basis of information on whether the ALF is applied or not, and ALF coefficient information provided from the encoding apparatus. The ALF information may be included and provided in a specific parameter set.
- The
memory 240 may store the reconstructed picture or block for use as a reference picture or a reference block, and may provide the reconstructed picture to an output module. - As described above, in the embodiments of the invention, the term “coding unit” is used as an encoding unit and may be also used as a unit of decoding (decoding unit).
- As illustrated in
FIGS. 1 and 2 , the transform modules of the encoding apparatus and the decoding apparatus may perform block-based transform, such as DST or DCT, on a residual block (transform block). - Here, if the residual block is generated based on a predicted block generated by intra prediction, transform may be determined according to a prediction mode.
-
FIG. 3 schematically illustrates a prediction mode used for intra prediction. Referring toFIG. 3 , intra prediction is carried out using two non-directional prediction modes and 32 directional prediction modes. - The encoding apparatus and the decoding apparatus may perform intra prediction on a current block using a prediction mode selected among the two non-directional prediction modes, a planar mode and a DC mode, and the 32 directional prediction modes corresponding to directions shown in
FIG. 3 . - When a directional intra prediction mode is used, the encoding apparatus and the decoding apparatus may perform prediction on the current block to generate a predicted block based on samples located in a corresponding direction among neighboring samples to the current block.
- Thus, as described above, the encoding apparatus and the decoding apparatus may determine a transform method based on a prediction mode used to generate a predicted block.
- Meanwhile, when a sparse signal is included or when horizontal and vertical signals have different characteristics, vertical transform or horizontal transform may be skipped or both transforms may be skipped for a signal, thereby reducing complexity of processing in the decoding apparatus and improving coding efficiency.
- For the encoding apparatus, a transform skip mode (TSM) is a method for enhancing encoding efficiency by performing all 2-dimensional (2D) transforms, skipping vertical transform or horizontal transform, or skipping both horizontal and vertical transforms.
- Among transform skip modes, TS0 is a mode of performing 2D transform on a transform block. TS1 is a mode of performing transform on rows only in a transform block (transform on rows), and TS2 is a mode of performing transform on columns only in a transform block (transform on columns). TS3 is a mode of performing neither transform on rows (horizontal transform) nor transform on columns (vertical transform).
- For the decoding apparatus, a transform skip mode is a method of performing all 2D inverse transforms, skipping vertical inverse transform or horizontal inverse transform, or skipping both horizontal and vertical inverse transforms.
- For example, in a decoding process, among transform skip modes, TS0 is a mode of performing 2D inverse transform on a transform block. TS1 is a mode of performing inverse transform on rows only in a transform block (inverse transform on rows), and TS2 is a mode of performing inverse transform on columns only in a transform block (inverse transform on columns). TS3 is a mode of performing neither inverse transform on rows (horizontal inverse transform) nor inverse transform on columns (vertical inverse transform).
-
FIG. 4 schematically illustrates a transform skip mode. - When
TS0 400 is employed in the encoding apparatus, 2D transform is applied to on a transform block. Here, whenTS0 400 is employed, horizontal transform may be performed before vertical transform or vertical transform may be performed before horizontal transform. WhenTS1 420 is employed, horizontal transform is performed on a transform block. WhenTS2 440 is employed, vertical transform is performed on a transform block. WhenTS3 460 is employed, neither horizontal transform nor vertical transform is performed on a transform block. - When
TS0 400 is employed in the decoding apparatus, 2D inverse transform is applied to on a transform block. Here, whenTS0 400 is employed, horizontal inverse transform may be performed before vertical inverse transform or vertical inverse transform may be performed before horizontal inverse transform. WhenTS1 420 is employed, horizontal inverse transform is performed on a transform block. WhenTS2 440 is employed, vertical inverse transform is performed on a transform block. WhenTS3 460 is employed, neither horizontal inverse transform nor vertical inverse transform is performed on a transform block. - Table 1 illustrates a codeword allocated to each mode in transform skip modes.
-
TABLE 1 Transform on Transform on TSM rows columns Codeword Note TS0 O O 1 2D transform TS1 O — 01 1D transform TS2 — O 001 1D transform TS3 — — 000 Non- transform - When transform skip mode is applied, scaling may be carried out without changing or modifying a quantization matrix.
- Equation 1 illustrates an example of scaling to be performed by the encoding apparatus and decoding apparatus.
-
Y=(X−scale+offset)>>shift [Equation 1] - In Equation 1, x is a scaling target parameter, and y is a scaled parameter value. A shift operation factor (shift) may be adaptively determined in the encoding apparatus or be determined in advance.
- A scaling coefficient (scale) is dependent on a TU size and may be determined based on a TU size. Table 2 illustrates a scaling coefficient according to block (for example, TU) size.
-
TABLE 2 N 4 8 16 32 Scale 128 181 256 362 - Referring to Table 2, a scaling coefficient may be determined according to a block size (N×N), for example, a scaling coefficient for a 4×4 block is 128, a scaling coefficient for a 8×8 block is 181, a scaling coefficient for a 16×16 block is 256, and a scaling coefficient for a 32×32 block is 362.
- Although a transform skip mode is applied based on an intra prediction mode in the foregoing description, the present invention is not limited thereto but transform skip mode may be also applied in inter prediction.
- A transform skip mode may be applied based on an intra prediction mode used when intra prediction is applied, while a transform skip mode may be applied based on a block shape when inter prediction is applied.
- Block shapes to which inter prediction may be applied are a 2N×2N square block, a minimum size block of N×N, and asymmetric blocks of 2N×N, N×2N, 2N×nU, 2N×nD, nL×2N and nR×2N, and a transform skip mode may be applied based on a block shape.
- Table 3 illustrates transform skip modes applicable in inter prediction.
-
TABLE 3 Transform on Transform on TSM rows columns Codeword Note TS0 O O 1 2D transform TS1 O — 01 1D transform TS2 — O 001 1D transform TS3 — — 000 Non- transform - Meanwhile, after a transform block is transformed, another transform may be applied to a low-frequency domain, which is referred to, for convenience, as second transform. For example, after transform is applied, DST may be applied to a low frequency domain by each 4×4 block to enhance efficiency.
- The applied DST as second transform may be 2D DST, horizontal DST, or vertical DST according to the intra prediction modes illustrated in
FIG. 3 . Table 4 illustrates DST types applicable according to the intra prediction modes. -
TABLE 4 IntraPredMode 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 horizTrType 0 1 0 1 1 0 0 1 1 1 1 1 0 0 1 1 1 1 vertTrType 0 0 0 1 1 1 1 1 0 0 1 1 1 1 1 1 0 0 IntraPredMode 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 horizTrType 1 1 1 1 0 0 0 0 1 1 1 1 1 1 1 1 1 vertTrType 1 1 1 1 1 1 1 1 1 1 1 1 0 0 0 0 1 - Referring to Table 4, it is determined whether to perform horizontal DST (horizTrType=1) or vertical DST (vertTrType=1) based on an intra prediction mode.
- Although Table 4 illustrates that whether to perform horizontal DST or vertical DST is determined based on an intra prediction mode, both vertical DST and horizontal DST may be applied by 4×4 blocks regardless of intra prediction modes.
- Meanwhile, when a transform skip mode is applied, how to apply second transform may be an issue. Here, the second transform may be performed based on an applied transform skip mode.
- For example, DST in the second transform may be performed as the same transform method as in a transform skip mode. Here, as an example of the same transform method as employed in the transform skip mode (TSM), a transform direction may be considered. Specifically, when the 2D transform mode TS0 is applied as a transform skip mode, 2D DST may be employed as second transform. When horizontal transform TS1 is applied as a transform skip mode, horizontal DST may be employed as second transform. When vertical transform TS2 is applied as a transform skip mode, vertical DST may be employed as second transform. When TS3 is applied, that is, when neither horizontal transform nor vertical transform is applied, second transform may not be applied.
- Table 5 illustrates a second transform type (mode) according to a TSM.
-
TSM TS0 TS1 TS2 TS3 Second horizTrType = 1 1 1 0 0 transform vertTrType = 1 1 0 1 0 - Although the second transform in intra prediction has been illustrated, the present invention is not limited thereto but second transform may be applied in the same manner in inter prediction. For example, when inter prediction has been performed, the second transform may be also applied based on a transform skip mode applied to a corresponding block. Specifically, when the 2D transform mode TS0 is applied as a transform skip mode, 2D DST may be employed as second transform. When horizontal transform TS1 is applied as a transform skip mode, horizontal DST may be employed as second transform. When vertical transform TS2 is applied as a transform skip mode, vertical DST may be employed as second transform. When TS3 is applied, that is, when neither horizontal transform nor vertical transform is applied, second transform may not be applied.
-
FIG. 5 is a flowchart schematically illustrating an encoding process adopting a transform skip mode and second transform according to the present invention. - Referring to
FIG. 5 , the encoding apparatus may partition an input picture (S510). The input picture may be partitioned into blocks, such as CUs, PUs and TUs. - The encoding apparatus may perform prediction for a processing target block that is a current block (S520). The encoding apparatus may perform inter prediction or intra prediction for the current block to generate a predicted block and generate a residual block based on the predicted block.
- The encoding apparatus may encode prediction information (S530). The encoding apparatus may encode motion information when inter prediction is applied and encode information indicating an intra prediction mode when intra prediction is applied.
- The encoding apparatus may transform a residual signal and encode the transformed residual signal (S540). The encoding apparatus may apply a transform skip mode to the residual signal and perform second transform based on the transform skip mode.
- The encoding apparatus may determine information to transmit (S550). The encoding apparatus may determine through rate-distortion optimization (RDO) which to transmit among the residual block and transform coefficients.
- To transmit the transform coefficients, the encoding apparatus may scan the transform coefficients (S560). The transform coefficients are rearranged by scanning.
- The encoding apparatus may entropy-encode the scanned transform coefficients (S570). The encoding apparatus may transmit the entropy-encoded transform coefficients as a bitstream.
- Hereinafter, the encoding process illustrated in
FIG. 5 is described in detail. - The encoding apparatus may partition the input picture (S510). The input picture is partitioned for encoding. For example, a current picture or frame may be partitioned into coding units (CUs).
- One inter coding unit CU may include a plurality of inter prediction units PUs and have a plurality of prediction modes PreMode. For instance, the plurality of prediction modes may include a skip mode MODE_SKIP and an inter mode MODE_INTER. In the skip mode, prediction may be performed for a block having a partition mode Part Mode of PART—2N×2N, without partitioning into smaller Prediction units PUs. Thus, prediction is performed using motion information on a neighboring block as motion information allocated to a PART—2N×2N prediction unit PU, and a residual signal is not transmitted.
- In the inter mode, a coding unit may include four types of prediction unit partitions, for example, PART—2N×2N, PART—2N×N, PART_N×2N and PART_N×N. In this case, the encoding apparatus may signal that the prediction mode PreMode is the inter mode MODE_INTER and information Part Mode indicating which is a partition type among the four types to the decoding apparatus.
- When a coding unit is partitioned into a plurality of prediction units, prediction may be performed for a prediction unit to be currently encoded (current block).
- The encoding apparatus may perform prediction for the prediction target block that is the current block (S520).
- When inter prediction is performed for the current block or current prediction unit, the encoding apparatus may perform motion prediction for the current block using previous pictures. Or When inter prediction is performed for the current block or current prediction unit, the encoding apparatus may perform motion prediction for the current block using frames; or previous and subsequent pictures; or frames. Motion information including a motion vector and a reference picture list, etc. may be obtained through motion prediction. When intra prediction is performed for the current block, the encoding apparatus may perform intra prediction for the current block using samples neighboring to the current block and derive an intra prediction mode.
- Information on the current prediction unit is not transmitted as it is but a differential value from a predicted value obtained from neighboring blocks may be transmitted so as to improve compression efficiency. Here, in the skip mode, prediction is performed using motion information on neighboring block as the motion information on the current block but the differential value is not transmitted.
- In the merge mode and the AMVP mode, prediction is perform using motion information on neighboring block and a differential value (residual signal) is transmitted.
-
FIG. 6 schematically illustrates information on a neighboring block available in the skip mode, the merge mode, and the AMVP mode. - To obtain a predicted motion value of a
current block 600, the encoding apparatus may construct a merging candidate list and an AMVP candidate list. The candidate lists may be constructed based on spatial candidate blocks A0, A1, B0, B1 and B2 neighboring to thecurrent block 600 and a corresponding block in a collocatedpicture 610 as a temporal candidate block. Here, the temporal candidate block may be any one of C0, C3, BR and H. On the merging candidate list, candidates A (A0→A1), B (B0→B1→B2) and the temporal candidate block may be considered in order. On the AMVP candidate list, candidates may be considered with the same order as for the merging candidate list or the candidates may be considered in order of the temporal candidate block, A (A0→A1) and B (B0→B1→B2). - The encoding apparatus may perform prediction for the current block using motion information on the candidate blocks.
- When the merge mode is applied, the encoding apparatus derives merging candidates from motion information on blocks temporally and spatially neighboring to the current block (for example, a prediction unit). If a candidate having the same motion information as the current block is present among the candidates, the encoding apparatus transmits a flag indicating that the merge mode is used and an index of the candidate having the same motion information as the current block. For example, in the merge mode, (i) the encoding apparatus may derive an available temporal motion vector prediction value using a derived reference picture index (refIdxLX, X=0 or 1). (ii) The encoding apparatus may make a merging candidate list (MergeCandList). (iii) When a candidate block having the same motion information as the current block is present, the encoding apparatus sets a merge flag (Merge_flag) equal to 1 and encodes an index (Merge_Idx) for the candidate block.
- In the AMVP mode, the encoding apparatus derives AMVP candidates from motion information on blocks temporally and spatially neighboring the current block (for example, a PU). (i) The encoding apparatus derives spatial motion vector predictor (MVP) candidates from the neighboring blocks (for example, Pus) to the current block. The neighboring blocks shown in
FIG. 6 may be used to derive the spatial motion vector candidates. (ii) The encoding apparatus derives a temporal motion vector candidate of a collocated block using a reference picture index (RefIdxLX) obtained in a motion estimation process. (iii) The encoding apparatus makes an MVP list (mvpListLX). Here, motion vectors may have priories in order of {circle around (1)} a motion vector of a temporal collocated block (mvLXCol), for example, the collocated block may be one of the corresponding blocks C0, C3, BR and H ofFIG. 6 , {circle around (2)} motion vectors of neighboring blocks in the left side of the current block (mvLXA) and {circle around (3)} motion vectors of neighboring blocks in the upper side of the current block (mvLXB), among available motion vectors. Here, the available blocks, such as the collocated block, the neighboring blocks in the left side of the current block and the neighboring blocks in the upper side of the current block, are illustrated above inFIG. 6 . (iv) When a plurality of motion vectors has the same value, the encoding apparatus removes motion vectors other than a motion vector having a highest priority among the motion vectors having the same value from the MVP list. (v) The encoding apparatus set an optimal MVP among the motion vector candidates on the MVP list (mvListLX) as an MVP for the current block. The optimal MVP is a MVP of a candidate block minimizing a cost function. - Meanwhile, when the intra prediction mode is applied, the encoding apparatus performs prediction using samples neighboring to the current block. The encoding apparatus may determine an optimal intra prediction mode using RDO. In the DC mode or planar mode, the encoding apparatus may generate a predicted block for the current block using a pixel value derived based on an average pixel value of neighboring samples or pixels values of neighboring samples regardless of neighboring samples' direction. When a directional mode is employed, the encoding apparatus may generate a predicted block for the current block using sample in direction indicated by an intra prediction mode for the current block.
- The encoding apparatus may encode the prediction information (S530).
- In the merge mode, when a candidate having the same motion information as the current block (for example, a PU) among merging candidates, the encoding apparatus indicates that the current block is in the merge mode and transmits a merge flag indicating that the merge mode is used and a merge index (Merge_Idx) indicating which candidate is selected among the merging candidates. The encoding apparatus obtains a differential signal (residual signal) between the current block and a block predicted by the merge mode after motion compensation. When there is no residual signal to transmit, the encoding apparatus may transmit information indicating that a merge skip mode is applied.
- In the AMVP mode, the encoding apparatus determines a candidate minimizing a cost function among AMVP candidates by comparing motion vector information of the AMVP candidates and motion vector information of the block to be currently encoded. The encoding apparatus obtain a differential value in motion information between the current block and the candidate minimizing the cost function, and a residual signal by motion compensation using the AMVP candidate. The encoding apparatus entropy-encodes a motion vector difference between a motion vector of the current block (for example, prediction unit) and the motion vector of the candidate (optimal predictor) minimizing the cost function.
- When intra prediction is applied, the encoding apparatus derives a residual signal as a difference between the current block and the predicted block generated using the intra prediction mode. The encoding apparatus may entropy-encode the residual signal. The encoding apparatus may also encode information indicating that the intra prediction mode is applied.
- As described above, the encoding apparatus may transform and encode the residual signal generated through prediction (S540). The encoding apparatus may derive the residual signal by obtaining a difference between a pixel value of the current block and a pixel value of the predicted block with a pixel as a unit.
- The encoding apparatus may transform and encode the generated residual signal. Here, available transforming and encoding kernels may be 2×2, 4×4, 8×8, 16×16, 32×32 and 64×64 block, among which a predetermined encoding kernel may be determined in advance as a kernel to be used for transform.
- When intra prediction is applied, the encoding apparatus may determine a transform skip mode based on a direction of an intra prediction mode. Although the foregoing description illustrates that a transform skip mode is determined according to a direction of an intra prediction mode, the encoding apparatus may determine a transform skip mode based on RDO and may signal information on the determined transform skip mode. Here, number of transform skip mode candidates may be determined differently according to directions of intra prediction modes. Further, information indicating transform skip modes may be encoded with different codewords based on directions of intra prediction modes.
- When inter prediction is applied, the encoding apparatus may determine a transform skip mode based on a shape of the current block (for example, prediction unit). Although the foregoing description illustrates that a transform skip mode is determined based on a shape of the current block, the encoding apparatus may determine a transform skip mode based on RDO and may signal information on the determined transform skip mode. Here, number of transform skip mode candidates may be determined differently based on shapes of the current block. Further, information indicating transform skip mode s may be encoded with different codewords based on shapes of the current block.
- The encoding apparatus may perform 2D transform, 1D transform (transform on columns and transform on rows) or transform bypassing according to a transform skip mode.
- Meanwhile, the same transform skip mode as for a luma component may be applied to a chroma component.
- After a transform skip mode is applied, the encoding apparatus may perform second transform based on the applied transform skip mode. A second transform may be performed by applying DST to each 4×4 block. The encoding apparatus determines a type of the second transform based on the transform skip mode and applies the determined type of second transform to a low-frequency domain. For example, the encoding apparatus may perform DST on a low-frequency domain with a 4×4 block size.
- As a type of the second transform methods determined according to transform skip mode s, as described above, 2D DST is applied as second transform when the 2D transform mode TS0 is applied as a transform skip mode; horizontal DST is employed as second transform when horizontal transform TS1 is applied as a transform skip mode; vertical DST is applied as second transform when vertical transform TS2 is applied as transform skip mode; and second transform may not be applied when TS3 is applied, that is, when neither horizontal transform nor vertical transform is applied.
- Meanwhile, a transform coefficient C for an n×n block may be determined by
Equation 2. -
C(n,n)=T(n,n)×B(n,n)×T(n,n)T [Equation 2] - In
Equation 2, T is a transform matrix, and B is a residual block. - The encoding apparatus quantizes transform coefficients.
- The encoding apparatus may determine the information to transmit (S550). The encoding apparatus may determine which to transmit among the residual signal and transform coefficients through rate-distortion optimization (RDO). If the residual signal is small as prediction is properly done, the encoding apparatus may transmit the residual signal as it is. Alternatively, the encoding apparatus may transmit information which minimizes cost by comparing costs before and after transform and encoding. When the information to transmit is determined, the encoding apparatus may signal a type of the determined information, that is, whether the determined information is the residual signal or transform coefficients.
- To transmit the transform coefficients, the encoding apparatus may scan the transform coefficients (S560). The transform coefficients are rearranged by scanning.
- The encoding apparatus may entropy-encode the scanned transform coefficients (S570). The encoding apparatus may transmit the entropy-encoded transform coefficients as a bitstream.
-
FIG. 7 is a flowchart schematically illustrating a decoding process adopting a transform skip mode and second transform according to the present invention. - Referring to
FIG. 7 , the decoding apparatus entropy-decodes a bitstream received from the encoding apparatus (S710). The decoding apparatus may perform entropy decoding using a corresponding method to entropy encoding used by the encoding apparatus. - The decoding apparatus may inverse-transform the entropy decoded information (S720). The decoding apparatus may scan inversely the entropy decoded information to generate a two-dimensional block.
- The decoding apparatus performs prediction for a current block (for example, a PU) (S730). The decoding apparatus may generate a predicted block for the current block according to a prediction method used for the encoding apparatus.
- The decoding apparatus may generate a reconstructed signal for the current block (S740). The decoding apparatus may add the predicted block and a residual block to reconstruct the current block.
- Hereinafter, the decoding process illustrated in
FIG. 7 is described in detail. - First, the decoding apparatus entropy-decodes the bitstream received from the encoding apparatus (S710). The decoding apparatus may obtain, from the received bitstream, a block type of the current block and information on a prediction mode for the current block. For example, when variable length coding (VLC) is applied to the current block in entropy encoding, the block type may be obtained from a VLC table.
- The decoding apparatus may find out through an information type whether the transmitted information on the current block is a residual signals or transform coefficients. The decoding apparatus may obtain information on the residual signal or transform coefficient of the current block.
- The decoding apparatus may inverse-transform the entropy decoded information (S720). The decoding apparatus may scan inversely the entropy decoded residual signal or transform coefficient to generate a two-dimensional block.
- When intra prediction is applied to the current block, the decoding apparatus may derive a transform skip mode based on an intra prediction mode and perform inverse transform according to the derived transform skip mode. When a transform skip mode is determined regardless of an intra prediction mode (for example, determined based on RDO), the decoding apparatus may decode information, received from the encoding apparatus, indicating a transform skip mode and perform inverse transform process according to the transform skip mode.
- When inter prediction is applied to the current block, the decoding apparatus may derive a transform skip mode based on a shape of the current block (for example, prediction unit) and perform inverse transform according to the derived transform skip mode. When a transform skip mode is determined regardless of a shape of the current block (for example, determined based on RDO), the decoding apparatus may decode information, received from the encoding apparatus, indicating a transform skip mode and perform inverse transform according to the received from the encoding apparatus.
- The same information as used for a luma component may be reused to determine transform skip mode for a chroma component.
- After a transform skip mode is applied, the decoding apparatus may perform second inverse transform based on the transform skip mode applied to the current block. Second inverse transform may be performed by applying inverse DST to each 4×4 block. The decoding apparatus determines a type of second inverse transform method based on the transform skip mode and applies the determined type of second inverse transform to a low-frequency domain. For example, the decoding apparatus may perform inverse DST on a low-frequency domain with a 4×4 block size.
- As a type of second inverse transform determined according to transform skip modes, inverse 2D DST is applied as second inverse transform when inverse 2D transform TS0 is applied as a transform skip mode; inverse horizontal DST is applied as second inverse transform when inverse horizontal transform TS1 is applied as transform skip mode; inverse vertical DST is applied as second inverse transform when inverse vertical transform TS2 is applied as transform skip mode; and second inverse transform may not be applied when TS3 is applied as transform skip mode, that is, when neither inverse horizontal transform nor inverse vertical transform is applied.
- When the transmitted signal is the residual signal, the decoding apparatus may generate a residual block based on the residual signal.
- When the transmitted signal is the transform coefficient, the decoding apparatus may generate a transform coefficient block based on the transform coefficient. The decoding apparatus may dequantize and inverse-transform the transform coefficient block to derive the residual block.
- Equation 3 illustrates an example of inverse transform applied to the current transform coefficient block.
-
B(n,n)=T(n,n)×C(n,n)×T(n,n)T [Equation 3] - In Equation 3, each factor is the same as described above in
Equation 2. - The decoding apparatus performs prediction for the current block (for example, prediction unit) (S730).
- Even though the information transmitted from the encoding apparatus indicates that the prediction mode is the skip mode (PredMode=MODE_SKIP), the decoding apparatus may obtain a motion vector (mvLX) and a reference picture index through the merge mode when a merge flag has a value of 1.
- The decoding apparatus may derive merging candidates from blocks (for example, prediction units) neighboring to the current block (for example, prediction unit). Further, the decoding apparatus may derive the reference picture index (refIdxLX) so as to obtain a temporal merging candidate. The merging candidates have been illustrated in
FIG. 6 . - The decoding apparatus derives an available temporal motion vector predictor (MVP) value using the derived reference picture index.
- When a number of candidates (NumMergeCand) on the merging candidate list (MergeCandList) is 1, the decoding apparatus may set a merge index (Merge_Idx) equal to 1. Otherwise, the decoding apparatus may set the merge index equal to an index value received from the encoding apparatus.
- The decoding apparatus may derive a motion vector (mvLX) of a merging candidate indicated by the merge index and the reference picture index (refIdxLX), and perform motion compensation using the derived motion vector and reference picture index.
- When the AMVP mode is applied, the decoding apparatus may derive a reference picture index (refIdxLX) of the current block (for example, prediction unit).
- The decoding apparatus may derive a motion vector predictor (MVP) value using the reference picture index.
- To this end, the decoding apparatus may derive spatial motion vector (MVP) candidates from the blocks (for example, prediction units) neighboring to the current block. The decoding apparatus may also derive a temporal motion vector predictor (MVP) of a collocated block indicated by the reference picture index. The decoding apparatus may construct an MVP list (mvpListLX). Here, motion vectors may have priories in order of {circle around (1)} a motion vector of a temporal collocated block (mvLXCol), for example, the temporal collocated block may be one of the corresponding blocks C0, C3, BR and H of
FIG. 6 , {circle around (2)} motion vectors of neighboring blocks in the left side of the current block (mvLXA) and {circle around (3)} motion vectors of neighboring blocks in the upper side of the current block (mvLXB) among available vectors. - When a plurality of motion vectors has the same value, the decoding apparatus may remove motion vectors other than a motion vector having a highest priority among the motion vectors having the same value from the MVP list.
- When a number (NumMVPCand(LX)) of MVP candidates on the MVP list is 1, the decoding apparatus may set mvpIdx equal to 1. When the number of MVP candidates is 2 or more, the decoding apparatus may set mvpIdx equal to an index value received from the encoding apparatus. The decoding apparatus allocates a motion vector indicated by mvpIdx among the MVP candidates on mvpListLX as the motion vector predictor value mvpLX.
- The decoding apparatus may derive a motion vector for the current block using Equation 4.
-
mvLX[0]=mvdLX[0]+mvpLX[0] -
mvLX[1]=mvdLX[1]+mvpLX[1] [Equation 4] - In Equation 4, mvLX[0] is an x component of the motion vector for the current block, mvdLX[0] is an x component of a motion vector differential value for the current block, and mvpLX[0] is an x component of the motion vector predictor value for the current block. mvLX[1] is a y component of the motion vector for the current block, mvdLX[1] is a y component of the motion vector differential value for the current block, and mvpLX[1] is a y component of the motion vector predictor value for the current block.
- Meanwhile, when intra prediction is applied, the decoding apparatus may generate a predicted block for the current block based on neighboring samples using an intra prediction mode for the current block.
- The decoding apparatus may generate the reconstructed signal for the current block (S740). When inter prediction is applied, the decoding apparatus may generate the predicted block using the derived motion vector and add the predicted block and the residual block to reconstruct the current block. When intra prediction is applied, the decoding apparatus also may add the predicted block and the residual block to reconstruct the current block as described.
- Although methods have been described with a series of stages or blocks based on the flowcharts in the aforementioned embodiments, the present invention is not limited to the foregoing sequence of the stages. Some stages may be carried out in different order from described above or at the same time. Further, the aforementioned embodiments include examples of various aspects. For instance, the illustrated embodiments may be achieved in diverse combinations within the scope of the present invention. It will be appreciated by those skilled in the art that changes, modifications and alternatives may be made in these exemplary embodiments without departing from the principles and spirit of be the invention, the scope of which is defined in the appended claims and their equivalents.
Claims (15)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/605,236 US20150131739A1 (en) | 2011-10-18 | 2015-01-26 | Method for encoding image, method for decoding image, image encoder, and image decoder |
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR20110106624 | 2011-10-18 | ||
KR10-2011-0106624 | 2011-10-18 | ||
PCT/KR2012/008563 WO2013058583A1 (en) | 2011-10-18 | 2012-10-18 | Method for encoding image, method for decoding image, image encoder, and image decoder |
US201414352837A | 2014-04-18 | 2014-04-18 | |
US14/605,236 US20150131739A1 (en) | 2011-10-18 | 2015-01-26 | Method for encoding image, method for decoding image, image encoder, and image decoder |
Related Parent Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/352,837 Division US10264283B2 (en) | 2011-10-18 | 2012-10-18 | Method and apparatus for decoding a video signal using adaptive transform |
PCT/KR2012/008563 Division WO2013058583A1 (en) | 2011-10-18 | 2012-10-18 | Method for encoding image, method for decoding image, image encoder, and image decoder |
Publications (1)
Publication Number | Publication Date |
---|---|
US20150131739A1 true US20150131739A1 (en) | 2015-05-14 |
Family
ID=48141128
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/352,837 Active US10264283B2 (en) | 2011-10-18 | 2012-10-18 | Method and apparatus for decoding a video signal using adaptive transform |
US14/605,236 Abandoned US20150131739A1 (en) | 2011-10-18 | 2015-01-26 | Method for encoding image, method for decoding image, image encoder, and image decoder |
US14/605,201 Active US10575015B2 (en) | 2011-10-18 | 2015-01-26 | Method and apparatus for decoding a video signal using adaptive transform |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/352,837 Active US10264283B2 (en) | 2011-10-18 | 2012-10-18 | Method and apparatus for decoding a video signal using adaptive transform |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/605,201 Active US10575015B2 (en) | 2011-10-18 | 2015-01-26 | Method and apparatus for decoding a video signal using adaptive transform |
Country Status (11)
Country | Link |
---|---|
US (3) | US10264283B2 (en) |
KR (10) | KR102030717B1 (en) |
CN (19) | CN105120272B (en) |
AU (5) | AU2012326819B2 (en) |
BR (1) | BR112014009449B1 (en) |
CA (2) | CA2853002C (en) |
GB (3) | GB2561487B (en) |
MX (4) | MX336750B (en) |
PL (1) | PL231160B1 (en) |
RU (10) | RU2719375C2 (en) |
WO (1) | WO2013058583A1 (en) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20180192071A1 (en) * | 2017-01-05 | 2018-07-05 | Mediatek Inc. | Decoder-side motion vector restoration for video coding |
US10334263B2 (en) * | 2013-04-05 | 2019-06-25 | Samsung Electronics Co., Ltd. | Interlayer video encoding method and apparatus and interlayer video decoding method and apparatus for compensating luminance difference |
WO2020000016A1 (en) * | 2018-06-29 | 2020-01-02 | Canon Kabushiki Kaisha | Method, apparatus and system for encoding and decoding a transformed block of video samples |
US11166039B2 (en) | 2018-01-17 | 2021-11-02 | Intellectual Discovery Co., Ltd. | Method and device for video coding using various transform techniques |
US11412223B2 (en) | 2016-08-31 | 2022-08-09 | Kt Corporation | Method and apparatus for processing video signal |
US11533508B2 (en) | 2018-06-08 | 2022-12-20 | Kt Corporation | Method and apparatus for encoding/decoding residual data based on a plurality of transformations |
US11638027B2 (en) | 2016-08-08 | 2023-04-25 | Hfi Innovation, Inc. | Pattern-based motion vector derivation for video coding |
US11700389B2 (en) | 2016-08-31 | 2023-07-11 | Kt Corporation | Method and apparatus for processing video signal |
Families Citing this family (130)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108063943B (en) * | 2011-10-17 | 2021-11-02 | 株式会社Kt | Method for decoding video signal having current block to be decoded by decoding device |
WO2015053115A1 (en) * | 2013-10-11 | 2015-04-16 | ソニー株式会社 | Decoding device, decoding method, encoding device, and encoding method |
JP6542206B2 (en) * | 2013-10-18 | 2019-07-10 | エルジー エレクトロニクス インコーポレイティド | Video decoding method and apparatus for decoding multiview video |
KR102551609B1 (en) * | 2014-11-27 | 2023-07-05 | 주식회사 케이티 | Method and apparatus for processing a video signal |
KR102294016B1 (en) * | 2014-12-05 | 2021-08-25 | 성균관대학교산학협력단 | Video encoding and decoding method using deblocking fitering with transform skip and apparatus using the same |
FR3032583B1 (en) * | 2015-02-06 | 2018-03-02 | Orange | METHOD OF ENCODING DIGITAL IMAGE, DECODING METHOD, DEVICES, AND COMPUTER PROGRAMS |
US11477484B2 (en) * | 2015-06-22 | 2022-10-18 | Qualcomm Incorporated | Video intra prediction using hybrid recursive filters |
WO2017030418A1 (en) * | 2015-08-19 | 2017-02-23 | 엘지전자(주) | Method and device for encoding/decoding video signal by using optimized conversion based on multiple graph-based model |
EP3345396A4 (en) * | 2015-09-01 | 2019-03-27 | Telefonaktiebolaget LM Ericsson (publ) | Spatial improvement of transform blocks |
KR102469145B1 (en) | 2015-10-13 | 2022-11-21 | 삼성전자주식회사 | Method and device for encoding or decoding image |
US9883137B2 (en) | 2015-11-03 | 2018-01-30 | Qualcomm Incorporated | Updating regions for display based on video decoding mode |
WO2017135663A2 (en) * | 2016-02-01 | 2017-08-10 | 엘지전자 주식회사 | Method and device for performing transformation using row-column transforms |
US11695958B2 (en) | 2016-02-01 | 2023-07-04 | Lg Electronics Inc. | Method and apparatus for encoding/decoding video signal by using edge-adaptive graph-based transform |
KR20230130772A (en) | 2016-02-12 | 2023-09-12 | 삼성전자주식회사 | image encoding method and apparatus, and image decoding method and apparatus |
JP2017158183A (en) * | 2016-02-29 | 2017-09-07 | 大学共同利用機関法人情報・システム研究機構 | Image processing device |
ES2710807B1 (en) * | 2016-03-28 | 2020-03-27 | Kt Corp | METHOD AND APPARATUS FOR PROCESSING VIDEO SIGNALS |
CN113810709A (en) * | 2016-04-29 | 2021-12-17 | 世宗大学校产学协力团 | Method and apparatus for encoding and decoding image signal |
RU2740863C2 (en) * | 2016-05-13 | 2021-01-21 | Сони Корпорейшн | Image processing device and method |
US11758136B2 (en) * | 2016-06-24 | 2023-09-12 | Electronics And Telecommunications Research Institute | Method and apparatus for transform-based image encoding/decoding |
US10735720B2 (en) * | 2016-06-24 | 2020-08-04 | Kt Corporation | Method and apparatus for processing video signal |
US11190770B2 (en) * | 2016-07-05 | 2021-11-30 | Kt Corporation | Method and apparatus for processing video signal |
CN114401402B (en) * | 2016-07-05 | 2024-06-14 | 株式会社Kt | Method and apparatus for processing video signal |
WO2018012830A1 (en) * | 2016-07-13 | 2018-01-18 | 한국전자통신연구원 | Image encoding/decoding method and device |
CN109644276B (en) * | 2016-08-01 | 2022-12-30 | 韩国电子通信研究院 | Image encoding/decoding method |
WO2018037737A1 (en) * | 2016-08-24 | 2018-03-01 | ソニー株式会社 | Image processing device, image processing method, and program |
WO2018038554A1 (en) * | 2016-08-24 | 2018-03-01 | 엘지전자(주) | Method and apparatus for encoding/decoding video signal by using secondary transform |
WO2018061837A1 (en) | 2016-09-30 | 2018-04-05 | ソニー株式会社 | Image processing device and method |
US10880564B2 (en) * | 2016-10-01 | 2020-12-29 | Qualcomm Incorporated | Transform selection for video coding |
CN117176948A (en) | 2016-10-04 | 2023-12-05 | 有限公司B1影像技术研究所 | Image encoding/decoding method, recording medium, and method of transmitting bit stream |
CN117119179A (en) * | 2016-11-18 | 2023-11-24 | 株式会社Kt | Video decoding method, video encoding method, and compressed video data transmitting apparatus |
RU2759052C2 (en) * | 2016-12-28 | 2021-11-09 | Сони Корпорейшн | Device and method for image processing |
WO2018143687A1 (en) * | 2017-02-01 | 2018-08-09 | 엘지전자(주) | Method and apparatus for performing transformation by using row-column transform |
US11405645B2 (en) * | 2017-02-28 | 2022-08-02 | Google Llc | Transform kernel selection and entropy coding |
KR102424411B1 (en) * | 2017-04-13 | 2022-07-25 | 엘지전자 주식회사 | Image encoding/decoding method and device therefor |
AU2018270853B2 (en) * | 2017-05-17 | 2021-04-01 | Kt Corporation | Method and device for video signal processing |
WO2018221554A1 (en) * | 2017-06-01 | 2018-12-06 | パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ | Encoding device, encoding method, decoding device, and decoding method |
EP3627836A4 (en) * | 2017-06-21 | 2021-04-07 | LG Electronics Inc. | Method and device for decoding image according to intra-prediction in image coding system |
KR20240010541A (en) * | 2017-07-04 | 2024-01-23 | 삼성전자주식회사 | A method and an apparatus for video decoding by multiple core transformation, a method and an apparatus for video encoding by multiple core transformation |
TWI794129B (en) * | 2017-07-13 | 2023-02-21 | 美商松下電器(美國)知識產權公司 | Encoding device, encoding method, decoding device, decoding method, and computer-readable non-transitory medium |
BR112020002205A2 (en) * | 2017-08-22 | 2020-07-28 | Panasonic Intellectual Property Corporation Of America | image encoder, image decoder, image encoding method and image decoding method |
WO2019076138A1 (en) * | 2017-10-16 | 2019-04-25 | Huawei Technologies Co., Ltd. | Encoding method and apparatus |
CN109922348B (en) * | 2017-12-13 | 2020-09-18 | 华为技术有限公司 | Image coding and decoding method and device |
EP3716630A4 (en) * | 2017-12-15 | 2021-01-27 | LG Electronics Inc. | Image coding method on basis of transformation and device therefor |
RU2748907C1 (en) | 2017-12-15 | 2021-06-01 | ЭлДжи ЭЛЕКТРОНИКС ИНК. | Image coding method based on non-separable secondary transformation and device for it |
CN115834876A (en) * | 2017-12-21 | 2023-03-21 | Lg电子株式会社 | Decoding and encoding device, medium for storing bit stream and data transmitting device |
WO2019151795A1 (en) * | 2018-01-31 | 2019-08-08 | 가온미디어 주식회사 | Image processing method for processing motion information, method for decoding and coding image using same, and apparatus therefor |
CN108416353B (en) * | 2018-02-03 | 2022-12-02 | 华中农业大学 | Method for quickly segmenting rice ears in field based on deep full convolution neural network |
US10567801B2 (en) * | 2018-03-07 | 2020-02-18 | Tencent America LLC | Method and apparatus for video coding with primary and secondary transforms |
TWI731322B (en) * | 2018-03-29 | 2021-06-21 | 弗勞恩霍夫爾協會 | Set of transforms |
JP7334730B2 (en) * | 2018-03-30 | 2023-08-29 | ソニーグループ株式会社 | Image processing device and method |
WO2019194420A1 (en) * | 2018-04-01 | 2019-10-10 | 엘지전자 주식회사 | Image coding method and device on basis of transform indicator |
US10999604B2 (en) * | 2018-04-13 | 2021-05-04 | Mediatek Inc. | Adaptive implicit transform setting |
US11297348B2 (en) * | 2018-04-13 | 2022-04-05 | Mediatek Inc. | Implicit transform settings for coding a block of pixels |
WO2019212230A1 (en) * | 2018-05-03 | 2019-11-07 | 엘지전자 주식회사 | Method and apparatus for decoding image by using transform according to block size in image coding system |
US10397603B1 (en) * | 2018-05-08 | 2019-08-27 | Tencent America LLC | Method and apparatus for video coding |
US10986340B2 (en) * | 2018-06-01 | 2021-04-20 | Qualcomm Incorporated | Coding adaptive multiple transform information for video coding |
CN115379216A (en) * | 2018-06-03 | 2022-11-22 | Lg电子株式会社 | Video signal decoding apparatus, video signal encoding apparatus, video signal transmitting apparatus, and video signal storage medium |
KR101997681B1 (en) * | 2018-06-11 | 2019-07-08 | 광운대학교 산학협력단 | A method and an apparatus for encoding/decoding a residual block based on quantization parameter |
KR102030384B1 (en) | 2018-06-19 | 2019-11-08 | 광운대학교 산학협력단 | A method and an apparatus for encoding/decoding residual coefficient |
US10638145B2 (en) * | 2018-06-19 | 2020-04-28 | Novatek Microelectronics Corp. | Video encoding apparatus and operating method thereof |
CN117499638A (en) * | 2018-06-27 | 2024-02-02 | 数字洞察力有限公司 | Method of encoding/decoding image and method of transmitting bitstream |
KR20210024502A (en) | 2018-06-29 | 2021-03-05 | 베이징 바이트댄스 네트워크 테크놀로지 컴퍼니, 리미티드 | Partial/full pruning when adding HMVP candidates to merge/AMVP |
JP7460617B2 (en) | 2018-06-29 | 2024-04-02 | 北京字節跳動網絡技術有限公司 | LUT update conditions |
TWI723444B (en) | 2018-06-29 | 2021-04-01 | 大陸商北京字節跳動網絡技術有限公司 | Concept of using one or multiple look up tables to store motion information of previously coded in order and use them to code following blocks |
TWI750486B (en) * | 2018-06-29 | 2021-12-21 | 大陸商北京字節跳動網絡技術有限公司 | Restriction of motion information sharing |
CN110662056B (en) | 2018-06-29 | 2022-06-07 | 北京字节跳动网络技术有限公司 | Which lookup table needs to be updated or not |
EP3797516A1 (en) | 2018-06-29 | 2021-03-31 | Beijing Bytedance Network Technology Co. Ltd. | Interaction between lut and amvp |
CN110662076B (en) * | 2018-06-29 | 2022-10-04 | 北京字节跳动网络技术有限公司 | Boundary enhancement of sub-blocks |
EP3791588A1 (en) | 2018-06-29 | 2021-03-17 | Beijing Bytedance Network Technology Co. Ltd. | Checking order of motion candidates in lut |
CN110662057B (en) | 2018-06-29 | 2022-06-21 | 北京字节跳动网络技术有限公司 | Video processing method, device and equipment and method for storing bit stream |
WO2020003278A1 (en) | 2018-06-29 | 2020-01-02 | Beijing Bytedance Network Technology Co., Ltd. | Update of look up table: fifo, constrained fifo |
EP4307679A3 (en) | 2018-07-02 | 2024-06-19 | Beijing Bytedance Network Technology Co., Ltd. | Luts with intra prediction modes and intra mode prediction from non-adjacent blocks |
CN117812257A (en) * | 2018-07-02 | 2024-04-02 | Lg电子株式会社 | Image decoding method, image encoding method, storage medium, and transmission method |
CN116916039A (en) | 2018-08-06 | 2023-10-20 | Lg电子株式会社 | Decoding method, encoding method and data transmitting method |
WO2020043145A1 (en) * | 2018-08-29 | 2020-03-05 | Huawei Technologies Co., Ltd. | Apparatus and method and for boundary partition |
CN115037934B (en) * | 2018-09-02 | 2024-04-26 | Lg电子株式会社 | Method for encoding and decoding image signal and computer readable recording medium |
CN115379211B (en) * | 2018-09-02 | 2024-06-04 | Lg电子株式会社 | Method of decoding/encoding video signal and computer readable storage medium |
KR102534160B1 (en) * | 2018-09-02 | 2023-05-26 | 엘지전자 주식회사 | Image coding method based on multiple transform selection and its device |
PL3723373T3 (en) * | 2018-09-02 | 2023-11-06 | Lg Electronics Inc. | Method for decoding an image signal, method for encoding an image signal and storage medium |
EP3723372A4 (en) * | 2018-09-05 | 2021-03-31 | LG Electronics Inc. | Method for encoding/decoding video signal, and apparatus therefor |
US10819979B2 (en) * | 2018-09-06 | 2020-10-27 | Tencent America LLC | Coupled primary and secondary transform |
BR112021004516B1 (en) | 2018-09-11 | 2021-12-14 | Lg Electronics Inc | IMAGE DECODING METHOD PERFORMED BY A DECODING DEVICE, IMAGE ENCODING METHOD PERFORMED BY A ENCODING DEVICE, AND COMPUTER READable STORAGE MEDIA |
TW202025760A (en) | 2018-09-12 | 2020-07-01 | 大陸商北京字節跳動網絡技術有限公司 | How many hmvp candidates to be checked |
CN112740684A (en) * | 2018-09-19 | 2021-04-30 | 韩国电子通信研究院 | Method and apparatus for encoding/decoding image and recording medium for storing bitstream |
CN111373753B (en) | 2018-09-20 | 2023-09-08 | Lg电子株式会社 | Conversion factor level coding method and device thereof |
KR20200039591A (en) * | 2018-10-05 | 2020-04-16 | 한국전자통신연구원 | Method and apparatus for encoding/decoding image and recording medium for storing bitstream |
CA3118269C (en) | 2018-11-08 | 2023-10-03 | Guangdong Oppo Mobile Telecommunications Corp., Ltd. | Method for encoding/decoding image signal, and apparatus therefor |
CN111277840B (en) * | 2018-12-04 | 2022-02-08 | 华为技术有限公司 | Transform method, inverse transform method, video encoder and video decoder |
WO2020114291A1 (en) * | 2018-12-04 | 2020-06-11 | Huawei Technologies Co., Ltd. | Video encoder, video decoder, and corresponding method |
KR20230154085A (en) * | 2018-12-17 | 2023-11-07 | 엘지전자 주식회사 | Method of determining transform coefficient scan order based on high frequency zeroing and apparatus thereof |
US11323748B2 (en) * | 2018-12-19 | 2022-05-03 | Qualcomm Incorporated | Tree-based transform unit (TU) partition for video coding |
CN118200577A (en) * | 2018-12-27 | 2024-06-14 | 英迪股份有限公司 | Image decoding method, image encoding method, and method for transmitting bit stream of image |
CN113273186A (en) | 2019-01-10 | 2021-08-17 | 北京字节跳动网络技术有限公司 | Invocation of LUT update |
CN113383554B (en) | 2019-01-13 | 2022-12-16 | 北京字节跳动网络技术有限公司 | Interaction between LUTs and shared Merge lists |
CN109819250B (en) * | 2019-01-15 | 2020-09-25 | 北京大学 | Method and system for transforming multi-core full combination mode |
CN113302937B (en) | 2019-01-16 | 2024-08-02 | 北京字节跳动网络技术有限公司 | Motion candidate derivation |
CN117812271A (en) * | 2019-02-01 | 2024-04-02 | Lg电子株式会社 | Image decoding method, image encoding method, storage medium, and transmission method |
CN118474371A (en) * | 2019-02-19 | 2024-08-09 | Lg 电子株式会社 | Video decoding method using residual information in video coding system and apparatus therefor |
CN113711593B (en) * | 2019-03-12 | 2024-08-23 | 弗劳恩霍夫应用研究促进协会 | Partition-based intra coding concept to achieve high efficiency |
CN113615193B (en) | 2019-03-22 | 2024-06-25 | 北京字节跳动网络技术有限公司 | Interactions between Merge list build and other tools |
EP3949404A1 (en) * | 2019-03-26 | 2022-02-09 | VID SCALE, Inc. | Content adaptive transform precision for video coding |
KR20210130235A (en) | 2019-04-15 | 2021-10-29 | 엘지전자 주식회사 | Scaling list parameter-based video or image coding |
SI3952313T1 (en) * | 2019-04-16 | 2024-08-30 | Lg Electronics Inc. | Transform in intra prediction-based image coding |
CN113841409B (en) | 2019-05-10 | 2023-12-19 | 北京字节跳动网络技术有限公司 | Conditional use of simplified quadratic transforms for video processing |
CN117221544A (en) | 2019-05-19 | 2023-12-12 | 字节跳动有限公司 | Transform bypass coding residual block in digital video |
BR112021023469A2 (en) * | 2019-05-24 | 2022-01-18 | Digital Insights Inc | Video and device encoding method using adaptive parameter set |
KR20210133301A (en) * | 2019-06-06 | 2021-11-05 | 엘지전자 주식회사 | Transformation-based video coding method and apparatus |
CN117354521A (en) | 2019-06-07 | 2024-01-05 | 北京字节跳动网络技术有限公司 | Conditional signaling of simplified secondary transforms in video bitstreams |
KR20200144511A (en) * | 2019-06-18 | 2020-12-29 | 한국전자통신연구원 | Method and apparatus for video encoding/decoding using secondary transform and recording medium for storing bitstream |
JP7259087B2 (en) * | 2019-06-18 | 2023-04-17 | エルジー エレクトロニクス インコーポレイティド | Image decoding method and apparatus based on BDPCM |
EP3982630A4 (en) * | 2019-06-19 | 2022-08-10 | LG Electronics Inc. | Method and device for coding image on basis of inter prediction |
KR20220024711A (en) * | 2019-06-20 | 2022-03-03 | 인터디지털 브이씨 홀딩스 프랑스 에스에이에스 | Lossless Mode for Versatile Video Coding |
WO2021006697A1 (en) * | 2019-07-10 | 2021-01-14 | 엘지전자 주식회사 | Image decoding method for residual coding and apparatus therefor |
EP3994887A4 (en) | 2019-08-03 | 2022-09-28 | Beijing Bytedance Network Technology Co., Ltd. | Selection of matrices for reduced secondary transform in video coding |
WO2021025528A1 (en) * | 2019-08-08 | 2021-02-11 | 엘지전자 주식회사 | Image coding method based on transform, and device therefor |
CN114223208B (en) | 2019-08-17 | 2023-12-29 | 北京字节跳动网络技术有限公司 | Context modeling for side information of reduced secondary transforms in video |
CN118714314A (en) * | 2019-08-31 | 2024-09-27 | Lg 电子株式会社 | Method for coding and decoding video using simplified residual data in video coding system and apparatus therefor |
CN118714309A (en) * | 2019-09-19 | 2024-09-27 | 数码士有限公司 | Video signal processing method and apparatus using scaling processing |
CN117560508A (en) * | 2019-09-21 | 2024-02-13 | Lg电子株式会社 | Image encoding/decoding apparatus and apparatus for transmitting data |
KR20220045048A (en) | 2019-09-21 | 2022-04-12 | 엘지전자 주식회사 | Transformation-based video coding method and apparatus |
CN116527938A (en) * | 2019-09-21 | 2023-08-01 | Lg电子株式会社 | Image decoding method, image encoding method, and data transmitting method |
SI4017008T1 (en) * | 2019-09-21 | 2024-08-30 | Lg Electronics Inc. | Transform-based image coding |
BR112022005267A2 (en) * | 2019-09-21 | 2022-06-14 | Lg Electronics Inc | Image encoding method based on transform and device for same |
AU2020354148B2 (en) * | 2019-09-25 | 2024-02-15 | Lg Electronics Inc. | Image encoding/decoding method and apparatus for signaling residual coding method used for encoding block to which BDPCM is applied, and method for transmitting bitstream |
CN117395415A (en) * | 2019-10-04 | 2024-01-12 | Lg电子株式会社 | Image encoding and decoding apparatus and apparatus for transmitting data |
MX2022005294A (en) * | 2019-11-01 | 2022-07-21 | Lg Electronics Inc | Transform-based image coding method and device for same. |
US12052421B2 (en) * | 2019-11-11 | 2024-07-30 | Lg Electronics Inc. | Transformation-based image coding method and device therefor |
US20210176468A1 (en) * | 2019-12-06 | 2021-06-10 | Qualcomm Incorporated | Residual coding selection and low-level signaling based on quantization parameter |
CN118540503A (en) * | 2020-02-27 | 2024-08-23 | Lg电子株式会社 | Image decoding apparatus, image encoding apparatus, and transmitting apparatus |
CN113766225B (en) * | 2020-06-05 | 2023-02-28 | 杭州海康威视数字技术股份有限公司 | Encoding method, decoding method and device |
Citations (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090238271A1 (en) * | 2006-09-20 | 2009-09-24 | Dae-Yeon Kim | Apparatus and method for encoding and decoding using alternative converter accoding to the correlation of residual signal |
US20110090954A1 (en) * | 2009-10-21 | 2011-04-21 | Cohen Robert A | Video Codes with Directional Transforms |
US20120008690A1 (en) * | 2010-07-09 | 2012-01-12 | Samsung Electronics Co., Ltd. | Methods and apparatuses for encoding and decoding motion vector |
US20120008683A1 (en) * | 2010-07-09 | 2012-01-12 | Qualcomm Incorporated | Signaling selected directional transform for video coding |
US20120057630A1 (en) * | 2010-09-08 | 2012-03-08 | Samsung Electronics Co., Ltd. | Low complexity transform coding using adaptive dct/dst for intra-prediction |
US20120082224A1 (en) * | 2010-10-01 | 2012-04-05 | Qualcomm Incorporated | Intra smoothing filter for video coding |
US20120189055A1 (en) * | 2011-01-21 | 2012-07-26 | Qualcomm Incorporated | Motion vector prediction |
US20120230392A1 (en) * | 2011-03-08 | 2012-09-13 | Qualcomm Incorporated | MOTION VECTOR PREDICTORS (MVPs) FOR BI-PREDICTIVE INTER MODE IN VIDEO CODING |
US20120320980A1 (en) * | 2011-06-15 | 2012-12-20 | Fujitsu Limited | Video decoding apparatus, video coding apparatus, video decoding method, video coding method, and storage medium |
US20120320984A1 (en) * | 2011-06-14 | 2012-12-20 | Minhua Zhou | Inter-Prediction Candidate Index Coding Independent of Inter-Prediction Candidate List Construction in Video Coding |
US20130034154A1 (en) * | 2010-04-16 | 2013-02-07 | Sk Telecom Co., Ltd. | Video encoding/decoding apparatus and method |
US20130064301A1 (en) * | 2010-05-20 | 2013-03-14 | Thomson Licensing | Methods and apparatus for adaptive motion vector candidate ordering for video encoding and decoding |
US20130083853A1 (en) * | 2011-10-04 | 2013-04-04 | Qualcomm Incorporated | Motion vector predictor candidate clipping removal for video coding |
US20130114717A1 (en) * | 2011-11-07 | 2013-05-09 | Qualcomm Incorporated | Generating additional merge candidates |
US20130156335A1 (en) * | 2010-09-02 | 2013-06-20 | Lg Electronics Inc. | Method for encoding and decoding video, and apparatus using same |
US20130170553A1 (en) * | 2012-01-04 | 2013-07-04 | Qualcomm Incorporated | Coding motion vector difference |
US20130177079A1 (en) * | 2010-09-27 | 2013-07-11 | Lg Electronics Inc. | Method for partitioning block and decoding device |
US20130230103A1 (en) * | 2010-11-23 | 2013-09-05 | Lg Electronics Inc. | Method for encoding and decoding images, and device using same |
US20130251044A1 (en) * | 2010-12-13 | 2013-09-26 | Electronics And Telecommunications Research Institute | Method and device for determining reference unit |
US20130301736A1 (en) * | 2011-01-28 | 2013-11-14 | Toshiyasu Sugio | Image coding method and image decoding method |
US20140140408A1 (en) * | 2011-06-14 | 2014-05-22 | Samsung Electronics Co., Ltd. | Method and apparatus for encoding motion information and method and apparatus for decoding same |
Family Cites Families (61)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7656949B1 (en) * | 2001-06-27 | 2010-02-02 | Cisco Technology, Inc. | Methods and apparatus for performing efficient inverse transform operations |
KR100846769B1 (en) * | 2002-02-19 | 2008-07-16 | 삼성전자주식회사 | Method for encoding motion image having fixed computational complexity and apparatus thereof |
KR100833228B1 (en) * | 2002-02-21 | 2008-05-28 | 삼성전자주식회사 | Method for encoding motion image having fixed computational complexity and apparatus thereof |
US7760950B2 (en) | 2002-09-26 | 2010-07-20 | Ntt Docomo, Inc. | Low complexity and unified transforms for video coding |
JP3685780B2 (en) | 2002-10-18 | 2005-08-24 | 三菱電機株式会社 | Digital video signal recording apparatus, recording method, reproducing apparatus, and reproducing method |
US7813574B2 (en) | 2003-09-24 | 2010-10-12 | Ntt Docomo, Inc. | Low complexity and unified transforms for video coding |
JP2005184042A (en) * | 2003-12-15 | 2005-07-07 | Sony Corp | Image decoding apparatus, image decoding method, and image decoding program |
KR100621581B1 (en) * | 2004-07-15 | 2006-09-13 | 삼성전자주식회사 | Method for pre-decoding, decoding bit-stream including base-layer, and apparatus thereof |
KR20060007142A (en) * | 2004-07-19 | 2006-01-24 | 삼성전자주식회사 | Method of inverse transform and apparatus thereof |
US20060104521A1 (en) | 2004-11-15 | 2006-05-18 | Shu-Wen Teng | Image processing devices and methods |
KR100794623B1 (en) * | 2005-06-20 | 2008-01-14 | 주식회사 픽스트리 | A decoding system for executing accelerated processing in real time, and methods thereof |
US7843995B2 (en) | 2005-12-19 | 2010-11-30 | Seiko Epson Corporation | Temporal and spatial analysis of a video macroblock |
WO2008035842A1 (en) | 2006-09-20 | 2008-03-27 | Electronics And Telecommunications Research Institute | Apparatus and method for encoding and decoding using alternative converter according to the correlation of residual signal |
US7957600B2 (en) * | 2007-05-08 | 2011-06-07 | Arris Group, Inc. | Methods and systems for rate-distortion optimized quantization of transform blocks in block transform video coding |
US8428133B2 (en) | 2007-06-15 | 2013-04-23 | Qualcomm Incorporated | Adaptive coding of video block prediction mode |
JP2009111691A (en) | 2007-10-30 | 2009-05-21 | Hitachi Ltd | Image-encoding device and encoding method, and image-decoding device and decoding method |
EP2232874B1 (en) * | 2008-01-08 | 2012-12-05 | Telefonaktiebolaget L M Ericsson (publ) | Adaptive filtering |
KR101291196B1 (en) | 2008-01-25 | 2013-07-31 | 삼성전자주식회사 | Video encoding method and apparatus, and video decoding method and apparatus |
JP2009224854A (en) * | 2008-03-13 | 2009-10-01 | Toshiba Corp | Image encoding device and method |
EP2266318B1 (en) * | 2008-03-19 | 2020-04-22 | Nokia Technologies Oy | Combined motion vector and reference index prediction for video coding |
CN101252686B (en) * | 2008-03-20 | 2010-04-14 | 上海交通大学 | Undamaged encoding and decoding method and system based on interweave forecast |
JP4748191B2 (en) | 2008-07-30 | 2011-08-17 | ソニー株式会社 | Motion vector detection apparatus, motion vector detection method, and program |
WO2010018992A2 (en) | 2008-08-12 | 2010-02-18 | Lg Electronics Inc. | Method of processing a video signal |
KR101377660B1 (en) * | 2008-09-30 | 2014-03-26 | 에스케이텔레콤 주식회사 | Motion Vector Encoding/Decoding Method and Apparatus Using Multiple Motion Vector Estimation and Video Encoding/Decoding Method and Apparatus Using Same |
KR101458471B1 (en) | 2008-10-01 | 2014-11-10 | 에스케이텔레콤 주식회사 | Method and Apparatus for Encoding and Decoding Vedio |
KR101377527B1 (en) * | 2008-10-14 | 2014-03-25 | 에스케이 텔레콤주식회사 | Method and Apparatus for Encoding and Decoding Motion Vector in Plural Number of Reference Pictures and Video Encoding/Decoding Method and Apparatus Using Same |
KR101567974B1 (en) * | 2009-01-05 | 2015-11-10 | 에스케이 텔레콤주식회사 | / / Block Mode Encoding/Decoding Method and Apparatus and Video Encoding/Decoding Method and Apparatus Using Same |
KR101672456B1 (en) * | 2009-02-09 | 2016-11-17 | 삼성전자 주식회사 | Method and apparatus for video encoding using low-complexity frequency transform, and method and apparatus for video decoding using the same |
US8762441B2 (en) * | 2009-06-05 | 2014-06-24 | Qualcomm Incorporated | 4X4 transform for media coding |
US9069713B2 (en) * | 2009-06-05 | 2015-06-30 | Qualcomm Incorporated | 4X4 transform for media coding |
US9635368B2 (en) | 2009-06-07 | 2017-04-25 | Lg Electronics Inc. | Method and apparatus for decoding a video signal |
WO2010143853A2 (en) | 2009-06-07 | 2010-12-16 | 엘지전자 주식회사 | Method and apparatus for decoding a video signal |
JP5841940B2 (en) | 2009-07-10 | 2016-01-13 | ブリティッシュ・ブロードキャスティング・コーポレーションBritish Broadcasting Corporation | Hybrid open-loop / closed-loop compression of images |
WO2011003480A1 (en) | 2009-07-10 | 2011-01-13 | British Broadcasting Corporation | Hybrid open-loop/closed-loop compression of pictures |
KR20110014000A (en) * | 2009-08-04 | 2011-02-10 | 광운대학교 산학협력단 | Apparatus and method of deblocking filtering an image data and decoding apparatus and method using the same |
KR101675116B1 (en) | 2009-08-06 | 2016-11-10 | 삼성전자 주식회사 | Method and apparatus for encoding video, and method and apparatus for decoding video |
US8885714B2 (en) | 2010-01-14 | 2014-11-11 | Texas Instruments Incorporated | Method and system for intracoding in video encoding |
KR101768207B1 (en) * | 2010-01-19 | 2017-08-16 | 삼성전자주식회사 | Method and apparatus for encoding/decoding motion vector based on reduced motion vector predictor candidates |
RU2419246C1 (en) * | 2010-01-25 | 2011-05-20 | Государственное образовательное учреждение высшего профессионального образования "Военная академия связи имени С.М. Буденного" Министерства обороны Российской Федерации | Method to compress and recover fixed halftone video images |
KR20120086232A (en) | 2011-01-25 | 2012-08-02 | (주)휴맥스 | Method for encoding/decoding video for rate-distortion optimization and apparatus for performing the same |
US8792740B2 (en) | 2010-02-02 | 2014-07-29 | Humax Holdings Co., Ltd. | Image encoding/decoding method for rate-distortion optimization and apparatus for performing same |
KR101753273B1 (en) | 2010-03-10 | 2017-07-03 | 톰슨 라이센싱 | Methods and apparatus for constrained transforms for video coding and decoding having transform selection |
CN101867813B (en) * | 2010-04-23 | 2012-05-09 | 南京邮电大学 | Multi-view video coding method oriented for interactive application |
WO2011142279A1 (en) * | 2010-05-13 | 2011-11-17 | シャープ株式会社 | Encoding device, decoding device, and data structure |
AU2010357291B2 (en) | 2010-07-15 | 2015-01-15 | Kabushiki Kaisha Toshiba | Image encoding method and image decoding method |
US9641846B2 (en) | 2010-10-22 | 2017-05-02 | Qualcomm Incorporated | Adaptive scanning of transform coefficients for video coding |
US20120218432A1 (en) * | 2011-02-28 | 2012-08-30 | Sony Corporation | Recursive adaptive intra smoothing for video coding |
US9693070B2 (en) | 2011-06-24 | 2017-06-27 | Texas Instruments Incorporated | Luma-based chroma intra-prediction for video coding |
GB2492333B (en) | 2011-06-27 | 2018-12-12 | British Broadcasting Corp | Video encoding and decoding using transforms |
US9756360B2 (en) * | 2011-07-19 | 2017-09-05 | Qualcomm Incorporated | Coefficient scanning in video coding |
US9338458B2 (en) * | 2011-08-24 | 2016-05-10 | Mediatek Inc. | Video decoding apparatus and method for selectively bypassing processing of residual values and/or buffering of processed residual values |
CN107197309B (en) * | 2011-10-07 | 2020-02-18 | 英迪股份有限公司 | Method for decoding video signal |
CN108063943B (en) * | 2011-10-17 | 2021-11-02 | 株式会社Kt | Method for decoding video signal having current block to be decoded by decoding device |
KR101718954B1 (en) * | 2011-10-17 | 2017-03-22 | 주식회사 케이티 | Method and apparatus for encoding/decoding image |
KR101542586B1 (en) * | 2011-10-19 | 2015-08-06 | 주식회사 케이티 | Method and apparatus for encoding/decoding image |
US10390046B2 (en) | 2011-11-07 | 2019-08-20 | Qualcomm Incorporated | Coding significant coefficient information in transform skip mode |
US10200709B2 (en) | 2012-03-16 | 2019-02-05 | Qualcomm Incorporated | High-level syntax extensions for high efficiency video coding |
US9503720B2 (en) | 2012-03-16 | 2016-11-22 | Qualcomm Incorporated | Motion vector coding and bi-prediction in HEVC and its extensions |
US9426466B2 (en) * | 2012-06-22 | 2016-08-23 | Qualcomm Incorporated | Transform skip mode |
US10257520B2 (en) * | 2012-06-26 | 2019-04-09 | Velos Media, Llc | Modified coding for transform skipping |
US20140092956A1 (en) * | 2012-09-29 | 2014-04-03 | Motorola Mobility Llc | Adaptive transform options for scalable extension |
-
2012
- 2012-10-18 GB GB1809879.8A patent/GB2561487B/en active Active
- 2012-10-18 CN CN201510501922.5A patent/CN105120272B/en active Active
- 2012-10-18 CN CN201711215702.1A patent/CN107959853B/en not_active Expired - Fee Related
- 2012-10-18 US US14/352,837 patent/US10264283B2/en active Active
- 2012-10-18 KR KR1020177020520A patent/KR102030717B1/en active IP Right Grant
- 2012-10-18 CN CN201711215872.XA patent/CN107835414B/en active Active
- 2012-10-18 KR KR1020147025587A patent/KR101762294B1/en active IP Right Grant
- 2012-10-18 CN CN201711218757.8A patent/CN107959857B/en not_active Expired - Fee Related
- 2012-10-18 RU RU2016126955A patent/RU2719375C2/en active
- 2012-10-18 RU RU2016126942A patent/RU2719302C2/en active
- 2012-10-18 RU RU2016126941A patent/RU2719377C2/en active
- 2012-10-18 CN CN201711218646.7A patent/CN107835420B/en active Active
- 2012-10-18 RU RU2016126978A patent/RU2719390C2/en active
- 2012-10-18 BR BR112014009449-7A patent/BR112014009449B1/en active IP Right Grant
- 2012-10-18 CN CN201410645698.2A patent/CN104378637B/en active Active
- 2012-10-18 RU RU2016126945A patent/RU2715382C2/en active
- 2012-10-18 AU AU2012326819A patent/AU2012326819B2/en active Active
- 2012-10-18 KR KR1020147008590A patent/KR101539107B1/en active IP Right Grant
- 2012-10-18 RU RU2014117489/07A patent/RU2593991C2/en active
- 2012-10-18 KR KR1020147028308A patent/KR101828964B1/en active IP Right Grant
- 2012-10-18 CN CN201711217414.XA patent/CN107835416B/en active Active
- 2012-10-18 MX MX2015010293A patent/MX336750B/en unknown
- 2012-10-18 KR KR1020177020521A patent/KR102030718B1/en active IP Right Grant
- 2012-10-18 CN CN201711217594.1A patent/CN107835418B/en not_active Expired - Fee Related
- 2012-10-18 KR KR1020177020522A patent/KR102030719B1/en active IP Right Grant
- 2012-10-18 CN CN201711217635.7A patent/CN107835419B/en not_active Expired - Fee Related
- 2012-10-18 KR KR1020147023246A patent/KR101539109B1/en active IP Right Grant
- 2012-10-18 RU RU2016126960A patent/RU2719374C2/en active
- 2012-10-18 GB GB1719342.6A patent/GB2554828B/en active Active
- 2012-10-18 RU RU2016126966A patent/RU2719379C2/en active
- 2012-10-18 MX MX2014004851A patent/MX2014004851A/en active IP Right Grant
- 2012-10-18 MX MX2016013695A patent/MX369192B/en unknown
- 2012-10-18 CN CN201711215886.1A patent/CN107835415B/en active Active
- 2012-10-18 WO PCT/KR2012/008563 patent/WO2013058583A1/en active Application Filing
- 2012-10-18 KR KR1020147023245A patent/KR101539108B1/en active IP Right Grant
- 2012-10-18 CN CN201711217421.XA patent/CN107820079B9/en active Active
- 2012-10-18 CN CN201711217591.8A patent/CN107835417B/en active Active
- 2012-10-18 CN CN201711218647.1A patent/CN107820082B9/en not_active Expired - Fee Related
- 2012-10-18 KR KR1020147023248A patent/KR101539111B1/en active IP Right Grant
- 2012-10-18 CN CN201610978407.0A patent/CN107105244B/en active Active
- 2012-10-18 PL PL408821A patent/PL231160B1/en unknown
- 2012-10-18 KR KR1020147023247A patent/KR101539110B1/en active IP Right Grant
- 2012-10-18 CN CN201711215875.3A patent/CN107820078B/en not_active Expired - Fee Related
- 2012-10-18 CA CA2853002A patent/CA2853002C/en active Active
- 2012-10-18 CN CN201711218885.2A patent/CN107959858B/en not_active Expired - Fee Related
- 2012-10-18 CA CA2946947A patent/CA2946947C/en active Active
- 2012-10-18 RU RU2016126988A patent/RU2719340C2/en active
- 2012-10-18 CN CN201711218509.3A patent/CN107820081B/en not_active Expired - Fee Related
- 2012-10-18 CN CN201280062710.6A patent/CN104067622B/en active Active
- 2012-10-18 RU RU2016126982A patent/RU2719386C2/en active
- 2012-10-18 CN CN201711218507.4A patent/CN107820080B/en not_active Expired - Fee Related
- 2012-10-18 GB GB1407659.0A patent/GB2509670B/en active Active
-
2014
- 2014-04-21 MX MX2016001115A patent/MX355346B/en unknown
-
2015
- 2015-01-26 US US14/605,236 patent/US20150131739A1/en not_active Abandoned
- 2015-01-26 US US14/605,201 patent/US10575015B2/en active Active
-
2016
- 2016-01-29 AU AU2016200532A patent/AU2016200532B2/en active Active
- 2016-10-19 AU AU2016247091A patent/AU2016247091B2/en active Active
- 2016-10-19 AU AU2016247090A patent/AU2016247090B2/en active Active
- 2016-10-19 AU AU2016247092A patent/AU2016247092B2/en active Active
Patent Citations (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090238271A1 (en) * | 2006-09-20 | 2009-09-24 | Dae-Yeon Kim | Apparatus and method for encoding and decoding using alternative converter accoding to the correlation of residual signal |
US20110090954A1 (en) * | 2009-10-21 | 2011-04-21 | Cohen Robert A | Video Codes with Directional Transforms |
US20130034154A1 (en) * | 2010-04-16 | 2013-02-07 | Sk Telecom Co., Ltd. | Video encoding/decoding apparatus and method |
US20130064301A1 (en) * | 2010-05-20 | 2013-03-14 | Thomson Licensing | Methods and apparatus for adaptive motion vector candidate ordering for video encoding and decoding |
US20120008690A1 (en) * | 2010-07-09 | 2012-01-12 | Samsung Electronics Co., Ltd. | Methods and apparatuses for encoding and decoding motion vector |
US20120008683A1 (en) * | 2010-07-09 | 2012-01-12 | Qualcomm Incorporated | Signaling selected directional transform for video coding |
US20130156335A1 (en) * | 2010-09-02 | 2013-06-20 | Lg Electronics Inc. | Method for encoding and decoding video, and apparatus using same |
US20120057630A1 (en) * | 2010-09-08 | 2012-03-08 | Samsung Electronics Co., Ltd. | Low complexity transform coding using adaptive dct/dst for intra-prediction |
US20130177079A1 (en) * | 2010-09-27 | 2013-07-11 | Lg Electronics Inc. | Method for partitioning block and decoding device |
US20120082224A1 (en) * | 2010-10-01 | 2012-04-05 | Qualcomm Incorporated | Intra smoothing filter for video coding |
US20130230103A1 (en) * | 2010-11-23 | 2013-09-05 | Lg Electronics Inc. | Method for encoding and decoding images, and device using same |
US20130251044A1 (en) * | 2010-12-13 | 2013-09-26 | Electronics And Telecommunications Research Institute | Method and device for determining reference unit |
US20120189055A1 (en) * | 2011-01-21 | 2012-07-26 | Qualcomm Incorporated | Motion vector prediction |
US20130301736A1 (en) * | 2011-01-28 | 2013-11-14 | Toshiyasu Sugio | Image coding method and image decoding method |
US20120230392A1 (en) * | 2011-03-08 | 2012-09-13 | Qualcomm Incorporated | MOTION VECTOR PREDICTORS (MVPs) FOR BI-PREDICTIVE INTER MODE IN VIDEO CODING |
US20120320984A1 (en) * | 2011-06-14 | 2012-12-20 | Minhua Zhou | Inter-Prediction Candidate Index Coding Independent of Inter-Prediction Candidate List Construction in Video Coding |
US20140140408A1 (en) * | 2011-06-14 | 2014-05-22 | Samsung Electronics Co., Ltd. | Method and apparatus for encoding motion information and method and apparatus for decoding same |
US20120320980A1 (en) * | 2011-06-15 | 2012-12-20 | Fujitsu Limited | Video decoding apparatus, video coding apparatus, video decoding method, video coding method, and storage medium |
US20130083853A1 (en) * | 2011-10-04 | 2013-04-04 | Qualcomm Incorporated | Motion vector predictor candidate clipping removal for video coding |
US20130114717A1 (en) * | 2011-11-07 | 2013-05-09 | Qualcomm Incorporated | Generating additional merge candidates |
US20130170553A1 (en) * | 2012-01-04 | 2013-07-04 | Qualcomm Incorporated | Coding motion vector difference |
Cited By (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10334263B2 (en) * | 2013-04-05 | 2019-06-25 | Samsung Electronics Co., Ltd. | Interlayer video encoding method and apparatus and interlayer video decoding method and apparatus for compensating luminance difference |
US11638027B2 (en) | 2016-08-08 | 2023-04-25 | Hfi Innovation, Inc. | Pattern-based motion vector derivation for video coding |
US11962774B2 (en) | 2016-08-31 | 2024-04-16 | Kt Corporation | Method and apparatus for processing video signal |
US12096018B2 (en) | 2016-08-31 | 2024-09-17 | Kt Corporation | Method and apparatus for processing video signal |
US11412223B2 (en) | 2016-08-31 | 2022-08-09 | Kt Corporation | Method and apparatus for processing video signal |
US11445195B2 (en) | 2016-08-31 | 2022-09-13 | Kt Corporation | Method and apparatus for processing video signal |
US11445193B2 (en) | 2016-08-31 | 2022-09-13 | Kt Corporation | Method and apparatus for processing video signal |
US11445194B2 (en) | 2016-08-31 | 2022-09-13 | Kt Corporation | Method and apparatus for processing video signal |
US11700389B2 (en) | 2016-08-31 | 2023-07-11 | Kt Corporation | Method and apparatus for processing video signal |
US12063387B2 (en) * | 2017-01-05 | 2024-08-13 | Hfi Innovation Inc. | Decoder-side motion vector restoration for video coding |
US20180192071A1 (en) * | 2017-01-05 | 2018-07-05 | Mediatek Inc. | Decoder-side motion vector restoration for video coding |
US11991378B2 (en) | 2018-01-17 | 2024-05-21 | Intellectual Discovery Co., Ltd. | Method and device for video coding using various transform techniques |
US11166039B2 (en) | 2018-01-17 | 2021-11-02 | Intellectual Discovery Co., Ltd. | Method and device for video coding using various transform techniques |
US11533508B2 (en) | 2018-06-08 | 2022-12-20 | Kt Corporation | Method and apparatus for encoding/decoding residual data based on a plurality of transformations |
US12003772B2 (en) | 2018-06-08 | 2024-06-04 | Kt Corporation | Method and apparatus for encoding/decoding residual data based on a plurality of transformations |
WO2020000016A1 (en) * | 2018-06-29 | 2020-01-02 | Canon Kabushiki Kaisha | Method, apparatus and system for encoding and decoding a transformed block of video samples |
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10575015B2 (en) | Method and apparatus for decoding a video signal using adaptive transform | |
US9578338B1 (en) | Method and apparatus for encoding image, and method and apparatus for decoding image | |
US9854245B2 (en) | Method and apparatus for coefficient scan based on partition mode of prediction unit | |
US9736480B2 (en) | Adaptive transform method based on in-screen prediction and apparatus using the method |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: KT CORPORATION, KOREA, REPUBLIC OF Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LEE, BAE KEUN;KWON, JAE CHEOL;KIM, JOO YOUNG;REEL/FRAME:034812/0112 Effective date: 20140319 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE AFTER FINAL ACTION FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: ADVISORY ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |