WO2024253427A1 - 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 - Google Patents
영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 Download PDFInfo
- Publication number
- WO2024253427A1 WO2024253427A1 PCT/KR2024/007711 KR2024007711W WO2024253427A1 WO 2024253427 A1 WO2024253427 A1 WO 2024253427A1 KR 2024007711 W KR2024007711 W KR 2024007711W WO 2024253427 A1 WO2024253427 A1 WO 2024253427A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- screen
- prediction mode
- prediction
- current block
- intra
- 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.)
- Pending
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/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
- H04N19/105—Selection of the reference unit for prediction within a chosen coding or prediction mode, e.g. adaptive choice of position and number of pixels used for 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/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
- H04N19/11—Selection of coding mode or of prediction mode among a plurality of spatial predictive coding modes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/176—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/593—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial prediction techniques
Definitions
- the present invention relates to a video encoding/decoding method, a device, and a recording medium storing a bitstream. Specifically, the present invention relates to a video encoding/decoding method using an intra-screen prediction method, a device, and a recording medium storing a bitstream.
- intra prediction is a technique for predicting the current block using previously reconstructed reference pixels of the current picture.
- a prediction block is generated from neighboring reference pixels surrounding the current block based on a predetermined non-directional mode or directional mode.
- Intra prediction may have lower prediction accuracy than inter prediction, which may limit encoding efficiency. Therefore, various methods for improving the prediction accuracy of intra prediction are being discussed.
- the purpose of the present invention is to provide a video encoding/decoding method and device with improved encoding/decoding efficiency.
- the present invention aims to provide a recording medium storing a bitstream generated by the image decoding method or device provided in the present invention.
- a video decoding method may include a step of determining an initial intra-picture prediction mode of a current block, a step of determining one or more adjacent candidate modes adjacent to the initial intra-picture prediction mode based on the initial intra-picture prediction mode of the current block, a step of determining a final intra-picture prediction mode of the current block among candidate intra-picture prediction modes including the one or more adjacent candidate modes, and a step of predicting the current block based on the final intra-picture prediction mode of the current block.
- the method may further include a step of determining whether intra-screen prediction improvement is performed on the current block, and if intra-screen prediction improvement is performed on the current block, a step of determining one or more adjacent candidate modes adjacent to the initial intra-screen prediction mode of the current block based on an initial intra-screen prediction mode of the current block, a step of determining a final intra-screen prediction mode of the current block among candidate intra-screen prediction modes including the one or more adjacent candidate modes, and a step of predicting the current block based on the final intra-screen prediction mode of the current block are performed, and if intra-screen prediction improvement is not performed on the current block, the current block is predicted based on the initial intra-screen prediction mode of the current block.
- the initial intra-screen prediction mode is a non-directional intra-screen prediction mode, it is determined that intra-screen prediction improvement is not performed on the current block.
- it may be characterized in that if an index of a prediction mode within the initial screen is not included in a predetermined range, it is determined that no prediction improvement within the screen is performed on the current block.
- it may be characterized in that whether or not intra-screen prediction improvement is performed on the current block is determined based on at least one of a width, a height, a height, and an aspect ratio of the current block.
- the initial intra-screen prediction mode of the current block may be determined based on the initial intra-screen prediction mode of the reference block.
- the one or more adjacent candidate modes may include a first adjacent candidate mode having a prediction direction between a prediction direction of a prediction mode in a first adjacent picture of the current block and a prediction direction of a prediction mode in the initial picture, and a second adjacent candidate mode having a prediction direction between a prediction direction of a prediction mode in a second adjacent picture of the current block and a prediction direction of the prediction mode in the initial picture, wherein the first adjacent picture prediction mode has an index that is smaller by a predetermined value than an index of the prediction mode in the initial picture, and the second adjacent picture prediction mode has an index that is larger by a predetermined value than an index of the prediction mode in the initial picture.
- the first adjacent candidate mode may be determined by evenly dividing the difference in direction between the prediction direction of the prediction mode in the first adjacent screen of the current block and the prediction direction of the prediction mode in the initial screen according to the number of the first adjacent candidate modes
- the second adjacent candidate mode may be determined by evenly dividing the difference in direction between the prediction direction of the prediction mode in the second adjacent screen of the current block and the prediction direction of the prediction mode in the initial screen according to the number of the second adjacent candidate modes.
- the one or more adjacent candidate modes may include only the second adjacent intra-screen prediction mode, and if the prediction mode within the initial screen is an intra-screen prediction mode with a largest index among directional modes within a given range, the one or more adjacent candidate modes may include only the first adjacent intra-screen prediction mode.
- a mode with the smallest distortion among the candidate in-screen prediction modes of the current block is determined as the final in-screen prediction mode of the current block.
- the distortion of a prediction mode within the candidate screen may be determined based on a difference between a restoration sample included in a template adjacent to the current block and a prediction sample corresponding to the restoration sample.
- the prediction sample may be characterized in that it is determined based on a template reference sample adjacent to the template and a prediction direction of a prediction mode within the candidate screen.
- the image decoding method may further include a step of obtaining, from a bitstream, intra-picture prediction mode improvement index information indicating a final intra-picture prediction mode of the current block among candidate intra-picture prediction modes of the current block, wherein the final intra-picture prediction mode of the current block is determined based on the intra-picture prediction mode improvement index information.
- the intra-screen prediction mode improvement index information may include intra-screen prediction mode improvement sign information indicating which direction the final intra-screen prediction mode is in among a + direction and a - direction from the initial intra-screen prediction mode, and intra-screen prediction mode improvement index difference information indicating an index difference between the final intra-screen prediction mode and the initial intra-screen prediction mode.
- the length of a codeword assigned to the prediction mode within the candidate screen is determined based on an index difference between the prediction mode within the initial screen and the prediction mode within the candidate screen.
- a video encoding method may include the steps of determining an initial intra-picture prediction mode of a current block, determining one or more adjacent candidate modes adjacent to the initial intra-picture prediction mode based on the initial intra-picture prediction mode of the current block, determining a final intra-picture prediction mode of the current block among candidate intra-picture prediction modes including the one or more adjacent candidate modes, and predicting the current block based on the final intra-picture prediction mode of the current block.
- a non-transitory computer-readable recording medium stores a bitstream generated by the image encoding method.
- a transmission method transmits a bitstream generated by the image encoding method.
- the present invention proposes various embodiments of an intra-screen prediction method according to improvement of the intra-screen prediction mode on the decoding side.
- the present invention proposes various embodiments of a method according to improvement of prediction mode in an encoded-side screen.
- the overall encoding efficiency can be improved.
- Figure 1 is a block diagram showing the configuration according to one embodiment of an encoding device to which the present invention is applied.
- FIG. 2 is a block diagram showing the configuration of one embodiment of a decryption device to which the present invention is applied.
- FIG. 3 is a diagram schematically showing a video coding system to which the present invention can be applied.
- FIG. 4 shows a template-based intra mode derivation (TIMD) method.
- Figures 5 and 6 illustrate one embodiment of a method for determining adjacent candidate modes of a prediction mode within an initial screen.
- FIGS. 7 and 8 illustrate one embodiment of a method for determining adjacent candidate modes of an initial intra-screen prediction mode when the initial intra-screen prediction mode is the intra-screen prediction mode with the smallest index among directional modes in a given range.
- Figures 9 and 10 illustrate one embodiment of a method for determining adjacent candidate modes of an initial intra-screen prediction mode when the initial intra-screen prediction mode is the intra-screen prediction mode with the largest index among directional modes in a given range.
- Fig. 11 illustrates an embodiment of an intra-screen prediction method to which intra-screen prediction mode improvement is applied.
- Figure 12 exemplarily illustrates a content streaming system to which an embodiment according to the present invention can be applied.
- a video decoding method may include a step of determining an initial intra-picture prediction mode of a current block, a step of determining one or more adjacent candidate modes adjacent to the initial intra-picture prediction mode based on the initial intra-picture prediction mode of the current block, a step of determining a final intra-picture prediction mode of the current block among candidate intra-picture prediction modes including the one or more adjacent candidate modes, and a step of predicting the current block based on the final intra-picture prediction mode of the current block.
- first, second, etc. may be used to describe various components, but the components should not be limited by the terms. The terms are only used for the purpose of distinguishing one component from another.
- the first component may be referred to as the second component, and similarly, the second component may also be referred to as the first component.
- the term and/or includes a combination of a plurality of related described items or any item among a plurality of related described items.
- each component shown in the embodiments of the present invention are independently depicted to indicate different characteristic functions, and do not mean that each component is formed as a separate hardware or software configuration unit. That is, each component is listed and included as a separate component for convenience of explanation, and at least two components among each component may be combined to form a single component, or one component may be divided into multiple components to perform a function, and such integrated embodiments and separate embodiments of each component are also included in the scope of the present invention as long as they do not deviate from the essence of the present invention.
- the terminology used in the present invention is only used to describe specific embodiments and is not intended to limit the present invention.
- the singular expression includes the plural expression unless the context clearly indicates otherwise.
- some components of the present invention are not essential components that perform essential functions in the present invention and may be optional components that merely enhance performance.
- the present invention may be implemented by including only essential components for implementing the essence of the present invention excluding components used only for enhancing performance, and a structure including only essential components excluding optional components used only for enhancing performance is also included in the scope of the present invention.
- the term "at least one” can mean one of a number greater than or equal to 1, such as 1, 2, 3, and 4.
- the term "a plurality of” can mean one of a number greater than or equal to 2, such as 2, 3, and 4.
- video may mean one picture constituting a video, and may also represent the video itself.
- encoding and/or decoding of a video may mean “encoding and/or decoding of a video,” and may also mean “encoding and/or decoding of one of the videos constituting the video.”
- the target image may be an encoding target image that is a target of encoding and/or a decoding target image that is a target of decoding.
- the target image may be an input image input to an encoding device and may be an input image input to a decoding device.
- the target image may have the same meaning as the current image.
- image may be used with the same meaning and may be used interchangeably.
- target block may be an encoding target block that is a target of encoding and/or a decoding target block that is a target of decoding.
- target block may be a current block that is a target of current encoding and/or decoding.
- target block and current block may be used with the same meaning and may be used interchangeably.
- a coding tree unit may be composed of one luma component (Y) coding tree block (CTB) and two chroma component (Cb, Cr) coding tree blocks related to it.
- sample may represent a basic unit constituting a block.
- Figure 1 is a block diagram showing the configuration according to one embodiment of an encoding device to which the present invention is applied.
- the encoding device (100) may be an encoder, a video encoding device, or an image encoding device.
- the video may include one or more images.
- the encoding device (100) may sequentially encode one or more images.
- an encoding device (100) may include an image segmentation unit (110), an intra prediction unit (120), a motion prediction unit (121), a motion compensation unit (122), a switch (115), a subtractor (113), a transformation unit (130), a quantization unit (140), an entropy encoding unit (150), an inverse quantization unit (160), an inverse transformation unit (170), an adder (117), a filter unit (180), and a reference picture buffer (190).
- the encoding device (100) can generate a bitstream including encoded information through encoding an input image, and output the generated bitstream.
- the generated bitstream can be stored in a computer-readable recording medium, or can be streamed through a wired/wireless transmission medium.
- the video segmentation unit (110) can segment the input video into various forms to increase the efficiency of video encoding/decoding. That is, the input video is composed of multiple pictures, and one picture can be hierarchically segmented and processed for compression efficiency, parallel processing, etc. For example, one picture can be segmented into one or multiple tiles or slices, and then segmented again into multiple CTUs (Coding Tree Units). Alternatively, one picture can be segmented into multiple sub-pictures defined as groups of rectangular slices, and each sub-picture can be segmented into the tiles/slices. Here, the sub-pictures can be utilized to support the function of partially independently encoding/decoding and transmitting the picture.
- multiple sub-pictures can be individually restored, they have the advantage of being easy to edit in applications that configure multi-channel input into one picture.
- tiles can be segmented horizontally to generate bricks.
- a brick can be utilized as a basic unit of intra-picture parallel processing.
- one CTU can be recursively split into a quad tree (QT), and the terminal node of the split can be defined as a CU (Coding Unit).
- the CU can be split into a PU (Prediction Unit) and a TU (Transform Unit), which are prediction units, and prediction and splitting can be performed. Meanwhile, the CU can be utilized as a prediction unit and/or a transform unit itself.
- each CTU can be recursively split into not only a quad tree (QT) but also a multi-type tree (MTT).
- Splitting of a CTU into a multi-type tree can start from the terminal node of a QT, and the MTT can be composed of a BT (Binary Tree) and a TT (Triple Tree).
- the MTT structure can be distinguished into vertical binary partition mode (SPLIT_BT_VER), horizontal binary partition mode (SPLIT_BT_HOR), vertical ternary partition mode (SPLIT_TT_VER), and horizontal ternary partition mode (SPLIT_TT_HOR).
- the minimum block size (MinQTSize) of the quad tree of the luma block during partitioning can be set to 16x16
- the maximum block size (MaxBtSize) of the binary tree can be set to 128x128, and the maximum block size (MaxTtSize) of the triple tree can be set to 64x64.
- the minimum block size (MinBtSize) of the binary tree and the minimum block size (MinTtSize) of the triple tree can be set to 4x4
- the maximum depth (MaxMttDepth) of the multi-type tree can be set to 4.
- a dual tree that uses different CTU partition structures of luma and chrominance components can be applied to improve the encoding efficiency of the I slice.
- the luminance and chrominance CTBs (Coding Tree Blocks) within the CTU can be split into a single tree sharing the coding tree structure.
- the encoding device (100) may perform encoding on the input image in the intra mode and/or the inter mode.
- the encoding device (100) may perform encoding on the input image in a third mode (e.g., IBC mode, Palette mode, etc.) other than the intra mode and the inter mode.
- a third mode e.g., IBC mode, Palette mode, etc.
- the third mode may be classified as the intra mode or the inter mode for convenience of explanation. In the present invention, the third mode will be classified and described separately only when a specific explanation is required.
- the switch (115) can be switched to intra, and when the inter mode is used as the prediction mode, the switch (115) can be switched to inter.
- the intra mode can mean the intra prediction mode
- the inter mode can mean the inter-screen prediction mode.
- the encoding device (100) can generate a prediction block for an input block of an input image.
- the encoding device (100) can encode a residual block using a residual of the input block and the prediction block.
- the input image can be referred to as a current image which is a current encoding target.
- the input block can be referred to as a current block which is a current encoding target or an encoding target block.
- the intra prediction unit (120) can use samples of blocks already encoded/decoded around the current block as reference samples.
- the intra prediction unit (120) can perform spatial prediction on the current block using the reference sample, and can generate prediction samples for the input block through spatial prediction.
- intra prediction can mean prediction within the screen.
- non-directional prediction modes such as DC mode and Planar mode and directional prediction modes (e.g., 65 directions) can be applied.
- the intra prediction method can be expressed as an intra prediction mode or an intra prediction mode.
- the motion prediction unit (121) can search for an area that best matches the input block from the reference image during the motion prediction process, and can derive a motion vector using the searched area. At this time, the search area can be used as the area.
- the reference image can be stored in the reference picture buffer (190).
- it when encoding/decoding for the reference image is processed, it can be stored in the reference picture buffer (190).
- the motion compensation unit (122) can generate a prediction block for the current block by performing motion compensation using a motion vector.
- inter prediction can mean inter-screen prediction or motion compensation.
- the above motion prediction unit (121) and motion compensation unit (122) can generate a prediction block by applying an interpolation filter to a portion of an area within a reference image when the value of a motion vector does not have an integer value.
- the AFFINE mode of sub-PU based prediction the AFFINE mode of sub-PU based prediction, the SbTMVP (Subblock-based Temporal Motion Vector Prediction) mode, and the MMVD (Merge with MVD) mode, the GPM (Geometric Partitioning Mode) mode of PU based prediction can be applied.
- the SbTMVP Subblock-based Temporal Motion Vector Prediction
- MMVD Merge with MVD
- GPM Gaometric Partitioning Mode
- the HMVP History based MVP
- the PAMVP Positionwise Average MVP
- the CIIP Combined Intra/Inter Prediction
- the AMVR Adaptive Motion Vector Resolution
- the BDOF Bi-Directional Optical-Flow
- the BCW Block Predictive with CU Weights
- the LIC Lical Illumination Compensation
- the TM Tempolate Matching
- the OBMC Overlapped Block Motion Compensation
- the subtractor (113) can generate a residual block using the difference between the input block and the predicted block.
- the residual block may also be referred to as a residual signal.
- the residual signal may mean the difference between the original signal and the predicted signal.
- the residual signal may be a signal generated by transforming, quantizing, or transforming and quantizing the difference between the original signal and the predicted signal.
- the residual block may be a residual signal in block units.
- the transform unit (130) can perform a transform on the residual block to generate a transform coefficient and output the generated transform coefficient.
- the transform coefficient can be a coefficient value generated by performing a transform on the residual block.
- the transform unit (130) can also skip the transform on the residual block.
- a quantized level can be generated by applying quantization to a transform coefficient or a residual signal.
- a quantized level may also be referred to as a transform coefficient.
- a 4x4 luminance residual block generated through within-screen prediction can be transformed using a basis vector based on DST (Discrete Sine Transform), and a basis vector based on DCT (Discrete Cosine Transform) can be used to transform the remaining residual blocks.
- a transform block can be divided into a quad tree shape for one block using RQT (Residual Quad Tree) technology, and after performing transformation and quantization on each transform block divided through RQT, a coded block flag (cbf) can be transmitted to increase encoding efficiency when all coefficients become 0.
- RQT Residual Quad Tree
- the Multiple Transform Selection (MTS) technique can be applied to perform transformation by selectively using multiple transformation bases. That is, instead of dividing the CU into TUs through the RQT, a function similar to TU division can be performed through the Sub-block Transform (SBT) technique.
- SBT Sub-block Transform
- the SBT is applied only to inter-screen prediction blocks, and unlike the RQT, the current block can be divided into 1 ⁇ 2 or 1 ⁇ 4 sizes in the vertical or horizontal direction, and then the transformation can be performed on only one of the blocks. For example, if it is divided vertically, the transformation can be performed on the leftmost or rightmost block, and if it is divided horizontally, the transformation can be performed on the topmost or bottommost block.
- LFNST Low Frequency Non-Separable Transform
- a secondary transform technique that additionally transforms the residual signal converted to the frequency domain through DCT or DST, can be applied.
- LFNST additionally performs a transform on the low-frequency region of 4x4 or 8x8 in the upper left, so that the residual coefficients can be concentrated in the upper left.
- the quantization unit (140) can generate a quantized level by quantizing a transform coefficient or a residual signal according to a quantization parameter (QP), and can output the generated quantized level. At this time, the quantization unit (140) can quantize the transform coefficient using a quantization matrix.
- QP quantization parameter
- a quantizer using QP values of 0 to 51 can be used.
- 0 to 63 QP can be used.
- DQ Dependent Quantization
- DQ performs quantization using two quantizers (e.g., Q0 and Q1), and even without signaling information about the use of a specific quantizer, the quantizer to be used for the next transform coefficient can be selected based on the current state through a state transition model.
- the entropy encoding unit (150) can generate a bitstream by performing entropy encoding according to a probability distribution on values produced by the quantization unit (140) or coding parameter values produced in the encoding process, and can output the bitstream.
- the entropy encoding unit (150) can perform entropy encoding on information about image samples and information for decoding the image. For example, information for decoding the image can include syntax elements, etc.
- the entropy encoding unit (150) can use an encoding method such as exponential Golomb, Context-Adaptive Variable Length Coding (CAVLC), or Context-Adaptive Binary Arithmetic Coding (CABAC) for entropy encoding.
- CAVLC Context-Adaptive Variable Length Coding
- CABAC Context-Adaptive Binary Arithmetic Coding
- the entropy encoding unit (150) can perform entropy encoding using a Variable Length Coding/Code (VLC) table.
- VLC Variable Length Coding/Code
- the entropy encoding unit (150) may derive a binarization method of a target symbol and a probability model of a target symbol/bin, and then perform arithmetic encoding using the derived binarization method, probability model, and context model.
- the table probability update method when applying CABAC, in order to reduce the size of the probability table stored in the decryption device, the table probability update method can be changed to a table update method using a simple formula and applied.
- two different probability models can be used to obtain more accurate symbol probability values.
- the entropy encoding unit (150) can change a two-dimensional block form coefficient into a one-dimensional vector form through a transform coefficient scanning method to encode a transform coefficient level (quantized level).
- Coding parameters may include information (flags, indexes, etc.) encoded in an encoding device (100) and signaled to a decoding device (200), such as syntax elements, as well as information derived during an encoding process or a decoding process, and may mean information necessary when encoding or decoding an image.
- signaling a flag or index may mean that the encoder entropy encodes the flag or index and includes it in the bitstream, and that the decoder entropy decodes the flag or index from the bitstream.
- the encoded current image can be used as a reference image for other images to be processed later. Therefore, the encoding device (100) can restore or decode the encoded current image again, and store the restored or decoded image as a reference image in the reference picture buffer (190).
- the quantized level can be dequantized in the dequantization unit (160) and inverse transformed in the inverse transform unit (170).
- the dequantized and/or inverse transformed coefficients can be combined with a prediction block through an adder (117), and a reconstructed block can be generated by combining the dequantized and/or inverse transformed coefficients and the prediction block.
- the dequantized and/or inverse transformed coefficients mean coefficients on which at least one of dequantization and inverse transformation has been performed, and may mean a reconstructed residual block.
- the dequantization unit (160) and the inverse transform unit (170) can be performed in the reverse process of the quantization unit (140) and the transform unit (130).
- the restoration block may pass through a filter unit (180).
- the filter unit (180) may apply a deblocking filter, a sample adaptive offset (SAO), an adaptive loop filter (ALF), a bilateral filter (BIF), LMCS (Luma Mapping with Chroma Scaling), etc. as a filtering technique, in whole or in part, to the restoration sample, restoration block, or restoration image.
- the filter unit (180) may also be called an in-loop filter. In this case, the in-loop filter is also used as a name excluding LMCS.
- the deblocking filter can remove block distortion that occurs at the boundary between blocks.
- different filters can be applied depending on the required deblocking filtering strength.
- a sample adaptive offset can be used to add an appropriate offset value to the sample value to compensate for the encoding error.
- the sample adaptive offset can correct the offset from the original image on a sample basis for the image on which deblocking has been performed.
- a method can be used in which the samples included in the image are divided into a certain number of regions, and then the region to be offset is determined and the offset is applied to the region, or a method can be used in which the offset is applied by considering the edge information of each sample.
- Bilateral filter can also compensate for the offset from the original image on a sample-by-sample basis for the deblocked image.
- An adaptive loop filter can perform filtering based on a comparison value between a restored image and an original image. After dividing samples included in an image into a predetermined group, a filter to be applied to each group can be determined, and filtering can be performed differentially for each group. Information related to whether to apply an adaptive loop filter can be signaled for each coding unit (CU), and the shape and filter coefficients of the adaptive loop filter to be applied can vary for each block.
- CU coding unit
- LMCS Luma Mapping with Chroma Scaling
- LM luma mapping
- CS chroma scaling
- LMCS can be utilized as an HDR correction technique that reflects the characteristics of HDR (High Dynamic Range) images.
- the restored block or restored image that has passed through the filter unit (180) may be stored in the reference picture buffer (190).
- the restored block that has passed through the filter unit (180) may be a part of the reference image.
- the reference image may be a restored image composed of restored blocks that have passed through the filter unit (180).
- the stored reference image may be used for inter-screen prediction or motion compensation thereafter.
- FIG. 2 is a block diagram showing the configuration of one embodiment of a decryption device to which the present invention is applied.
- the decoding device (200) may be a decoder, a video decoding device, or an image decoding device.
- the decoding device (200) may include an entropy decoding unit (210), an inverse quantization unit (220), an inverse transformation unit (230), an intra prediction unit (240), a motion compensation unit (250), an adder (201), a switch (203), a filter unit (260), and a reference picture buffer (270).
- an entropy decoding unit (210) may include an entropy decoding unit (210), an inverse quantization unit (220), an inverse transformation unit (230), an intra prediction unit (240), a motion compensation unit (250), an adder (201), a switch (203), a filter unit (260), and a reference picture buffer (270).
- the decoding device (200) can receive a bitstream output from the encoding device (100).
- the decoding device (200) can receive a bitstream stored in a computer-readable recording medium, or can receive a bitstream streamed through a wired/wireless transmission medium.
- the decoding device (200) can perform decoding on the bitstream in an intra mode or an inter mode.
- the decoding device (200) can generate a restored image or a decoded image through decoding, and can output the restored image or the decoded image.
- the switch (203) can be switched to intra. If the prediction mode used for decryption is inter mode, the switch (203) can be switched to inter.
- the decoding device (200) can obtain a reconstructed residual block by decoding the input bitstream and can generate a prediction block. When the reconstructed residual block and the prediction block are obtained, the decoding device (200) can generate a reconstructed block to be decoded by adding the reconstructed residual block and the prediction block.
- the decoding target block can be referred to as a current block.
- the entropy decoding unit (210) can generate symbols by performing entropy decoding according to a probability distribution for the bitstream.
- the generated symbols can include symbols in the form of quantized levels.
- the entropy decoding method can be the reverse process of the entropy encoding method described above.
- the entropy decoding unit (210) can change a one-dimensional vector-shaped coefficient into a two-dimensional block-shaped coefficient through a transform coefficient scanning method to decode a transform coefficient level (quantized level).
- the quantized level can be dequantized in the dequantization unit (220) and detransformed in the inverse transform unit (230).
- the quantized level can be generated as a restored residual block as a result of the dequantization and/or detransformation.
- the dequantization unit (220) can apply a quantization matrix to the quantized level.
- the dequantization unit (220) and the detransform unit (230) applied to the decoding device can apply the same technology as the dequantization unit (160) and the detransform unit (170) applied to the encoding device described above.
- the intra prediction unit (240) can generate a prediction block by performing spatial prediction on the current block using sample values of already decoded blocks surrounding the block to be decoded.
- the intra prediction unit (240) applied to the decoding device can apply the same technology as the intra prediction unit (120) applied to the encoding device described above.
- the motion compensation unit (250) can perform motion compensation using a motion vector and a reference image stored in the reference picture buffer (270) for the current block to generate a prediction block.
- the motion compensation unit (250) can apply an interpolation filter to a part of the reference image to generate a prediction block when the value of the motion vector does not have an integer value.
- the motion compensation unit (250) applied to the decoding device can apply the same technology as the motion compensation unit (122) applied to the encoding device described above.
- the adder (201) can add the restored residual block and the prediction block to generate a restored block.
- the filter unit (260) can apply at least one of an Inverse-LMCS, a deblocking filter, a sample adaptive offset, and an adaptive loop filter to the restored block or the restored image.
- the filter unit (260) applied to the decoding device can apply the same filtering technology as that applied to the filter unit (180) applied to the encoding device described above.
- the filter unit (260) can output a restored image.
- the restored block or restored image can be stored in the reference picture buffer (270) and used for inter prediction.
- the restored block that has passed through the filter unit (260) can be a part of the reference image.
- the reference image can be a restored image composed of restored blocks that have passed through the filter unit (260).
- the stored reference image can be used for inter-screen prediction or motion compensation thereafter.
- FIG. 3 is a diagram schematically showing a video coding system to which the present invention can be applied.
- a video coding system may include an encoding device (10) and a decoding device (20).
- the encoding device (10) may transmit encoded video and/or image information or data to the decoding device (20) in the form of a file or streaming through a digital storage medium or a network.
- An encoding device (10) may include a video source generating unit (11), an encoding unit (12), and a transmitting unit (13).
- a decoding device (20) may include a receiving unit (21), a decoding unit (22), and a rendering unit (23).
- the encoding unit (12) may be called a video/image encoding unit, and the decoding unit (22) may be called a video/image decoding unit.
- the transmitting unit (13) may be included in the encoding unit (12).
- the receiving unit (21) may be included in the decoding unit (22).
- the rendering unit (23) may include a display unit, and the display unit may be configured as a separate device or an external component.
- the video source generation unit (11) can obtain a video/image through a process of capturing, synthesizing, or generating a video/image.
- the video source generation unit (11) can include a video/image capture device and/or a video/image generation device.
- the video/image capture device can include, for example, one or more cameras, a video/image archive including previously captured video/image, etc.
- the video/image generation device can include, for example, a computer, a tablet, a smartphone, etc., and can (electronically) generate a video/image.
- a virtual video/image can be generated through a computer, etc., and in this case, the video/image capture process can be replaced with a process of generating related data.
- the encoding unit (12) can encode the input video/image.
- the encoding unit (12) can perform a series of procedures such as prediction, transformation, and quantization for compression and encoding efficiency.
- the encoding unit (12) can output encoded data (encoded video/image information) in the form of a bitstream.
- the detailed configuration of the encoding unit (12) can also be configured in the same manner as the encoding device (100) of FIG. 1 described above.
- the transmission unit (13) can transmit encoded video/image information or data output in the form of a bitstream to the reception unit (21) of the decoding device (20) through a digital storage medium or a network in the form of a file or streaming.
- the digital storage medium can include various storage media such as USB, SD, CD, DVD, Blu-ray, HDD, SSD, etc.
- the transmission unit (13) can include an element for generating a media file through a predetermined file format and can include an element for transmission through a broadcasting/communication network.
- the reception unit (21) can extract/receive the bitstream from the storage medium or the network and transmit it to the decoding unit (22).
- the decoding unit (22) can decode video/image by performing a series of procedures such as inverse quantization, inverse transformation, and prediction corresponding to the operation of the encoding unit (12).
- the detailed configuration of the decoding unit (22) can also be configured in the same manner as the decoding device (200) of FIG. 2 described above.
- the rendering unit (23) can render the decrypted video/image.
- the rendered video/image can be displayed through the display unit.
- the present disclosure describes a method for improving an intra-prediction mode by correcting an intra-prediction mode determined in intra-prediction, in order to improve the prediction accuracy of intra-prediction.
- a decoder may select a candidate intra-prediction mode having the highest prediction accuracy among a plurality of candidate intra-prediction modes based on a template.
- the decoder may select one of the plurality of candidate intra-prediction modes based on information transmitted from an encoder.
- the prediction accuracy of intra-prediction can be improved.
- DIMR decoder side intra prediction mode refinement
- FIG. 4 shows a template-based intra mode derivation (TIMD) method.
- Fig. 4 shows a template (402) of a current block (400) of a size MxN and reference pixels (404) of the template used for generating a prediction value of pixels of the template (402).
- the template (402) of the current block includes at least one of a left area and an upper area of the current block (400) and is restored prior to the current block (400).
- the left area has a size L1xN
- the upper area consists of an upper template of a size MxL2.
- M, N, L1, and L2 are arbitrary positive integers.
- the suitability for each candidate mode in the MPM (most probable mode) list of the current block (400) is calculated.
- a prediction value of the template is generated from a reference pixel of the template based on the directionality of the candidate mode.
- the sum of absolute transformed differences (SATD) between the prediction value and the restored value of the pixel of the template is calculated.
- the candidate mode with the smallest sum of absolute transformed differences is selected as the on-screen prediction mode.
- the intra-screen prediction mode can be selected from among the prediction modes within the entire screen.
- the intra-screen prediction mode can be selected from among any intra-screen prediction modes.
- an initial intra prediction mode is determined. Then, the initial intra prediction mode is corrected by a template-based intra prediction mode derivation method. Specifically, among candidate intra prediction modes including adjacent candidate modes of the initial intra prediction mode, an optimal candidate mode is selected by the template-based intra prediction mode derivation method. Then, the optimal candidate mode is determined as the final intra prediction mode.
- DIMR decoder side intra prediction mode refinement
- the candidate intra-picture prediction modes may include an initial intra-picture prediction mode and adjacent candidate modes of the initial intra-picture prediction mode. This is because, without data acquired on a block-by-block basis, the decoder must determine whether the initial intra-picture prediction mode has lower distortion than all adjacent candidate modes.
- the candidate intra-picture prediction modes may only include adjacent candidate modes of the initial intra-picture prediction mode. This is because, if the encoder determines that the initial intra-picture prediction mode of the current block has the lowest distortion, the block-by-block syntax element encoded by the encoder will be encoded to indicate that the intra-picture prediction mode improvement on the decoding side is unnecessary.
- the adjacent candidate modes of the prediction mode within the initial screen can have a prediction direction between the prediction direction of the first adjacent intra-screen prediction mode having an index that is 1 less than the index of the prediction mode within the initial screen and the prediction direction of the prediction mode within the initial screen.
- the adjacent candidate modes of the prediction mode within the initial screen can include S intra-screen prediction modes whose prediction directions are between the prediction direction of the first adjacent intra-screen prediction mode and the prediction direction of the prediction mode within the initial screen.
- S intra-screen prediction modes having a prediction direction between the prediction direction of the prediction mode within screen 33, which is the first adjacent intra-screen prediction mode, and the prediction direction of the prediction mode within screen 34, which is the initial intra-screen prediction mode can be included as the adjacent candidate modes.
- the S is an arbitrary positive integer greater than or equal to 1.
- the adjacent candidate modes of the prediction mode within the initial screen can have a prediction direction between a prediction direction of a second adjacent intra-screen prediction mode having an index that is 1 greater than the index of the prediction mode within the initial screen and the prediction direction of the prediction mode within the initial screen.
- the adjacent candidate modes of the prediction mode within the initial screen can include S intra-screen prediction modes whose prediction directions are between the prediction direction of the second adjacent intra-screen prediction mode and the prediction direction of the prediction mode within the initial screen.
- S intra-screen prediction modes having a prediction direction between the prediction direction of the prediction mode within screen 34, which is the initial intra-screen prediction mode, and the prediction direction of the prediction mode within screen 35, which is the second adjacent intra-screen prediction mode can be included as the adjacent candidate modes.
- the S is an arbitrary positive integer greater than or equal to 1.
- Fig. 5 illustrates one embodiment of a method for determining adjacent candidate modes of a prediction mode within an initial screen.
- the prediction mode within the initial screen is mode 63
- the prediction mode within the first adjacent screen and the prediction mode within the second adjacent screen are mode 62 and mode 64.
- the adjacent candidate modes may include a prediction mode 63-1/2 mode which is between the prediction direction of the 62nd mode and the 63rd mode and a prediction mode 63+1/2 mode which is between the prediction direction of the 63rd mode and the 64th mode.
- an intra-screen prediction mode having a smallest distortion value among the 63rd mode, the 63-1/2 mode, and the 63+1/2 mode may be determined as the intra-screen prediction mode of the current block.
- Fig. 6 illustrates another embodiment of a method for determining adjacent candidate modes of a prediction mode within an initial screen.
- the prediction mode within the initial screen is mode 63
- the prediction mode within the first adjacent screen and the prediction mode within the second adjacent screen are mode 62 and mode 64.
- the adjacent candidate modes may include prediction modes 63-1/3 mode and 63-2/3 mode between the prediction direction of mode 62 and the prediction direction of mode 63, and prediction modes 63+1/3 mode and 63+2/3 mode between the prediction direction of mode 63 and the prediction direction of mode 64.
- an intra-screen prediction mode having a smallest distortion value among the 63 mode, the 63-1/3 mode, the 63-2/3 mode, the 63+1/3 mode, and the 63+2/3 mode may be determined as the intra-screen prediction mode of the current block.
- the number of adjacent candidate modes in Fig. 5 is 2 in total, and the number of adjacent candidate modes in Fig. 6 is 4 in total.
- the number of adjacent candidate modes can be increased considering the computational burden of the decoder.
- the adjacent candidate mode is selected based on the encoded adjacent candidate mode information in the encoder instead of selecting the adjacent candidate mode based on the distortion in the decoder, the computational burden of the decoder for calculating the distortion of the adjacent candidate mode is not increased even if the number of adjacent candidate modes increases. Therefore, if the adjacent candidate mode is selected based on the adjacent candidate mode information, more adjacent candidate modes can be used to improve the prediction mode within the screen.
- Fig. 7 illustrates one embodiment of a method for determining adjacent candidate modes of an initial intra-screen prediction mode when the initial intra-screen prediction mode is the intra-screen prediction mode with the smallest index among directional modes in a given range.
- the initial intra-screen prediction mode with the smallest index among directional modes in a given range is mode 2.
- the adjacent candidate modes may include a 2+1/2 mode whose prediction direction is between the prediction direction of the 2nd mode and the 3rd mode. And based on the template-based intra-screen mode derivation method, the intra-screen prediction mode having the smallest distortion value among the 2nd mode and the 2+1/2 mode may be determined as the intra-screen prediction mode of the current block.
- Fig. 8 illustrates another embodiment of a method for determining adjacent candidate modes of an initial intra-screen prediction mode when the initial intra-screen prediction mode is the intra-screen prediction mode with the smallest index among directional modes in a given range.
- the initial intra-screen prediction mode with the smallest index among directional modes in a given range is mode 2.
- the adjacent candidate modes may include mode 2+1/3 and mode 2+2/3, whose prediction directions are between the prediction directions of mode 2 and mode 3. And based on the template-based intra-screen mode derivation method, an intra-screen prediction mode having the smallest distortion value among mode 2, mode 2+1/3, and mode 2+2/3 may be determined as the intra-screen prediction mode of the current block.
- the smallest index among the directional modes is depicted as mode 2, but this is only an example, and the smallest index among the directional modes may be a different value.
- the number of adjacent candidate modes may be increased considering the computational burden of the decoder.
- the computational burden of the decoder decreases, and more adjacent candidate modes can be used to improve the prediction mode within the screen.
- Fig. 9 illustrates one embodiment of a method for determining adjacent candidate modes of an initial intra-screen prediction mode when the initial intra-screen prediction mode is the intra-screen prediction mode with the largest index among directional modes in a given range.
- the initial intra-screen prediction mode with the largest index among directional modes in a given range is mode 66.
- the adjacent candidate modes may include the 66-1/2 mode, whose prediction direction is between the prediction direction of the 65th mode and the prediction direction of the 66th mode. And based on the template-based intra-screen mode derivation method, the intra-screen prediction mode having the smallest distortion value among the 66-1/2 mode and the 66th mode may be determined as the intra-screen prediction mode of the current block.
- Fig. 10 illustrates another embodiment of a method for determining adjacent candidate modes of an initial intra-screen prediction mode when the initial intra-screen prediction mode is the intra-screen prediction mode with the largest index among directional modes in a given range.
- the initial intra-screen prediction mode with the largest index among directional modes in a given range is mode 66.
- the adjacent candidate modes may include the 66-1/3 mode and the 66-2/3 mode, the prediction directions of which are between the prediction directions of the 65 mode and the 66 mode. Then, based on the template-based intra-screen mode derivation method, the intra-screen prediction mode having the smallest distortion value among the 66-1/3 mode, the 66-2/3 mode, and the 66 mode may be determined as the intra-screen prediction mode of the current block.
- the largest index among the directional modes is depicted as mode 66, but this is only an example, and the largest index among the directional modes may be determined to a different value in consideration of the number of prediction modes within the entire screen.
- the number of adjacent candidate modes may be increased in consideration of the computational burden of the decoder.
- the computational burden of the decoder decreases, and more adjacent candidate modes can be used to improve the prediction mode within the screen.
- one or two intra-screen prediction modes are included as adjacent candidate modes in each index direction of the prediction mode within the initial screen.
- S intra-screen prediction modes may be included as adjacent candidate modes in each index direction of the prediction mode within the initial screen.
- S is any positive integer greater than or equal to 3.
- the adjacent candidate mode is determined by equally dividing the difference in the prediction direction between the prediction mode in the initial screen and the prediction mode in the adjacent screen.
- the adjacent candidate mode may be determined by unequally dividing the difference in the prediction direction.
- the adjacent candidate mode may be determined based on an arbitrary direction adjacent to the direction pointed to by the prediction mode in the initial screen.
- the above equal division may mean equal division of the angular difference between the prediction direction of the prediction mode in the initial screen and the prediction mode in the adjacent screen.
- the above equal division may mean equal division of the positional difference between the reference positions indicated by the prediction direction of the prediction mode in the initial screen and the prediction mode in the adjacent screen.
- the adjacent candidate mode is determined based on the prediction mode in the adjacent screen immediately adjacent to the prediction mode in the initial screen.
- the adjacent candidate mode may be determined based on the prediction mode in the adjacent screen having an index difference of A from the prediction mode in the initial screen. For example, if the prediction mode in the initial screen is 32 and A is 2, the prediction mode in the first adjacent screen may be determined as 30, and the prediction mode in the second adjacent screen may be determined as 34.
- multiple intra-screen prediction modes having index values between 30 and 34 may be included in the adjacent candidate mode.
- A is any positive integer greater than or equal to 1.
- the method of improving the prediction mode in the decryption side screen can be determined whether to be applied based on the following conditions.
- the method for improving the intra-screen prediction mode on the decoding side may not be applied to the current block.
- whether to apply the prediction mode improvement method on the decoding side within the picture may be determined depending on the size of the current block. For example, if the width of the current block is less than or equal to M luminance samples (M is an arbitrary positive integer greater than or equal to 1), the prediction mode improvement method on the decoding side within the picture may not be applied to the current block.
- the width of the current block may be measured by the number of luminance samples included in the current block.
- K is an arbitrary positive integer greater than or equal to 1
- the prediction mode improvement method on the decoding side within the picture may not be applied to the current block.
- the aspect ratio (width/height or height/width) of the current block is included in a predetermined range, the prediction mode improvement method on the decoding side within the picture may not be applied to the current block.
- the decoding-side Intra prediction mode improvement method may not be applied to the current block.
- the prediction mode improvement method within the decoding-side screen may not be applied to the current block.
- the T value and the U value may be determined according to the number of prediction modes within the entire screen.
- the intra-screen prediction mode of the reference block is referred to.
- the initial intra-screen prediction mode instead of the final intra-screen prediction mode of the reference block, can be used for generating the MPM list and determining the direct mode of the chrominance component.
- the computational burden on the decoder side may increase in calculating the distortion of the adjacent candidate mode. Therefore, instead of the decoder calculating the distortion of the adjacent candidate mode, the encoder can encode intra prediction mode refinement information for the adjacent candidate mode applied to the current block. Then, the decoder can determine the optimal adjacent candidate mode for the encoder-side intra prediction mode refinement (EIMR) based on the intra prediction mode refinement information.
- EIMR encoder-side intra prediction mode refinement
- the intra-screen prediction mode improvement information may include intra-screen prediction mode improvement application information indicating whether intra-screen prediction mode improvement is applied and intra-screen prediction mode improvement index information indicating an optimal adjacent candidate mode among adjacent candidate modes.
- intra-screen prediction mode improvement application information indicates that the current block or an upper unit (encoding tree block, slice, tile, picture, etc.) of the current block is applied
- the optimal candidate intra-screen prediction mode may be selected as the final intra-screen prediction mode of the current block based on the intra-screen prediction mode improvement index information.
- the intra-screen prediction mode improvement application information indicates that the current block or an upper unit of the current block is not applied
- the initial intra-screen prediction mode may be selected as the final intra-screen prediction mode of the current block.
- the initial prediction mode within the screen is also included in the candidate prediction mode within the screen.
- the initial prediction mode within the screen is excluded from the candidate prediction mode within the screen.
- the above intra-screen prediction mode improvement application information can be encoded as a 1-bit codeword.
- the intra-screen prediction mode improvement index information represents optimal candidate intra-screen prediction modes among candidate intra-screen prediction modes.
- the optimal candidate intra-screen prediction mode is mapped to a predetermined index in consideration of the number of adjacent candidate modes. For example, when there are four adjacent candidate modes, the optimal adjacent candidate mode is mapped to one of values 0 to 3.
- the intra-screen prediction mode improvement index information is set to represent the mapped value.
- the intra-screen prediction mode improvement index information can be encoded based on a fixed length code (FLC), a truncated unary code (TU), a signed Exp-Golomb code, or the like.
- the above-described intra-screen prediction mode improvement index information can be encoded by considering the occurrence frequency of adjacent candidate modes. Specifically, a short codeword can be matched to an adjacent candidate mode with a high occurrence frequency, and a long codeword can be matched to an adjacent candidate mode with a low occurrence frequency.
- the occurrence frequency of adjacent candidate modes can differ depending on the index difference with respect to the intra-screen prediction mode. For example, the occurrence frequency of an adjacent candidate mode having the smallest absolute value of index difference with respect to the intra-screen prediction mode can be the highest. Accordingly, a short codeword can be matched to an adjacent candidate mode having the smallest absolute value of index difference with respect to the intra-screen prediction mode.
- a long codeword can be matched to an adjacent candidate mode having the largest absolute value of index difference with respect to the intra-screen prediction mode.
- the intra-screen prediction mode improvement index information may include intra-screen prediction mode improvement sign information and intra-screen prediction mode improvement index difference information.
- the intra-screen prediction mode improvement sign information indicates which direction the optimal candidate intra-screen prediction mode is in among the + direction and the - direction from the initial intra-screen prediction mode.
- the intra-screen prediction mode improvement index difference information indicates the index difference between the optimal candidate intra-screen prediction mode and the initial intra-screen prediction mode.
- the above intra-screen prediction mode improvement code information can be encoded as a 1-bit codeword. If the initial intra-screen prediction mode is the intra-screen prediction mode of the smallest index or the intra-screen prediction mode of the largest index among the directional modes of a predetermined range, the intra-screen prediction mode improvement code information is not encoded, and only the intra-screen prediction mode improvement index difference information can be encoded.
- the intra-picture prediction mode improvement index difference information may not be encoded. If there are two or more adjacent candidate modes in each direction, the intra-picture prediction mode improvement index difference information may be encoded based on a fixed length code (FLC), a truncated unary code (TU), a signed Exp-Golomb code, etc.
- FLC fixed length code
- TU truncated unary code
- Exp-Golomb code signed Exp-Golomb code
- the improved index difference information of the prediction mode within the above screen can be encoded by considering the occurrence frequency of the adjacent candidate mode.
- the occurrence frequency of the adjacent candidate mode can differ depending on the index difference with the prediction mode within the initial screen. For example, the occurrence frequency of the adjacent candidate mode having the smallest absolute value of the index difference with the prediction mode within the initial screen can be the highest. Accordingly, a short codeword can be matched with respect to the index of the adjacent candidate mode having the smallest absolute value of the index difference with the prediction mode within the initial screen. In addition, a long codeword can be matched with respect to the index of the adjacent candidate mode having the largest absolute value of the index difference with the prediction mode within the initial screen.
- Fig. 11 illustrates an embodiment of an intra-screen prediction method to which intra-screen prediction mode improvement is applied.
- an initial intra-screen prediction mode of a current block is determined.
- the initial intra-screen prediction mode of the current block can be determined with reference to an intra-screen prediction mode of a reference block. If intra-screen prediction improvement is applied to a reference block of the current block, the initial intra-screen prediction mode of the current block can be determined based on the initial intra-screen prediction mode of the reference block.
- the reference block can be a block referenced when determining an MPM (Most Probable Mode) or DM (Direct Mode) of the current block.
- MPM Motion Probable Mode
- DM Direct Mode
- the reference block can be a spatially adjacent block of the current block.
- the reference block In determining the DM of the current block of the chroma component, the reference block can be a corresponding block of a luma component at a position corresponding to the current block.
- step 1104 based on the prediction mode within the initial screen of the current block, one or more adjacent candidate modes adjacent to the prediction mode within the initial screen are determined.
- the one or more adjacent candidate modes may include a first adjacent candidate mode having a prediction direction between a prediction direction of a prediction mode in a first adjacent picture of the current block and a prediction direction of a prediction mode in the initial picture, and a second adjacent candidate mode having a prediction direction between a prediction direction of a prediction mode in a second adjacent picture of the current block and a prediction direction of the prediction mode in the initial picture.
- the first adjacent picture prediction mode has an index that is smaller than an index of the prediction mode in the initial picture by a predetermined value
- the second adjacent picture prediction mode has an index that is larger than an index of the prediction mode in the initial picture by a predetermined value.
- the first adjacent candidate mode is determined by evenly dividing the directional difference between the prediction direction of the prediction mode in the first adjacent screen of the current block and the prediction direction of the prediction mode in the initial screen according to the number of first adjacent candidate modes. That is, the directional difference between the first adjacent candidate modes and the directional difference between the first adjacent candidate mode and the prediction mode in the initial screen are determined evenly.
- the second adjacent candidate mode is determined by evenly dividing the difference in direction between the prediction direction of the prediction mode in the second adjacent screen of the current block and the prediction direction of the prediction mode in the initial screen according to the number of second adjacent candidate modes. That is, the difference in direction between the second adjacent candidate modes and the difference in direction between the second adjacent candidate mode and the prediction mode in the initial screen are determined evenly.
- the one or more adjacent candidate modes may include only the second intra-screen prediction mode. Conversely, if the initial intra-screen prediction mode is an intra-screen prediction mode with a largest index among the directional modes in the given range, the one or more adjacent candidate modes may include only the first intra-screen prediction mode.
- a final within-picture prediction mode of the current block is determined among the candidate within-picture prediction modes including one or more adjacent candidate modes.
- a mode having the smallest distortion among the candidate screen prediction modes of the current block may be determined as the final screen prediction mode of the current block.
- the distortion of the candidate screen prediction mode may be determined based on a difference between a restoration sample included in a template adjacent to the current block and a prediction sample corresponding to the restoration sample.
- the prediction sample may be determined based on a template reference sample adjacent to the template and a prediction direction of the candidate screen prediction mode.
- intra-picture prediction mode improvement index information indicating a final intra-picture prediction mode of the current block among candidate intra-picture prediction modes of the current block can be obtained from a bitstream. Then, a final intra-picture prediction mode of the current block can be determined based on the intra-picture prediction mode improvement index information.
- the intra-screen prediction mode improvement index information may include intra-screen prediction mode improvement sign information indicating in which direction the final intra-screen prediction mode is in the + direction or - direction from the initial intra-screen prediction mode, and intra-screen prediction mode improvement index difference information indicating an index difference between the final intra-screen prediction mode and the initial intra-screen prediction mode. Accordingly, the final intra-screen prediction mode of the current block can be derived according to the sign according to the intra-screen prediction mode improvement index sign information and the index difference according to the intra-screen prediction mode improvement index difference information.
- a codeword of a predetermined length is assigned to each symbol of an index difference indicated by the improved index difference information of the prediction mode within the screen.
- the length of the codeword assigned to the prediction mode within the candidate screen can be determined based on the index difference between the prediction mode within the initial screen and the prediction mode within the candidate screen. For example, a codeword of a short length can be assigned to a symbol of a small index difference.
- the current block is predicted based on the final on-screen prediction mode of the current block.
- the video decoding method may further include a step of determining whether intra-picture prediction improvement is performed on the current block. If intra-picture prediction improvement is performed on the current block, steps 1104 to 1108 may be performed. If intra-picture prediction improvement is not performed on the current block, steps 1104 to 1108 may be omitted, and the current block may be predicted based on an initial intra-picture prediction mode of the current block.
- the initial intra-screen prediction mode is a non-directional intra-screen prediction mode, it may be determined that intra-screen prediction improvement is not to be performed on the current block.
- an index of a prediction mode within the initial screen is not within a given range, it may be determined that no prediction improvement within the screen is to be performed on the current block.
- whether in-screen prediction improvement is performed on a current block may be determined based on at least one of a width, a height, an area, and an aspect ratio of the current block.
- the current block can be encoded or decoded.
- the intra-screen prediction mode improvement index information is encoded in the encoder according to the prediction result.
- the intra-screen prediction mode improvement index information is decoded in the decoder and can be used to derive the final intra-screen prediction mode.
- bitstream generated by the encoder according to the prediction method performed in steps 1102 to 1108 can be stored in a recording medium or transmitted outside the encoder.
- FIG. 12 is a drawing exemplarily showing a content streaming system to which an embodiment according to the present invention can be applied.
- a content streaming system to which an embodiment of the present invention is applied may largely include an encoding server, a streaming server, a web server, a media storage, a user device, and a multimedia input device.
- the encoding server compresses content input from multimedia input devices such as smartphones, cameras, CCTVs, etc. into digital data to generate a bitstream and transmits it to the streaming server.
- multimedia input devices such as smartphones, cameras, CCTVs, etc. directly generate a bitstream
- the encoding server may be omitted.
- the above bitstream can be generated by an image encoding method and/or an image encoding device to which an embodiment of the present invention is applied, and the streaming server can temporarily store the bitstream during the process of transmitting or receiving the bitstream.
- the above streaming server transmits multimedia data to a user device based on a user request via a web server, and the web server can act as an intermediary that informs the user of any available services.
- the web server transmits it to the streaming server, and the streaming server can transmit multimedia data to the user.
- the content streaming system may include a separate control server, and in this case, the control server may perform a role of controlling commands/responses between each device within the content streaming system.
- the above streaming server can receive content from a media storage and/or an encoding server. For example, when receiving content from the encoding server, the content can be received in real time. In this case, in order to provide a smooth streaming service, the streaming server can store the bitstream for a certain period of time.
- Examples of the user devices may include mobile phones, smart phones, laptop computers, digital broadcasting terminals, personal digital assistants (PDAs), portable multimedia players (PMPs), navigation devices, slate PCs, tablet PCs, ultrabooks, wearable devices (e.g., smartwatches, smart glasses, HMDs (head mounted displays)), digital TVs, desktop computers, digital signage, etc.
- PDAs personal digital assistants
- PMPs portable multimedia players
- navigation devices slate PCs
- tablet PCs tablet PCs
- ultrabooks ultrabooks
- wearable devices e.g., smartwatches, smart glasses, HMDs (head mounted displays)
- digital TVs desktop computers, digital signage, etc.
- Each server within the above content streaming system can be operated as a distributed server, in which case data received from each server can be processed in a distributed manner.
- an image can be encoded/decoded using at least one or a combination of at least one of the above embodiments.
- the order in which the above embodiments are applied may be different in the encoding device and the decoding device. Alternatively, the order in which the above embodiments are applied may be the same in the encoding device and the decoding device.
- the above embodiments can be performed for each of the luminance and chrominance signals, or the above embodiments can be performed identically for the luminance and chrominance signals.
- the methods are described based on the flowchart as a series of steps or units, but the present invention is not limited to the order of the steps, and some steps may occur in a different order or simultaneously with other steps described above.
- the steps shown in the flowchart are not exclusive, and other steps may be included, or one or more steps in the flowchart may be deleted without affecting the scope of the present invention.
- the above embodiments may be implemented in the form of program commands that can be executed through various computer components and recorded on a computer-readable recording medium.
- the computer-readable recording medium may include program commands, data files, data structures, etc., alone or in combination.
- the program commands recorded on the computer-readable recording medium may be those specifically designed and configured for the present invention or may be those known to and available to those skilled in the art of computer software.
- a bitstream generated by an encoding method according to the above embodiment can be stored in a non-transitory computer-readable recording medium.
- the bitstream stored in the non-transitory computer-readable recording medium can be decoded by a decoding method according to the above embodiment.
- examples of computer-readable recording media include magnetic media such as hard disks, floppy disks, and magnetic tapes, optical recording media such as CD-ROMs and DVDs, magneto-optical media such as floptical disks, and hardware devices specifically configured to store and execute program instructions such as ROMs, RAMs, and flash memories.
- Examples of program instructions include not only machine language codes generated by a compiler, but also high-level language codes that can be executed by a computer using an interpreter, etc.
- the hardware devices may be configured to operate as one or more software modules to perform the processing according to the present invention, and vice versa.
- the present invention can be used in a device for encoding/decoding an image and a recording medium storing a bitstream.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
본 발명에서, 영상 복호화 방법에 있어서, 현재 블록의 초기 화면 내 예측 모드를 결정하는 단계, 현재 블록의 초기 화면 내 예측 모드에 기초하여, 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계, 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계, 및 현재 블록의 최종 화면 내 예측 모드에 기초하여 현재 블록을 예측하는 단계를 포함하는 영상 복호화 방법이 제공된다.
Description
본 발명은 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체에 관한 것이다. 구체적으로, 본 발명은 화면 내 예측 방법을 이용한 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체에 관한 것이다.
최근 UHD(Ultra High Definition) 영상과 같은 고해상도, 고품질의 영상에 대한 수요가 다양한 응용 분야에서 증가하고 있다. 영상 데이터가 고해상도, 고품질이 될수록 기존의 영상 데이터에 비해 상대적으로 데이터량이 증가하기 때문에 기존의 유무선 광대역 회선과 같은 매체를 이용하여 영상 데이터를 전송하거나 기존의 저장 매체를 이용해 저장하는 경우, 전송 비용과 저장 비용이 증가하게 된다. 영상 데이터가 고해상도, 고품질화 됨에 따라 발생하는 이러한 문제들을 해결하기 위해서는 더 높은 해상도 및 화질을 갖는 영상에 대한 고효율 영상 부호화(encoding)/복호화(decoding) 기술이 요구된다.
비디오 부호화 및 복호화에서 화면 내 예측(intra prediction)은 현재 픽처의 기 복원된 참조 화소를 사용하여 현재 블록을 예측하는 기술이다. 이 때, 화면 내 예측에 따르면, 기 정해진 비방향성 모드(non-directional mode) 또는 방향성 모드(directional mode)를 기반으로 현재 블록의 주변 이웃하는 참조 화소로부터 예측 블록이 생성된다. 화면 내 예측은 화면 간 예측에 비하여 예측 정확도가 낮을 가능성이 있으며, 이로 인하여 부호화 효율에 한계가 있을 수 있다. 따라서, 화면 내 예측의 예측 정확도를 향상시키 위한 다양한 방법이 논의되고 있다.
본 발명은 부호화/복호화 효율이 향상된 영상 부호화/복호화 방법 및 장치를 제공하는 것을 목적으로 한다.
또한, 본 발명은 본 발명에서 제공된 영상 복호화 방법 또는 장치에 의해 생성된 비트스트림을 저장한 기록 매체를 제공하는 것을 목적으로 한다.
본 발명의 일 실시예에 따른 영상 복호화 방법은, 현재 블록의 초기 화면 내 예측 모드를 결정하는 단계, 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계, 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계, 및 현재 블록의 최종 화면 내 예측 모드에 기초하여 현재 블록을 예측하는 단계를 포함할 수 있다.
일 실시 예에 따르면, 상기 현재 블록에 화면 내 예측 개선이 수행되는지 여부를 결정하는 단계를 더 포함하고, 상기 현재 블록에 화면 내 예측 개선이 수행될 경우, 상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계, 상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계, 및 상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계가 수행되고, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않을 경우, 상기 현재 블록의 초기 화면 내 예측 모드에 기초하여 상기 현재 블록이 예측되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 초기 화면 내 예측 모드가 비방향성 화면 내 예측 모드일 경우, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않는 것으로 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 초기 화면 내 예측 모드의 인덱스가 소정 범위에 포함되지 않은 경우, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않는 것으로 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 현재 블록의 너비, 높이, 넓이, 및 종횡비 중 적어도 하나에 따라, 상기 현재 블록에 화면 내 예측 개선이 수행되는지 여부가 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 현재 블록의 참조 블록에 화면 내 예측 개선이 적용된 경우, 상기 참조 블록의 초기 화면 내 예측 모드에 기초하여, 상기 현재 블록의 초기 화면 내 예측 모드가 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 하나 이상의 인접 후보 모드는, 상기 현재 블록의 제1 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 사이의 예측 방향을 가진 제1 인접 후보 모드, 및 상기 현재 블록의 제2 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 사이의 예측 방향을 가진 제2 인접 후보 모드를 포함하고, 상기 제1 인접 화면 내 예측 모드는, 상기 초기 화면 내 예측 모드의 인덱스보다 소정의 값 만큼 작은 인덱스를 가지고, 상기 제2 인접 화면 내 예측 모드는, 상기 초기 화면 내 예측 모드의 인덱스보다 소정의 값 만큼 큰 인덱스를 가지는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 제1 인접 후보 모드는 상기 현재 블록의 제1 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 방향 차이를 상기 제1 인접 후보 모드의 개수에 따라 균등 분할하여 결정되고, 상기 제2 인접 후보 모드는 상기 현재 블록의 제2 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 방향 차이를 상기 제2 인접 후보 모드의 개수에 따라 균등 분할하여 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 초기 화면 내 예측 모드가 소정 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드인 경우, 상기 하나 이상의 인접 후보 모드는, 상기 제2 인접 화면 내 예측 모드만 포함하고, 상기 초기 화면 내 예측 모드가 소정 범위의 방향성 모드들 중 가장 큰 인덱스의 화면 내 예측 모드인 경우, 상기 하나 이상의 인접 후보 모드는, 상기 제1 인접 화면 내 예측 모드만 포함하는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 현재 블록의 후보 화면 내 예측 모드들 중 왜곡도가 가장 작은 모드가 상기 현재 블록의 최종 화면 내 예측 모드로 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 현재 블록에 인접한 템플릿에 포함된 복원 샘플과 상기 복원 샘플에 대응되는 예측 샘플의 차이에 기초하여 상기 후보 화면 내 예측 모드의 왜곡도가 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 예측 샘플은 상기 템플릿에 인접한 템플릿 참조 샘플 및 상기 후보 화면 내 예측 모드의 예측 방향에 기초하여 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 영상 복호화 방법은, 상기 현재 블록의 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 나타내는 화면 내 예측 모드 개선 인덱스 정보를 비트스트림으로부터 획득하는 단계를 더 포함하고, 상기 현재 블록의 최종 화면 내 예측 모드는 상기 화면 내 예측 모드 개선 인덱스 정보에 기초하여 결정되는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 화면 내 예측 모드 개선 인덱스 정보는, 상기 최종 화면 내 예측 모드가 상기 초기 화면 내 예측 모드로부터 + 방향 및 - 방향 중 어느 방향에 있는지 나타내는 화면 내 예측 모드 개선 부호 정보, 및 상기 최종 화면 내 예측 모드와 상기 초기 화면 내 예측 모드의 인덱스 차이를 나타내는 화면 내 예측 모드 개선 인덱스 차이 정보를 포함하는 것을 특징으로 할 수 있다.
일 실시 예에 따르면, 상기 화면 내 예측 모드 개선 인덱스 차이 정보에 있어서, 상기 초기 화면 내 예측 모드와 상기 후보 화면 내 예측 모드의 인덱스 차이에 기초하여, 상기 후보 화면 내 예측 모드에 할당된 코드워드의 길이가 결정되는 것을 특징으로 할 수 있다.
본 발명의 일 실시예에 따른 영상 부호화 방법은, 현재 블록의 초기 화면 내 예측 모드를 결정하는 단계, 상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계, 상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계, 및 상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계를 포함할 수 있다.
본 발명의 일 실시예에 따른 비 일시적 컴퓨터 판독가능한 기록 매체는, 상기 영상 부호화 방법에 의하여 생성된 비트스트림을 저장한다.
본 발명의 일 실시예에 따른 전송 방법은, 상기 영상 부호화 방법에 의하여 생성된 비트스트림을 전송한다.
본 발명에 대하여 위에서 간략하게 요약된 특징들은 후술하는 본 발명의 상세한 설명의 예시적인 양상일 뿐이며, 본 발명의 범위를 제한하는 것은 아니다.
본 발명은, 복호화측 화면 내 예측 모드 개선에 따른 화면 내 예측 방법의 다양한 실시 예를 제안한다.
또한, 본 발명은, 부호화측 화면 내 예측 모드 개선에 따른 방법의 다양한 실시 예를 제안한다.
상기 다양한 실시 예에 따라, 화면 내 예측 모드의 예측 정확도가 향상됨에 따라, 전체 부호화 효율이 향상될 수 있다.
도 1은 본 발명이 적용되는 부호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다.
도 2는 본 발명이 적용되는 복호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다.
도 3은 본 발명이 적용될 수 있는 비디오 코딩 시스템을 개략적으로 나타내는 도면이다.
도 4는 템플릿 기반 화면 내 모드 유도 (Template-based intra mode derivation, TIMD) 방법을 나타낸다.
도 5 및 도 6은 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 일 실시 예를 나타낸다.
도 7 및 도 8은 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드인 경우, 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 일 실시 예를 나타낸다.
도 9 및 10은 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 큰 인덱스의 화면 내 예측 모드인 경우, 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 일 실시 예를 나타낸다.
도 11은 화면 내 예측 모드 개선이 적용되는 화면 내 예측 방법의 일 실시 예를 나타낸다.
도 12는 본 발명에 따른 실시예가 적용될 수 있는 컨텐츠 스트리밍 시스템을 예시적으로 나타낸다.
본 발명의 일 실시예에 따른 영상 복호화 방법은, 현재 블록의 초기 화면 내 예측 모드를 결정하는 단계, 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계, 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계, 및 현재 블록의 최종 화면 내 예측 모드에 기초하여 현재 블록을 예측하는 단계를 포함할 수 있다.
본 발명은 다양한 변경을 가할 수 있고 여러 가지 실시예를 가질 수 있는 바, 특정 실시예들을 도면에 예시하고 상세한 설명에 상세하게 설명하고자 한다. 그러나, 이는 본 발명을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 발명의 사상 및 기술 범위에 포함되는 모든 변경, 균등물 내지 대체물을 포함하는 것으로 이해되어야 한다. 도면에서 유사한 참조부호는 여러 측면에 걸쳐서 동일하거나 유사한 기능을 지칭한다. 도면에서의 요소들의 형상 및 크기 등은 보다 명확한 설명을 위해 예시적으로 제공될 수 있다. 후술하는 예시적 실시예들에 대한 상세한 설명은, 특정 실시예를 예시로서 도시하는 첨부 도면을 참조한다. 이들 실시예는 당업자가 실시예를 실시할 수 있기에 충분하도록 상세히 설명된다. 다양한 실시예들은 서로 다르지만 상호 배타적일 필요는 없음이 이해되어야 한다. 예를 들어, 여기에 기재되어 있는 특정 형상, 구조 및 특성은 일 실시예에 관련하여 본 발명의 정신 및 범위를 벗어나지 않으면서 다른 실시예로 구현될 수 있다. 또한, 각각의 개시된 실시예 내의 개별 구성요소의 위치 또는 배치는 실시예의 정신 및 범위를 벗어나지 않으면서 변경될 수 있음이 이해되어야 한다. 따라서, 후술하는 상세한 설명은 한정적인 의미로서 취하려는 것이 아니며, 예시적 실시예들의 범위는, 적절하게 설명된다면, 그 청구항들이 주장하는 것과 균등한 모든 범위와 더불어 첨부된 청구항에 의해서만 한정된다.
본 발명에서 제1, 제2 등의 용어는 다양한 구성요소들을 설명하는데 사용될 수 있지만, 상기 구성요소들은 상기 용어들에 의해 한정되어서는 안 된다. 상기 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용된다. 예를 들어, 본 발명의 권리 범위를 벗어나지 않으면서 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소도 제1 구성요소로 명명될 수 있다. 및/또는 이라는 용어는 복수의 관련된 기재된 항목들의 조합 또는 복수의 관련된 기재된 항목들 중의 어느 항목을 포함한다.
본 발명의 실시예에 나타나는 구성부들은 서로 다른 특징적인 기능들을 나타내기 위해 독립적으로 도시되는 것으로, 각 구성부들이 분리된 하드웨어나 하나의 소프트웨어 구성단위로 이루어짐을 의미하지 않는다. 즉, 각 구성부는 설명의 편의상 각각의 구성부로 나열하여 포함한 것으로 각 구성부 중 적어도 두 개의 구성부가 합쳐져 하나의 구성부로 이루어지거나, 하나의 구성부가 복수 개의 구성부로 나뉘어져 기능을 수행할 수 있고 이러한 각 구성부의 통합된 실시예 및 분리된 실시예도 본 발명의 본질에서 벗어나지 않는 한 본 발명의 권리범위에 포함된다.
본 발명에서 사용한 용어는 단지 특정한 실시예를 설명하기 위해 사용된 것으로, 본 발명을 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 또한, 본 발명의 일부의 구성 요소는 본 발명에서 본질적인 기능을 수행하는 필수적인 구성 요소는 아니고 단지 성능을 향상시키기 위한 선택적 구성 요소일 수 있다. 본 발명은 단지 성능 향상을 위해 사용되는 구성 요소를 제외한 본 발명의 본질을 구현하는데 필수적인 구성부만을 포함하여 구현될 수 있고, 단지 성능 향상을 위해 사용되는 선택적 구성 요소를 제외한 필수 구성 요소만을 포함한 구조도 본 발명의 권리범위에 포함된다.
실시예에서 용어 "적어도 하나(at least one)"는 1, 2, 3 및 4와 같은 1 이상의 개수들 중 하나를 의미할 수 있다. 실시예에서 용어 "복수(a plurality of)"는 2, 3 및 4와 같은 2 이상의 개수들 중 하나를 의미할 수 있다.
이하, 도면을 참조하여 본 발명의 실시 형태에 대하여 구체적으로 설명한다. 본 명세서의 실시예를 설명함에 있어, 관련된 공지 구성 또는 기능에 대한 구체적인 설명이 본 명세서의 요지를 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명은 생략하고, 도면상의 동일한 구성요소에 대해서는 동일한 참조부호를 사용하고 동일한 구성요소에 대해서 중복된 설명은 생략한다.
용어 설명
이하에서, “영상”은 동영상(video)을 구성하는 하나의 픽처(picture)를 의미할 수 있으며, 동영상 자체를 나타낼 수도 있다. 예를 들면, "영상의 부호화 및/또는 복호화"는 "동영상의 부호화 및/또는 복호화"를 의미할 수 있으며, "동영상을 구성하는 영상들 중 하나의 영상의 부호화 및/또는 복호화"를 의미할 수도 있다.
이하에서, "동영상" 및 "비디오"는 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다. 또한, 대상 영상은 부호화의 대상인 부호화 대상 영상 및/또는 복호화의 대상인 복호화 대상 영상일 수 있다. 또한, 대상 영상은 부호화 장치로 입력된 입력 영상일 수 있고, 복호화 장치로 입력된 입력 영상일 수 있다. 여기서, 대상 영상은 현재 영상과 동일한 의미를 가질 수 있다.
이하에서, "영상(image)", "픽처(picture)", "프레임(frame)" 및 "스크린(screen)"은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.
이하에서, “대상 블록”은 부호화의 대상인 부호화 대상 블록 및/또는 복호화의 대상인 복호화 대상 블록일 수 있다. 또한, 대상 블록은 현재 부호화 및/또는 복호화의 대상인 현재 블록일 수 있다. 예를 들면, "대상 블록" 및 "현재 블록"은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.
이하에서, "블록" 및 "유닛"은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다. 또한, “유닛”은 블록과 구분하여 지칭하기 위해 휘도(Luma) 성분 블록과 그에 대응하는 색차(Chroma) 성분 블록을 포함한 것을 의미할 수 있다. 일 예로, 부호화 트리 유닛(Coding Tree Unit, CTU)은 하나의 휘도 성분(Y) 부호화 트리 블록(Coding Tree Block, CTB)과 관련된 두 색차 성분(Cb, Cr) 부호화 트리 블록들로 구성될 수 있다.
이하에서, “샘플”, “픽셀” 및 “픽셀”은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다. 여기서, 샘플은 블록을 구성하는 기본 단위를 나타낼 수 있다.
이하에서, “인터” 및 “화면 간”은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.
이하에서, “인트라” 및 “화면 내”는 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.
도 1은 본 발명이 적용되는 부호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다.
부호화 장치(100)는 인코더, 비디오 부호화 장치 또는 영상 부호화 장치일 수 있다. 비디오는 하나 이상의 영상들을 포함할 수 있다. 부호화 장치(100)는 하나 이상의 영상들을 순차적으로 부호화할 수 있다.
도 1을 참조하면, 부호화 장치(100)는 영상 분할부(110), 인트라 예측부(120), 움직임 예측부(121), 움직임 보상부(122), 스위치(115), 감산기(113), 변환부(130), 양자화부(140), 엔트로피 부호화부(150), 역양자화부(160), 역변환부(170), 가산기(117), 필터부(180) 및 참조 픽처 버퍼(190)를 포함할 수 있다.
또한, 부호화 장치(100)는 입력 영상에 대한 부호화를 통해 부호화된 정보를 포함하는 비트스트림을 생성할 수 있고, 생성된 비트스트림을 출력할 수 있다. 생성된 비트스트림은 컴퓨터 판독가능한 기록 매체에 저장될 수 있거나, 유/무선 전송 매체를 통해 스트리밍될 수 있다.
영상 분할부(110)는 동영상 부호화/복호화의 효율을 높이기 위해, 입력 영상을 다양한 형태로 분할할 수 있다. 즉, 입력 동영상은 다수의 픽처로 구성되어 있고 하나의 픽처는 압축 효율, 병렬처리 등을 위하여 계층적으로 분할되어 처리될 수 있다. 예를 들어, 하나의 픽처를 하나 또는 다수개의 타일(tile) 또는 슬라이스(slice)로 분할하고 다시 다수개의 CTU (Coding Tree Unit)로 분할할 수 있다. 또 다른 방식으로, 먼저 하나의 픽처를 직사각형 모양의 슬라이스의 그룹으로 정의되는 다수개의 서브픽처(sub-picture)로 분할하고, 각 서브픽처를 상기 타일/슬라이스로 분할할 수도 있다. 여기서, 서브픽처는 픽처를 부분적으로 독립 부호화/복호화 및 전송하는 기능을 지원하기 위하여 활용될 수 있다. 여러 개의 서브픽처는 각각 개별적으로 복원 가능하기에 멀티 채널 입력을 하나의 픽처로 구성하는 응용에 있어서 편집이 용이하다는 장점을 가지게 된다. 또한, 타일을 횡방향으로 분할하여 브릭(brick)을 생성할 수도 있다. 여기서, 브릭(brick)은 픽처 내 병렬처리의 기본 단위로 활용할 수 있다. 또한, 하나의 CTU는 쿼드 트리(QT: Quadtree)로 재귀적으로 분할될 수 있고, 분할의 말단 노드를 CU (Coding Unit)라고 정의할 수 있다. CU는 예측 단위인 PU(Prediction Unit)와 변환 단위인 TU (Transform Unit)로 분할되어 예측과 분할이 수행될 수 있다. 한편, CU는 예측 단위 및/또는 변환 단위 그 자체로 활용할 수 있다. 여기서, 유연한 분할을 위하여 각 CTU는 쿼드 트리(QT) 뿐만 아니라 멀티타입 트리(MTT: Multi-Type Tree)로 재귀적으로 분할될 수도 있다. CTU는 QT의 말단 노드에서 멀티타입 트리로 분할이 시작될 수 있으며 MTT는 BT(Binary Tree)와 TT(Triple Tree)로 구성될 수 있다. 예를 들어, MTT구조에는 수직 이진 분할모드(SPLIT_BT_VER), 수평 이진 분할모드(SPLIT_BT_HOR), 수직 삼항 분할모드(SPLIT_TT_VER), 수평 삼항 분할모드(SPLIT_TT_HOR)로 구분될 수 있다. 또한, 분할 시 휘도 블록의 쿼드 트리의 최소 블록 크기(MinQTSize)는 16x16이고 바이너리 트리의 최대블록 크기(MaxBtSize)는 128x128, 트리플 트리의 최대 블록 크기(MaxTtSize)는 64x64로 설정할 수 있다. 또한, 바이너리 트리의 최소 블록 크기(MinBtSize)와 트리플 트리의 최소 블록 크기(MinTtSize)는 4x4, 멀티 타입 트리의 최대 깊이(MaxMttDepth)는 4로 지정할 수 있다. 또한 I 슬라이스의 부호화 효율을 높이기 위하여 휘도와 색차 성분의 CTU 분할 구조를 서로 다르게 사용하는 듀얼 트리(dual tree)를 적용할 수도 있다. 반면 P와 B슬라이스에서는 CTU 내의 휘도와 색차 CTB (Coding Tree Block)들이 코딩 트리 구조를 공유하는 싱글 트리(single tree)로 분할할 수 있다.
부호화 장치(100)는 입력 영상에 대해 인트라 모드 및/또는 인터 모드로 부호화를 수행할 수 있다. 또는, 부호화 장치(100)는 입력 영상에 대해 상기 인트라 모드 및 인터 모드가 아닌 제3의 모드 (예, IBC 모드, Palette 모드 등)로 부호화를 수행할 수도 있다. 단, 상기 제3의 모드가 인트라 모드 또는 인터 모드와 유사한 기능적 특징을 가지는 경우, 설명의 편의를 위해 인트라 모드 또는 인터 모드로 분류하기도 한다. 본 발명에서는 상기 제3의 모드에 대한 구체적인 설명이 필요한 경우에만 이를 별도로 분류하여 기술할 것이다.
예측 모드로 인트라 모드가 사용되는 경우 스위치(115)는 인트라로 전환될 수 있고, 예측 모드로 인터 모드가 사용되는 경우 스위치(115)는 인터로 전환될 수 있다. 여기서 인트라 모드는 인트라 예측 모드를 의미할 수 있으며, 인터 모드는 화면 간 예측 모드를 의미할 수 있다. 부호화 장치(100)는 입력 영상의 입력 블록에 대한 예측 블록을 생성할 수 있다. 또한, 부호화 장치(100)는 예측 블록이 생성된 후, 입력 블록 및 예측 블록의 차분(residual)을 사용하여 잔여 블록을 부호화할 수 있다. 입력 영상은 현재 부호화의 대상인 현재 영상으로 칭해질 수 있다. 입력 블록은 현재 부호화의 대상인 현재 블록 혹은 부호화 대상 블록으로 칭해질 수 있다.
예측 모드가 인트라 모드인 경우, 인트라 예측부(120)는 현재 블록의 주변에 이미 부호화/복호화된 블록의 샘플을 참조 샘플로서 이용할 수 있다. 인트라 예측부(120)는 참조 샘플을 이용하여 현재 블록에 대한 공간적 예측을 수행할 수 있고, 공간적 예측을 통해 입력 블록에 대한 예측 샘플들을 생성할 수 있다. 여기서 인트라 예측은 화면 내 예측을 의미할 수 있다.
인트라 예측 방식으로, DC 모드, Planar 모드와 같은 무방향성 예측 모드와 방향성 예측 모드 (예, 65개 방향)가 적용될 수 있다. 여기서, 인트라 예측 방식은 인트라 예측 모드 또는 인트라 예측 모드로 표현될 수 있다.
예측 모드가 인터 모드인 경우, 움직임 예측부(121)는, 움직임 예측 과정에서 참조 영상으로부터 입력 블록과 가장 매치가 잘 되는 영역을 검색할 수 있고, 검색된 영역을 이용하여 움직임 벡터를 도출할 수 있다. 이때, 상기 영역으로 탐색 영역을 사용할 수 있다. 참조 영상은 참조 픽처 버퍼(190)에 저장될 수 있다. 여기서, 참조 영상에 대한 부호화/복호화가 처리되었을 때 참조 픽처 버퍼(190)에 저장될 수 있다.
움직임 보상부(122)는 움직임 벡터를 이용하는 움직임 보상을 수행함으로써 현재 블록에 대한 예측 블록을 생성할 수 있다. 여기서 인터 예측은 화면 간 예측 혹은 움직임 보상을 의미할 수 있다.
상기 움직임 예측부(121)과 움직임 보상부(122)는 움직임 벡터의 값이 정수 값을 가지지 않을 경우에 참조 영상 내의 일부 영역에 대해 보간 필터(Interpolation Filter)를 적용하여 예측 블록을 생성할 수 있다. 화면 간 예측 혹은 움직임 보상을 수행하기 위해 부호화 유닛을 기준으로 해당 부호화 유닛에 포함된 예측 유닛의 움직임 예측 및 움직임 보상 방법이 스킵 모드(Skip Mode), 머지 모드(Merge Mode), 향상된 움직임 벡터 예측(Advanced Motion Vector Prediction; AMVP) 모드, 인트라 블록 카피(Intra Block Copy; IBC) 모드 중 어떠한 방법인지 여부를 판단할 수 있고, 각 모드에 따라 화면 간 예측 혹은 움직임 보상을 수행할 수 있다.
또한, 상기 화면 간 예측 방법을 기초로, sub-PU 기반 예측의 AFFINE 모드, SbTMVP (Subblock-based Temporal Motion Vector Prediction) 모드, 및 PU 기반 예측의 MMVD(Merge with MVD) 모드, GPM(Geometric Partitioning Mode) 모드를 적용할 수도 있다. 또한, 각 모드의 성능 향상을 위하여 HMVP(History based MVP), PAMVP(Pairwise Average MVP), CIIP(Combined Intra/Inter Prediction), AMVR(Adaptive Motion Vector Resolution), BDOF(Bi-Directional Optical-Flow), BCW(Bi-predictive with CU Weights), LIC (Local Illumination Compensation), TM(Template Matching), OBMC(Overlapped Block Motion Compensation) 등을 적용할 수도 있다.
감산기(113)는 입력 블록 및 예측 블록의 차분을 사용하여 잔여 블록을 생성할 수 있다. 잔여 블록은 잔여 신호로 칭해질 수도 있다. 잔여 신호는 원 신호 및 예측 신호 간의 차이(difference)를 의미할 수 있다. 또는, 잔여 신호는 원신호 및 예측 신호 간의 차이를 변환(transform)하거나, 양자화하거나, 또는 변환 및 양자화함으로써 생성된 신호일 수 있다. 잔여 블록은 블록 단위의 잔여 신호일 수 있다.
변환부(130)는 잔여 블록에 대해 변환(transform)을 수행하여 변환 계수(transform coefficient)를 생성할 수 있고, 생성된 변환 계수를 출력할 수 있다. 여기서, 변환 계수는 잔여 블록에 대한 변환을 수행함으로써 생성된 계수 값일 수 있다. 변환 생략(transform skip) 모드가 적용되는 경우, 변환부(130)는 잔여 블록에 대한 변환을 생략할 수도 있다.
변환 계수 또는 잔여 신호에 양자화를 적용함으로써 양자화된 레벨(quantized level)이 생성될 수 있다. 이하, 실시예들에서는 양자화된 레벨도 변환 계수로 칭해질 수 있다.
일 예로, 화면내 예측을 통해 생성된 4x4 휘도 잔차 블록은 DST(Discrete Sine Transform) 기반 기저 벡터를 통해 변환하며, 나머지 잔차 블록에 대해서는 DCT(Discrete Cosine Transform) 기반의 기저 벡터를 사용하여 변환을 수행할 수 있다. 또한 RQT(Residual Quad Tree) 기술을 통하여 하나의 블록에 대하여 변환 블록을 쿼드 트리 형태로 분할하며 RQT를 통해 분할된 각 변환 블록에 대하여 변환과 양자화를 수행하고 난 후 모든 계수가 0이 되는 경우의 부호화 효율을 높이기 위해 cbf(coded block flag)를 전송할 수 있다.
또 다른 대안으로는, 여러 변환 기저를 선택적으로 사용하여 변환을 수행하는 MTS(Multiple Transform Selection) 기술을 적용할 수도 있다. 즉, CU를 RQT를 통해 TU로 분할하지 않고, SBT(Sub-block Transform) 기술을 통해 TU분할과 유사한 기능을 수행할 수 있다. 구체적으로, SBT는 화면 간 예측 블록에만 적용되며 RQT와 달리 현재 블록을 수직 혹은 수평 방향으로 ½ 혹은 ¼ 크기로 분할한 뒤 그 중 하나의 블록에 대해서만 변환을 수행할 수 있다. 예를 들어, 수직으로 분할된 경우 맨 왼쪽 혹은 맨 오른쪽 블록에 대해 변환을 수행하고, 수평으로 분할된 경우 맨 위쪽 혹은 맨 아래쪽 블록에 대하여 변환을 수행할 수 있다.
또한 DCT 또는 DST를 통해 주파수 영역으로 변환된 잔차 신호를 추가 변환하는 2차 변환 (secondary transform) 기술인 LFNST(Low Frequency Non-Separable Transform)를 적용할 수도 있다. LFNST는 좌측 상단의 4x4 또는 8x8의 저주파수 영역에 대해서 변환을 추가적으로 수행하여 잔차 계수를 좌측 상단으로 집중시킬 수 있게 된다.
양자화부(140)는 변환 계수 또는 잔여 신호를 양자화 매개변수 (QP, Quantization parameter)에 따라 양자화함으로써 양자화된 레벨을 생성할 수 있고, 생성된 양자화된 레벨을 출력할 수 있다. 이때, 양자화부(140)에서는 양자화 행렬을 사용하여 변환 계수를 양자화할 수 있다.
일 예로, 0~51 QP 값을 사용하는 양자화기를 사용할 수 있다. 또는, 영상의 크기가 보다 크고 높은 부호화 효율이 요구되는 경우에는, 0~63 QP를 사용할 수도 있다. 또한 하나의 양자화기를 사용하는 것이 아닌 두 개의 양자화기를 사용하는 DQ(Dependent Quantization) 방법을 적용할 수도 있다. DQ는 두개의 양자화기(예, Q0, Q1)를 사용하여 양자화를 수행하되, 특정 양자화기 사용에 대한 정보를 시그널링 하지 않더라도, 상태 전이 모델을 통해 현재 상태에 기반하여 다음 변환 계수에 사용할 양자화기가 선택되도록 적용할 수 있다.
엔트로피 부호화부(150)는, 양자화부(140)에서 산출된 값들 또는 부호화 과정에서 산출된 부호화 파라미터(Coding Parameter) 값들 등에 대하여 확률 분포에 따른 엔트로피 부호화를 수행함으로써 비트스트림(bitstream)을 생성할 수 있고, 비트스트림을 출력할 수 있다. 엔트로피 부호화부(150)는 영상의 샘플에 관한 정보 및 영상의 복호화를 위한 정보에 대한 엔트로피 부호화를 수행할 수 있다. 예를 들면, 영상의 복호화를 위한 정보는 구문 요소(syntax element) 등을 포함할 수 있다.
엔트로피 부호화가 적용되는 경우, 높은 발생 확률을 갖는 심볼(symbol)에 적은 수의 비트가 할당되고 낮은 발생 확률을 갖는 심볼에 많은 수의 비트가 할당되어 심볼이 표현됨으로써, 부호화 대상 심볼들에 대한 비트열의 크기가 감소될 수 있다. 엔트로피 부호화부(150)는 엔트로피 부호화를 위해 지수 골롬(exponential Golomb), CAVLC(Context-Adaptive Variable Length Coding), CABAC(Context-Adaptive Binary Arithmetic Coding)과 같은 부호화 방법을 사용할 수 있다. 예를 들면, 엔트로피 부호화부(150)는 가변 길이 부호화(Variable Length Coding/Code; VLC) 테이블을 이용하여 엔트로피 부호화를 수행할 수 있다. 또한 엔트로피 부호화부(150)는 대상 심볼의 이진화(binarization) 방법 및 대상 심볼/빈(bin)의 확률 모델(probability model)을 도출한 후, 도출된 이진화 방법, 확률 모델, 문맥 모델(Context Model)을 사용하여 산술 부호화를 수행할 수도 있다.
관련하여, CABAC을 적용함에 있어서, 복호화 장치에서 저장되는 확률 테이블의 크기를 줄이고자, 테이블 확률 업데이트 방식을 간단한 수식을 통한 테이블 업데이트 방식으로 변경하여 적용할 수도 있다. 또한 더 정확한 심볼의 확률 값을 얻기 위하여 2개의 서로 다른 확률 모델을 사용할 수도 있다.
엔트로피 부호화부(150)는 변환 계수 레벨(양자화된 레벨)을 부호화하기 위해 변환 계수 스캐닝(Transform Coefficient Scanning) 방법을 통해 2차원의 블록 형태(form) 계수를 1차원의 벡터 형태로 변경할 수 있다.
부호화 파라미터(Coding Parameter)는 구문 요소 (syntax element)와 같이 부호화 장치(100)에서 부호화되어 복호화 장치(200)로 시그널링되는 정보(플래그, 색인 등)뿐만 아니라, 부호화 과정 혹은 복호화 과정에서 유도되는 정보를 포함할 수 있으며, 영상을 부호화하거나 복호화할 때 필요한 정보를 의미할 수 있다.
여기서, 플래그 혹은 색인을 시그널링(signaling)한다는 것은 인코더에서는 해당 플래그 혹은 색인을 엔트로피 부호화(Entropy Encoding)하여 비트스트림(Bitstream)에 포함하는 것을 의미할 수 있고, 디코더에서는 비트스트림으로부터 해당 플래그 혹은 색인을 엔트로피 복호화(Entropy Decoding)하는 것을 의미할 수 있다.
부호화된 현재 영상은 이후에 처리되는 다른 영상에 대한 참조 영상으로서 사용될 수 있다. 따라서, 부호화 장치(100)는 부호화된 현재 영상을 다시 복원 또는 복호화할 수 있고, 복원 또는 복호화된 영상을 참조 영상으로 참조 픽처 버퍼(190)에 저장할 수 있다.
양자화된 레벨은 역양자화부(160)에서 역양자화(dequantization)될 수 있고. 역변환부(170)에서 역변환(inverse transform)될 수 있다. 역양자화 및/또는 역변환된 계수는 가산기(117)를 통해 예측 블록과 합해질 수 있다, 역양자화 및/또는 역변환된 계수와 예측 블록을 합함으로써 복원 블록(reconstructed block)이 생성될 수 있다. 여기서, 역양자화 및/또는 역변환된 계수는 역양자화 및 역변환 중 적어도 하나 이상이 수행된 계수를 의미하며, 복원된 잔여 블록을 의미할 수 있다. 상기 역양자화부(160) 및 역변환부(170)는 양자화부(140) 및 변환부(130)의 역과정으로 수행될 수 있다.
복원 블록은 필터부(180)를 거칠 수 있다. 필터부(180)는 디블록킹 필터(deblocking filter), 샘플 적응적 오프셋(Sample Adaptive Offset; SAO), 적응적 루프 필터(Adaptive Loop Filter; ALF), 양방향 필터 (Bilateral filter; BIF), LMCS (Luma Mapping with Chroma Scaling) 등을 복원 샘플, 복원 블록 또는 복원 영상에, 전부 또는 일부 필터링 기술로 적용할 수 있다. 필터부(180)는 인-루프 필터(in-loop filter)로 칭해질 수도 있다. 이때, 인-루프 필터(in-loop filter)는 LMCS를 제외하는 명칭으로 사용하기도 한다.
디블록킹 필터는 블록들 간의 경계에서 발생한 블록 왜곡을 제거할 수 있다. 디블록킹 필터를 수행할지 여부를 판단하기 위해 블록에 포함된 몇 개의 열 또는 행에 포함된 샘플을 기초로 현재 블록에 디블록킹 필터 적용할지 여부를 판단할 수 있다. 블록에 디블록킹 필터를 적용하는 경우 필요한 디블록킹 필터링 강도에 따라 서로 다른 필터를 적용할 수 있다.
샘플 적응적 오프셋을 이용하여 부호화 에러를 보상하기 위해 샘플 값에 적정 오프셋(offset) 값을 더할 수 있다. 샘플 적응적 오프셋은 디블록킹을 수행한 영상에 대해 샘플 단위로 원본 영상과의 오프셋을 보정할 수 있다. 영상에 포함된 샘플을 일정한 수의 영역으로 구분한 후 오프셋을 수행할 영역을 결정하고 해당 영역에 오프셋을 적용하는 방법 또는 각 샘플의 에지 정보를 고려하여 오프셋을 적용하는 방법을 사용할 수 있다.
양방향 필터 (Bilateral filter; BIF) 또한 디블록킹을 수행한 영상에 대해 샘플 단위로 원본 영상과의 오프셋을 보정할 수 있다.
적응적 루프 필터는 복원 영상 및 원래의 영상을 비교한 값에 기반하여 필터링을 수행할 수 있다. 영상에 포함된 샘플을 소정의 그룹으로 나눈 후 해당 그룹에 적용될 필터를 결정하여 그룹마다 차별적으로 필터링을 수행할 수 있다. 적응적 루프 필터를 적용할지 여부에 관련된 정보는 부호화 유닛(Coding Unit, CU) 별로 시그널링될 수 있고, 각각의 블록에 따라 적용될 적응적 루프 필터의 모양 및 필터 계수는 달라질 수 있다.
LMCS(Luma Mapping with Chroma Scaling)에서, 루마 매핑(LM, Luma-mapping)은 piece-wise 선형 모델을 통해 휘도 값을 재맵핑 하는 것을 의미하고, 크로마 스케일링(CS, Chroma scaling)은 예측 신호의 평균 휘도 값에 따라 색차 성분의 잔차 값을 스케일링해주는 기술을 의미한다. 특히, LMCS는 HDR(High Dynamic Range) 영상의 특성을 반영한 HDR 보정 기술로 활용될 수 있다.
필터부(180)를 거친 복원 블록 또는 복원 영상은 참조 픽처 버퍼(190)에 저장될 수 있다. 필터부(180)를 거친 복원 블록은 참조 영상의 일부일 수 있다. 말하자면, 참조 영상은 필터부(180)를 거친 복원 블록들로 구성된 복원 영상일 수 있다. 저장된 참조 영상은 이후 화면 간 예측 혹은 움직임 보상에 사용될 수 있다.
도 2는 본 발명이 적용되는 복호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다.
복호화 장치(200)는 디코더, 비디오 복호화 장치 또는 영상 복호화 장치일 수 있다.
도 2를 참조하면, 복호화 장치(200)는 엔트로피 복호화부(210), 역양자화부(220), 역변환부(230), 인트라 예측부(240), 움직임 보상부(250), 가산기(201), 스위치 (203), 필터부(260) 및 참조 픽처 버퍼(270)를 포함할 수 있다.
복호화 장치(200)는 부호화 장치(100)에서 출력된 비트스트림을 수신할 수 있다. 복호화 장치(200)는 컴퓨터 판독가능한 기록 매체에 저장된 비트스트림을 수신하거나, 유/무선 전송 매체를 통해 스트리밍되는 비트스트림을 수신할 수 있다. 복호화 장치(200)는 비트스트림에 대하여 인트라 모드 또는 인터 모드로 복호화를 수행할 수 있다. 또한, 복호화 장치(200)는 복호화를 통해 복원된 영상 또는 복호화된 영상을 생성할 수 있고, 복원된 영상 또는 복호화된 영상을 출력할 수 있다.
복호화에 사용되는 예측 모드가 인트라 모드인 경우 스위치(203)가 인트라로 전환될 수 있다. 복호화에 사용되는 예측 모드가 인터 모드인 경우 스위치(203)가 인터로 전환될 수 있다.
복호화 장치(200)는 입력된 비트스트림을 복호화하여 복원된 잔여 블록(reconstructed residual block)을 획득할 수 있고, 예측 블록을 생성할 수 있다. 복원된 잔여 블록 및 예측 블록이 획득되면, 복호화 장치(200)는 복원된 잔여 블록과 및 예측 블록을 더함으로써 복호화 대상이 되는 복원 블록을 생성할 수 있다. 복호화 대상 블록은 현재 블록으로 칭해질 수 있다.
엔트로피 복호화부(210)는 비트스트림에 대한 확률 분포에 따른 엔트로피 복호화를 수행함으로써 심볼들을 생성할 수 있다. 생성된 심볼들은 양자화된 레벨 형태의 심볼을 포함할 수 있다. 여기에서, 엔트로피 복호화 방법은 상술된 엔트로피 부호화 방법의 역과정일 수 있다.
엔트로피 복호화부(210)는 변환 계수 레벨(양자화된 레벨)을 복호화하기 위해 변환 계수 스캐닝 방법을 통해 1차원의 벡터 형태 계수를 2차원의 블록 형태로 변경할 수 있다.
양자화된 레벨은 역양자화부(220)에서 역양자화될 수 있고, 역변환부(230)에서 역변환될 수 있다. 양자화된 레벨은 역양자화 및/또는 역변환이 수행된 결과로서, 복원된 잔여 블록으로 생성될 수 있다. 이때, 역양자화부(220)는 양자화된 레벨에 양자화 행렬을 적용할 수 있다. 복호화 장치에 적용되는 역양자화부(220) 및 역변환부(230)는 전술한 부호화 장치에 적용되는 역양자화부(160) 및 역변환부(170)와 동일한 기술을 적용할 수 있다.
인트라 모드가 사용되는 경우, 인트라 예측부(240)는 복호화 대상 블록 주변의 이미 복호화된 블록의 샘플 값을 이용하는 공간적 예측을 현재 블록에 대해 수행함으로써 예측 블록을 생성할 수 있다. 복호화 장치에 적용되는 인트라 예측부(240)는 전술한 부호화 장치에 적용되는 인트라 예측부(120)와 동일한 기술을 적용할 수 있다.
인터 모드가 사용되는 경우, 움직임 보상부(250)는 움직임 벡터 및 참조 픽처 버퍼(270)에 저장되어 있는 참조 영상을 이용하는 움직임 보상을 현재 블록에 대해 수행함으로써 예측 블록을 생성할 수 있다. 상기 움직임 보상부(250)는 움직임 벡터의 값이 정수 값을 가지지 않을 경우에 참조 영상 내의 일부 영역에 대해 보간 필터를 적용하여 예측 블록을 생성할 수 있다. 움직임 보상을 수행하기 위해 부호화 유닛을 기준으로 해당 부호화 유닛에 포함된 예측 유닛의 움직임 보상 방법이 스킵 모드, 머지 모드, AMVP 모드, 현재 픽처 참조 모드 중 어떠한 방법인지 여부를 판단할 수 있고, 각 모드에 따라 움직임 보상을 수행할 수 있다. 복호화 장치에 적용되는 움직임 보상부(250)는 전술한 부호화 장치에 적용되는 움직임 보상부(122)와 동일한 기술을 적용할 수 있다.
가산기(201)는 복원된 잔여 블록 및 예측 블록을 가산하여 복원 블록을 생성할 수 있다. 필터부(260)는 Inverse-LMCS, 디블록킹 필터, 샘플 적응적 오프셋 및 적응적 루프 필터 등 적어도 하나를 복원 블록 또는 복원 영상에 적용할 수 있다. 복호화 장치에 적용되는 필터부(260)는 전술한 부호화 장치에 적용되는 필터부(180)에 적용된 필터링 기술과 동일한 기술을 적용할 수 있다.
필터부(260)는 복원 영상을 출력할 수 있다. 복원 블록 또는 복원 영상은 참조 픽처 버퍼(270)에 저장되어 인터 예측에 사용될 수 있다. 필터부(260)를 거친 복원 블록은 참조 영상의 일부일 수 있다. 말하자면, 참조 영상은 필터부(260)를 거친 복원 블록들로 구성된 복원 영상일 수 있다. 저장된 참조 영상은 이후 화면 간 예측 혹은 움직임 보상에 사용될 수 있다.
도 3은 본 발명이 적용될 수 있는 비디오 코딩 시스템을 개략적으로 나타내는 도면이다.
일 실시예에 따른 비디오 코딩 시스템은 부호화 장치(10) 및 복호화 장치(20)를 포함할 수 있다. 부호화 장치(10)는 부호화된 비디오(video) 및/또는 영상(image) 정보 또는 데이터를 파일 또는 스트리밍 형태로 디지털 저장매체 또는 네트워크를 통하여 복호화 장치(20)로 전달할 수 있다.
일 실시예에 따른 부호화 장치(10)는 비디오 소스 생성부(11), 부호화부(12), 전송부(13)를 포함할 수 있다. 일 실시예에 따른 복호화 장치(20)는 수신부(21), 복호화부(22) 및 렌더링부(23)를 포함할 수 있다. 상기 부호화부(12)는 비디오/영상 부호화부라고 불릴 수 있고, 상기 복호화부(22)는 비디오/영상 복호화부라고 불릴 수 있다. 전송부(13)는 부호화부(12)에 포함될 수 있다. 수신부(21)는 복호화부(22)에 포함될 수 있다. 렌더링부(23)는 디스플레이부를 포함할 수도 있고, 디스플레이부는 별개의 디바이스 또는 외부 컴포넌트로 구성될 수도 있다.
비디오 소스 생성부(11)는 비디오/영상의 캡쳐, 합성 또는 생성 과정 등을 통하여 비디오/영상을 획득할 수 있다. 비디오 소스 생성부(11)는 비디오/영상 캡쳐 디바이스 및/또는 비디오/영상 생성 디바이스를 포함할 수 있다. 비디오/영상 캡쳐 디바이스는 예를 들어, 하나 이상의 카메라, 이전에 캡쳐된 비디오/영상을 포함하는 비디오/영상 아카이브 등을 포함할 수 있다. 비디오/영상 생성 디바이스는 예를 들어 컴퓨터, 타블렛 및 스마트폰 등을 포함할 수 있으며 (전자적으로) 비디오/영상을 생성할 수 있다. 예를 들어, 컴퓨터 등을 통하여 가상의 비디오/영상이 생성될 수 있으며, 이 경우 관련 데이터가 생성되는 과정으로 비디오/영상 캡쳐 과정이 갈음될 수 있다.
부호화부(12)는 입력 비디오/영상을 부호화할 수 있다. 부호화부(12)는 압축 및 부호화 효율을 위하여 예측, 변환, 양자화 등 일련의 절차를 수행할 수 있다. 부호화부(12)는 부호화된 데이터(부호화된 비디오/영상 정보)를 비트스트림(bitstream) 형태로 출력할 수 있다. 상기 부호화부(12)의 상세 구성은 전술한 도 1의 부호화 장치(100)와 동일하게 구성하는 것도 가능하다.
전송부(13)는 비트스트림 형태로 출력된 부호화된 비디오/영상 정보 또는 데이터를 파일 또는 스트리밍 형태로 디지털 저장매체 또는 네트워크를 통하여 복호화 장치(20)의 수신부(21)로 전달할 수 있다. 디지털 저장 매체는 USB, SD, CD, DVD, 블루레이, HDD, SSD 등 다양한 저장 매체를 포함할 수 있다. 전송부(13)는 미리 정해진 파일 포맷을 통하여 미디어 파일을 생성하기 위한 엘리먼트를 포함할 수 있고, 방송/통신 네트워크를 통한 전송을 위한 엘리먼트를 포함할 수 있다. 수신부(21)는 상기 저장매체 또는 네트워크로부터 상기 비트스트림을 추출 /수신하여 복호화부(22)로 전달할 수 있다.
복호화부(22)는 부호화부(12)의 동작에 대응하는 역양자화, 역변환, 예측 등 일련의 절차를 수행하여 비디오/영상을 복호화할 수 있다. 상기 복호화부(22)의 상세 구성은 전술한 도 2의 복호화 장치(200)와 동일하게 구성하는 것도 가능하다.
렌더링부(23)는 복호화된 비디오/영상을 렌더링할 수 있다. 렌더링된 비디오/영상은 디스플레이부를 통하여 디스플레이될 수 있다.
본 개시는, 화면 내 예측의 예측 정확도를 향상시키기 위하여, 화면 내 예측에서 결정된 화면 내 예측 모드(intra prediction mode)를 보정함으로써, 화면 내 예측 모드를 개선하는 방법이 설명된다. 화면 내 예측 모드의 보정을 위하여, 복호화기가 템플릿에 기초하여 복수의 후보 화면 내 예측 모드들 중 가장 예측 정확도가 높은 후보 화면 내 예측 모드를 선택할 수 있다. 또는 복호화기는 부호화기에서 전송된 정보에 기초하여 복수의 후보 화면 내 예측 모드들 중 하나를 선택할 수 있다. 위와 같이, 화면 내 예측 모드를 보정함으로써, 화면 내 예측의 예측 정확도가 향상될 수 있다.
이하, 복호화측 화면 내 예측 모드 개선 (Decoder side intra prediction mode refinement, DIMR) 방법의 다양한 실시 예가 설명된다.
도 4는 템플릿 기반 화면 내 모드 유도 (Template-based intra mode derivation, TIMD) 방법을 나타낸다.
도 4는 MxN 크기의 현재 블록 (400)의 템플릿 (402)과 상기 템플릿 (402)의 화소의 예측 값 생성에 사용되는 템플릿의 참조 화소 (404)를 나타낸다. 상기 현재 블록의 템플릿 (402)은 상기 현재 블록 (400)의 좌측 영역 및 상측 영역 중 적어도 하나를 포함하며, 상기 현재 블록 (400)에 앞서 복원되어 있다. 상기 좌측 영역은 L1xN 크기이며, 상기 상측 영역은 MxL2 크기의 상측 템플릿으로 구성된다. 여기서 M, N, L1, 그리고 L2는 임의의 양의 정수이다.
템플릿 기반 화면 내 모드 유도 방법에 의하면, 현재 블록 (400)의 MPM (most probable mode) 리스트 내의 각 후보 모드에 대한 적합성이 계산된다. 상기 적합성을 계산하기 위하여, 해당 후보 모드의 방향성에 기초하여 상기 템플릿의 참조 화소로부터 상기 템플릿의 예측 값이 생성된다. 그리고 상기 템플릿의 화소의 예측 값과 복원 값의 절대 변환 차이의 합(sum of absolute transformed differences, SATD)가 계산된다. 그리고 MPM 리스트 내의 모든 후보 모드 중 절대 변환 차이의 합이 가장 작은 후보 모드가 화면 내 예측 모드로 선택된다.
템플릿 기반 화면 내 모드 유도 방법에서, 절대 변환 차이의 대신, 절대 차이의 합 (sum of absolute difference, SAD) 또는 제곱 차이의 합 (sum of squared difference, SSD) 등 다양한 왜곡 측정 방법이 사용될 수 있다. 또한, 템플릿 기반 화면 내 모드 유도 방법에서, MPM 리스트의 후보 모드 뿐만 아니라, 전체 화면 내 예측 모드에 대한 왜곡 측정이 수행됨으로써, 전체 화면 내 예측 모드 중에서 화면 내 예측 모드로 선택될 수 있다. 또한, 임의의 화면 내 예측 후보 모드로 구성된 리스트에 대한 왜곡 측정이 수행됨으로써, 임의의 화면 내 예측 모드 중에서 화면 내 예측 모드가 선택될 수 있다.
복호화측 화면 내 예측 모드 개선(Decoder side intra prediction mode refinement, DIMR) 방법에 따르면, 먼저 초기 화면 내 예측 모드가 결정된다. 그리고, 초기 화면 내 예측 모드가 템플릿 기반 화면 내 모드 유도 방법에 의하여 보정된다. 구체적으로, 초기 화면 내 예측 모드의 인접 후보 모드들을 포함하는 후보 화면 내 예측 모드들 중에서, 최적의 후보 모드가 템플릿 기반 화면 내 모드 유도 방법으로 선택된다. 그리고 최적의 후보 모드가 최종 화면 내 예측 모드로 결정된다.
만약, 복호화측 화면 내 예측 모드 개선 모드의 허용 여부가 블록의 상위 데이터 단위 (시퀀스, 픽처, 슬라이스, 타일, 부호화 트리 유닛 등)의 신택스 요소에 의하여 결정되는 경우, 후보 화면 내 예측 모드들은 초기 화면 내 예측 모드 및 초기 화면 내 예측 모드의 인접 후보 모드들을 포함할 수 있다. 왜냐하면 블록 단위로 획득된 데이터 없이, 복호화기가 초기 화면 내 예측 모드가 모든 인접 후보 모드보다 왜곡도가 낮은지 판단하여야 하기 때문이다.
또는, 복호화측 화면 내 예측 모드 개선 모드의 적용 여부가 최종적으로 블록 단위의 신택스 요소에 의하여 결정되는 경우, 후보 화면 내 예측 모드들은 초기 화면 내 예측 모드의 인접 후보 모드들만 포함할 수 있다. 왜냐하면 부호화기에서 현재 블록에 초기 화면 내 예측 모드가 가장 왜곡도가 낮다고 판단하였을 경우, 부호화기에서 부호화된 블록 단위의 신택스 요소는 복호화측 화면 내 예측 모드 개선이 불필요함을 나타내도록 부호화될 것이기 때문이다.
초기 화면 내 예측 모드의 인접 후보 모드들은 초기 화면 내 예측 모드의 인덱스보다 1만큼 작은 인덱스의 제1 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향 사이의 예측 방향을 가질 수 있다. 이 때 초기 화면 내 예측 모드의 인접 후보 모드들은 예측 방향이 제1 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향의 사이에 있는 S개의 화면 내 예측 모드를 포함할 수 있다. 예를 들어, 초기 화면 내 예측 모드의 인덱스가 34일 경우, 제1 인접 화면 내 예측 모드인 33번 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드인 34번 화면 내 예측 모드의 예측 방향 사이의 예측 방향을 가진 S개의 화면 내 예측 모드들이 인접 후보 모드로 포함될 수 있다. 상기 S는 1 이상의 임의의 양의 정수이다.
초기 화면 내 예측 모드의 인접 후보 모드들은 초기 화면 내 예측 모드의 인덱스보다 1만큼 큰 인덱스의 제2 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향 사이의 예측 방향을 가질 수 있다. 이 때 초기 화면 내 예측 모드의 인접 후보 모드들은 예측 방향이 제2 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향의 사이에 있는 S개의 화면 내 예측 모드를 포함할 수 있다. 예를 들어, 초기 화면 내 예측 모드의 인덱스가 34일 경우, 초기 화면 내 예측 모드인 34번 화면 내 예측 모드의 예측 방향과 제2 인접 화면 내 예측 모드인 35번 화면 내 예측 모드의 예측 방향 사이의 예측 방향을 가진 S개의 화면 내 예측 모드들이 인접 후보 모드로 포함될 수 있다. 상기 S는 1 이상의 임의의 양의 정수이다.
도 5는 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 일 실시 예를 나타낸다. 도 5에 따르면, 초기 화면 내 예측 모드는 63번 모드이고, 제1 인접 화면 내 예측 모드 및 제2 인접 화면 내 예측 모드는 62번 모드, 64번 모드이다.
인접 후보 모드는 62번 모드의 예측 방향과 63번 모드의 예측 방향의 사이에 있는 예측 모드 63-1/2 모드와 63번 모드의 예측 방향과 64번 모드의 예측 방향의 사이에 있는 예측 모드 63+1/2 모드를 포함할 수 있다. 그리고 템플릿 기반 화면 내 모드 유도 방법에 기초하여 63번 모드, 63-1/2 모드, 및 63+1/2 모드 중 가장 작은 왜곡 값을 갖는 화면 내 예측 모드가 현재 블록의 화면 내 예측 모드로 결정될 수 있다.
도 6은 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 다른 일 실시 예를 나타낸다. 도 6에 따르면, 도 5와 마찬가지로 초기 화면 내 예측 모드는 63번 모드이고, 제1 인접 화면 내 예측 모드 및 제2 인접 화면 내 예측 모드는 62번 모드, 64번 모드이다.
인접 후보 모드는 62번 모드의 예측 방향과 63번 모드의 예측 방향의 사이에 있는 예측 모드 63-1/3 모드 및 63-2/3 모드와 63번 모드의 예측 방향과 64번 모드의 예측 방향의 사이에 있는 예측 모드 63+1/3 모드 및 63+2/3 모드를 포함할 수 있다. 그리고 템플릿 기반 화면 내 모드 유도 방법에 기초하여 63번 모드, 63-1/3 모드, 63-2/3 모드, 63+1/3 모드 및 63+2/3 모드 중 가장 작은 왜곡 값을 갖는 화면 내 예측 모드가 현재 블록의 화면 내 예측 모드로 결정될 수 있다.
도 5의 인접 후보 모드의 개수는 총 2개이고, 도 6의 인접 후보 모드의 개수는 총 4개이다. 도 6과 같이 인접 후보 모드의 개수가 증가할 경우, 현재 블록의 화면 내 예측의 정확도가 향상될 수 있다. 그러나, 왜곡도 기반의 최적의 인접 후보 모드 선택 과정에서, 복호화기의 연산 부담이 증가할 수 있다. 따라서, 복호화기의 연산 부담을 고려하여 인접 후보 모드의 개수가 증가될 수 있다. 다만, 복호화기에서 왜곡도에 기반하여 인접 후보 모드를 선택하는 대신, 부호화기에서 부호화된 인접 후보 모드 정보에 기초하여 인접 후보 모드가 선택될 경우, 인접 후보 모드의 개수가 증가하여도 인접 후보 모드의 왜곡도 계산을 위한 복호화기의 연산 부담이 없다. 따라서, 인접 후보 모드 정보에 기초하여 인접 후보 모드가 선택될 경우, 더 많은 인접 후보 모드가 화면 내 예측 모드 개선에 이용될 수 있다.
도 7은 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드인 경우, 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 일 실시 예를 나타낸다. 도 7에 따르면, 소정의 범위의 방향성 모드들 중 가장 작은 인덱스의 초기 화면 내 예측 모드는 2번 모드이다.
인접 후보 모드는 예측 방향이 2번 모드의 예측 방향과 3번 모드의 예측 방향의 사이에 있는 2+1/2번 모드를 포함할 수 있다. 그리고 템플릿 기반 화면 내 모드 유도 방법에 기초하여 2번 모드 및 2+1/2번 모드 중 가장 작은 왜곡 값을 갖는 화면 내 예측 모드가 현재 블록의 화면 내 예측 모드로 결정될 수 있다.
도 8은 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드인 경우, 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 다른 일 실시 예를 나타낸다. 도 8에 따르면, 소정의 범위의 방향성 모드들 중 가장 작은 인덱스의 초기 화면 내 예측 모드는 2번 모드이다.
인접 후보 모드는 예측 방향이 2번 모드의 예측 방향과 3번 모드의 예측 방향의 사이에 있는 2+1/3번 모드 및 2+2/3번 모드를 포함할 수 있다. 그리고 템플릿 기반 화면 내 모드 유도 방법에 기초하여 2번 모드, 2+1/3번 모드 및 2+2/3번 모드 중 가장 작은 왜곡 값을 갖는 화면 내 예측 모드가 현재 블록의 화면 내 예측 모드로 결정될 수 있다.
도 7 및 도 8에는 방향성 모드 중 가장 작은 인덱스가 2번 모드로 묘사되어 있으나 이는 예시에 불과하며, 방향성 모드 중 가장 작은 인덱스는 다른 값일 수 있다. 도 5 및 6의 실시 예에 대하여 설명한 것과 마찬가지로, 도 7 및 도 8의 실시 예에서도, 인접 후보 모드의 개수가 증가하면 예측 정확도는 향상되나 복호화기의 연산 부담이 증가한다. 따라서, 복호화기의 연산 부담을 고려하여, 인접 후보 모드의 개수가 증가될 수 있다. 또한, 부호화기에서 부호화된 인접 후보 모드 정보에 기초하여 인접 후보 모드가 선택될 경우, 복호화기의 연산 부담이 감소하는 바, 더 많은 인접 후보 모드가 화면 내 예측 모드 개선에 이용될 수 있다.
도 9는 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 큰 인덱스의 화면 내 예측 모드인 경우, 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 일 실시 예를 나타낸다. 도 9에 따르면, 소정의 범위의 방향성 모드들 중 가장 큰 인덱스의 초기 화면 내 예측 모드는 66번 모드이다.
인접 후보 모드는 예측 방향이 65번 모드의 예측 방향과 66번 모드의 예측 방향의 사이에 있는 66-1/2번 모드를 포함할 수 있다. 그리고 템플릿 기반 화면 내 모드 유도 방법에 기초하여 66-1/2번 모드 및 66번 모드 중 가장 작은 왜곡 값을 갖는 화면 내 예측 모드가 현재 블록의 화면 내 예측 모드로 결정될 수 있다.
도 10은 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 큰 인덱스의 화면 내 예측 모드인 경우, 초기 화면 내 예측 모드의 인접 후보 모드들의 결정 방법의 다른 일 실시 예를 나타낸다. 도 10에 따르면, 소정의 범위의 방향성 모드들 중 가장 큰 인덱스의 초기 화면 내 예측 모드는 66번 모드이다.
인접 후보 모드는 예측 방향이 65번 모드의 예측 방향과 66번 모드의 예측 방향의 사이에 있는 66-1/3번 모드 및 66-2/3번 모드를 포함할 수 있다. 그리고 템플릿 기반 화면 내 모드 유도 방법에 기초하여 66-1/3번 모드, 66-2/3번 모드 및 66번 모드 중 가장 작은 왜곡 값을 갖는 화면 내 예측 모드가 현재 블록의 화면 내 예측 모드로 결정될 수 있다.
도 9 및 도 10에는 방향성 모드 중 가장 큰 인덱스가 66번 모드로 묘사되어 있으나 이는 예시에 불과하며, 방향성 모드 중 가장 큰 인덱스는 전체 화면 내 예측 모드의 개수를 고려하여 다른 값으로 결정될 수 있다. 도 5 및 6의 실시 예에 대하여 설명한 것과 마찬가지로, 도 9 및 도 10의 실시 예에서도, 인접 후보 모드의 개수가 증가하면 예측 정확도는 향상되나 복호화기의 연산 부담이 증가한다. 따라서, 복호화기의 연산 부담을 고려하여, 인접 후보 모드의 개수가 증가될 수 있다. 또한, 부호화기에서 부호화된 인접 후보 모드 정보에 기초하여 인접 후보 모드가 선택될 경우, 복호화기의 연산 부담이 감소하는 바, 더 많은 인접 후보 모드가 화면 내 예측 모드 개선에 이용될 수 있다.
도 5 내지 도 10의 실시 예에서는 초기 화면 내 예측 모드의 각 인덱스 방향마다 1개 또는 2개의 화면 내 예측 모드가 인접 후보 모드로 포함된다. 그러나 이는 예시에 불과하며, 초기 화면 내 예측 모드의 각 인덱스 방향마다 S개의 화면 내 예측 모드가 인접 후보 모드로 포함될 수 있다. 상기 S는 3 이상인 임의의 양의 정수이다.
도 5 내지 도 10에서는 초기 화면 내 예측 모드와 인접 화면 내 예측 모드의 예측 방향 차이를 균등 분할함으로써, 인접 후보 모드가 결정된다. 그러나 실시 예에 따라, 예측 방향 차이를 비균등 분할함으로써, 인접 후보 모드가 결정될 수 있다. 또한, 초기 화면 내 예측 모드가 가리키는 방향의 인접한 임의의 방향에 기초하여, 인접 후보 모드가 결정될 수 있다.
상기 균등 분할은 초기 화면 내 예측 모드와 인접 화면 내 예측 모드의 예측 방향의 각도 차이를 균등 분할함을 의미할 수 있다. 또는 상기 균등 분할은 초기 화면 내 예측 모드와 인접 화면 내 예측 모드의 예측 방향이 가리키는 참조 위치 간의 위치 차이를 균등 분할함을 의미할 수 있다
도 5 내지 도 10에서는 초기 화면 내 예측 모드를 기준으로 바로 인접한 인접 화면 내 예측 모드에 기초하여 인접 후보 모드가 결정된다. 그러나 실시 예에 따라, 초기 화면 내 예측 모드와 인덱스 차이가 A인 인접 화면 내 예측 모드를 기준으로 인접 후보 모드가 결정될 수 있다. 예를 들어, 초기 화면 내 예측 모드가 32이고, A가 2일 경우, 제1 인접 화면 내 예측 모드는 30으로, 제2 인접 화면 내 예측 모드는 34로 결정될 수 있다. 그리고 인덱스 값이 30-34 사이의 복수의 화면 내 예측 모드가 인접 후보 모드에 포함될 수 있다. 여기서 A는 1 이상인 임의의 양의 정수이다.
복호화측 화면 내 예측 모드 개선 방법은 이하 조건에 기초하여 적용 여부가 결정될 수 있다.
일 실시 예에 따르면, 현재 블록의 초기 화면 내 예측 모드가 비방향성 모드인 planar 모드 또는 DC 모드인 경우, 현재 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용되지 않을 수 있다.
일 실시 예에 따르면, 현재 블록의 크기에 따라, 현재 블록에 복호화측 화면 내 예측 모드 개선 방법의 적용 여부가 결정될 수 있다. 예를 들면, 현재 블록의 넓이가 M 휘도 샘플 이하인 경우 (M은 1 이상의 임의의 양의 정수), 현재 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용되지 않을 수 있다. 여기서, 현재 블록의 넓이는 현재 블록에 포함된 휘도 샘플의 개수로 측정될 수 있다. 또 다른 예로, 현재 블록의 너비와 높이 중 작은 값이 K 이하인 경우 (K는 1 이상의 임의의 양의 정수), 현재 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용되지 않을 수 있다. 또는 현재 블록의 종횡비(aspect ratio, 너비/높이 또는 높이/너비)가 소정의 범위에 포함된 경우, 현재 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용되지 않을 수 있다.
일 실시 예에 따르면, 현재 블록에 화면 내 템플릿 매칭 (Intra template matching prediction, IntraTMP) 모드 또는 화면 내 블록 복사 (Intra block copy, IBC) 모드가 적용된 경우, 현재 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용되지 않을 수 있다.
일 실시 예에 따르면, 초기 화면 내 예측 모드의 인덱스 값이 T 값 이상인 경우 또는 U 값 이하인 경우 (T 및 U는 서로 다른 임의의 정수), 현재 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용되지 않을 수 있다. T 값과 U 값은 전체 화면 내 예측 모드의 개수에 따라 결정될 수 있다.
현재 블록의 MPM 리스트 생성 및 색차 성분의 다이렉트 모드 (direct mode, DM) 결정 등에 있어서, 참조 블록의 화면 내 예측 모드가 참조된다. 이 때, 참조 블록에 복호화측 화면 내 예측 모드 개선 방법이 적용된 경우, 참조 블록의 최종 화면 내 예측 모드 대신 초기 화면 내 예측 모드가 MPM 리스트 생성 및 색차 성분의 다이렉트 모드 결정에 이용될 수 있다.
복호화측 화면 내 예측 모드 개선 방법에 따르면, 복호화기는 인접 후보 모드의 왜곡의 계산에 있어서, 복호화측의 연산 부담이 증가할 수 있다. 따라서, 복호화기가 인접 후보 모드의 왜곡을 계산하는 대신, 부호화기가 현재 블록에 적용되는 인접 후보 모드에 대한 화면 내 예측 모드 개선 정보를 부호화할 수 있다. 그리고, 복호화기는 상기 화면 내 예측 모드 개선 정보에 기초하여 부호화측 화면 내 예측 모드 개선 (Encoder-side intra prediction mode refinement, EIMR)을 위한 최적의 인접 후보 모드를 결정할 수 있다.
일 실시 예에 따르면, 상기 화면 내 예측 모드 개선 정보는 화면 내 예측 모드 개선이 적용되는지 여부를 나타내는 화면 내 예측 모드 개선 적용 정보 및 인접 후보 모드들 중 최적의 인접 후보 모드를 나타내는 화면 내 예측 모드 개선 인덱스 정보를 포함할 수 있다. 상기 화면 내 예측 모드 개선 적용 정보가 현재 블록 또는 현재 블록의 상위 유닛 (부호화 트리 블록, 슬라이스, 타일, 픽처 등)에 적용됨을 나타낼 때, 화면 내 예측 모드 개선 인덱스 정보에 기초하여 최적의 후보 화면 내 예측 모드가 현재 블록의 최종 화면 내 예측 모드로 선택될 수 있다. 반대로, 상기 화면 내 예측 모드 개선 적용 정보가 현재 블록 또는 현재 블록의 상위 유닛에 적용되지 않음을 나타낼 때, 초기 화면 내 예측 모드가 현재 블록의 최종 화면 내 예측 모드로 선택될 수 있다.
복호화측 화면 내 예측 모드 개선 방법에 따르면, 초기 화면 내 예측 모드도 후보 화면 내 예측 모드에 포함된다. 그러나, 부호화측 화면 내 예측 모드 개선 방법에 따르면, 화면 내 예측 모드 개선 적용 정보가 화면 내 예측 개선이 적용됨을 나타낼 경우, 초기 화면 내 예측 모드는 후보 화면 내 예측 모드에서 제외된다.
상기 화면 내 예측 모드 개선 적용 정보는 1 비트 코드워드로 부호화될 수 있다. 상기 화면 내 예측 모드 개선 인덱스 정보는 후보 화면 내 예측 모드들 중 최적의 후보 화면 내 예측 모드들 나타낸다. 상기 최적의 후보 화면 내 예측 모드는 인접 후보 모드의 개수를 고려하여 소정의 인덱스로 매핑된다. 예를 들어, 인접 후보 모드가 4개일 경우, 상기 최적의 인접 후보 모드는 0 내지 3 중 하나의 값에 매핑된다. 그리고 상기 화면 내 예측 모드 개선 인덱스 정보는 매핑된 값을 나타내도록 설정된다. 상기 화면 내 예측 모드 개선 인덱스 정보는 고정 길이 코드(fixed length code, FLC), 절삭형 단항 코드(truncated unary code, TU), 부호 지수 골롬 (signed Exp-Golomb) 코드 등에 기초하여 부호화될 수 있다.
상기 화면 내 예측 모드 개선 인덱스 정보는 인접 후보 모드의 발생 빈도를 고려하여 부호화될 수 있다. 구체적으로, 발생 빈도가 높은 인접 후보 모드에 대하여 짧은 코드워드가 매칭되고, 발생 빈도가 낮은 인접 후보 모드에 대하여 긴 코드워드가 매칭될 수 있다. 그리고 초기 화면 내 예측 모드와의 인덱스 차이에 따라 인접 후보 모드의 발생 빈도가 차이가 있을 수 있다. 예를 들어, 초기 화면 내 예측 모드와 인덱스 차이의 절대 값이 가장 작은 인접 후보 모드의 발생 빈도가 제일 높을 수 있다. 따라서, 초기 화면 내 예측 모드와 인덱스 차이의 절대 값이 가장 작은 인접 후보 모드에 대하여 짧은 코드워드가 매칭될 수 있다. 그리고 초기 화면 내 예측 모드와 인덱스 차이의 절대 값이 가장 큰 인접 후보 모드에 대하여 긴 코드워드가 매칭될 수 있다.
일 실시 예에 따르면, 상기 화면 내 예측 모드 개선 인덱스 정보는 화면 내 예측 모드 개선 부호 정보 및 화면 내 예측 모드 개선 인덱스 차이 정보를 포함할 수 있다. 상기 화면 내 예측 모드 개선 부호 정보는 최적의 후보 화면 내 예측 모드가 초기 화면 내 예측 모드로부터 + 방향 및 - 방향 중 어느 방향에 있는지 나타낸다. 상기 화면 내 예측 모드 개선 인덱스 차이 정보는 최적의 후보 화면 내 예측 모드와 초기 화면 내 예측 모드의 인덱스 차이를 나타낸다.
상기 화면 내 예측 모드 개선 부호 정보는 1 비트 코드워드로 부호화될 수 있다. 만약 초기 화면 내 예측 모드가 소정의 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드 또는 가장 큰 인덱스의 화면 내 예측 모드인 경우 화면 내 예측 모드 개선 부호 정보는 부호화되지 않고, 화면 내 예측 모드 개선 인덱스 차이 정보만 부호화될 수 있다.
만약 인접 후보 모드가 각 방향마다 한 개만 있을 경우, 상기 화면 내 예측 모드 개선 인덱스 차이 정보는 부호화되지 않을 수 있다. 만약 인접 후보 모드가 각 방향에 대하여 두 개 이상 있을 경우, 상기 화면 내 예측 모드 개선 인덱스 차이 정보는 고정 길이 코드(fixed length code, FLC), 절삭형 단항 코드(truncated unary code, TU), 부호 지수 골롬 (signed Exp-Golomb) 코드 등에 기초하여 부호화될 수 있다.
상기 화면 내 예측 모드 개선 인덱스 차이 정보는 인접 후보 모드의 발생 빈도를 고려하여 부호화될 수 있다. 그리고 초기 화면 내 예측 모드와의 인덱스 차이에 따라 인접 후보 모드의 발생 빈도가 차이가 있을 수 있다. 예를 들어, 초기 화면 내 예측 모드와 인덱스 차이의 절대 값이 가장 작은 인접 후보 모드의 발생 빈도가 제일 높을 수 있다. 따라서, 초기 화면 내 예측 모드와 인덱스 차이의 절대 값이 가장 짧은 인접 후보 모드의 인덱스에 대하여 짧은 코드워드가 매칭될 수 있다. 그리고 초기 화면 내 예측 모드와 인덱스 차이의 절대 값이 가장 큰 인접 후보 모드의 인덱스에 대하여 긴 코드워드가 매칭될 수 있다.
도 11는 화면 내 예측 모드 개선이 적용되는 화면 내 예측 방법의 일 실시 예를 나타낸다.
단계 1102에서, 현재 블록의 초기 화면 내 예측 모드가 결정된다. 상기 현재 블록의 초기 화면 내 예측 모드는 참조 블록의 화면 내 예측 모드를 참조하여 결정될 수 있다. 만약 현재 블록의 참조 블록에 화면 내 예측 개선이 적용된 경우, 참조 블록의 초기 화면 내 예측 모드에 기초하여, 현재 블록의 초기 화면 내 예측 모드가 결정될 수 있다. 상기 참조 블록은, 현재 블록의 MPM (Most Probable Mode) 또는 DM (Direct Mode)를 결정할 때 참조되는 블록일 수 있다. 현재 블록의 MPM의 결정에 있어서, 상기 참조 블록은 현재 블록의 공간적 인접 블록일 수 있다. 크로마 성분의 현재 블록의 DM 의 결정에 있어서, 상기 참조 블록은 현재 블록에 대응되는 위치의 루마 성분의 대응 블록일 수 있다.
단계 1104에서, 현재 블록의 초기 화면 내 예측 모드에 기초하여, 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드가 결정된다.
일 실시 예에 따르면, 하나 이상의 인접 후보 모드는 현재 블록의 제1 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향의 사이의 예측 방향을 가진 제1 인접 후보 모드 및 현재 블록의 제2 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향의 사이의 예측 방향을 가진 제2 인접 후보 모드를 포함할 수 있다. 제1 인접 화면 내 예측 모드는 초기 화면 내 예측 모드의 인덱스보다 소정의 값 만큼 작은 인덱스를 가지고, 제2 인접 화면 내 예측 모드는 초기 화면 내 예측 모드의 인덱스보다 소정의 값 만큼 큰 인덱스를 가진다.
일 실시 예에 따르면, 제1 인접 후보 모드는 현재 블록의 제1 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향의 방향 차이를 제1 인접 후보 모드의 개수에 따라 균등 분할하여 결정된다. 즉, 제1 인접 후보 모드 간의 방향 차이 및 제1 인접 후보 모드와 초기 화면 내 예측 모드 간의 방향 차이는 균등하게 결정된다.
마찬가지로, 제2 인접 후보 모드는 현재 블록의 제2 인접 화면 내 예측 모드의 예측 방향과 초기 화면 내 예측 모드의 예측 방향의 방향 차이를 제2 인접 후보 모드의 개수에 따라 균등 분할하여 결정된다. 즉, 제2 인접 후보 모드 간의 방향 차이 및 제2 인접 후보 모드와 초기 화면 내 예측 모드 간의 방향 차이는 균등하게 결정된다.
일 실시 예에 따르면, 초기 화면 내 예측 모드가 소정 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드인 경우, 하나 이상의 인접 후보 모드에 제2 인접 화면 내 예측 모드만 포함될 수 있다. 반대로 초기 화면 내 예측 모드가 소정 범위의 방향성 모드들 중 가장 큰 인덱스의 화면 내 예측 모드인 경우, 하나 이상의 인접 후보 모드에 상기 제1 인접 화면 내 예측 모드만 포함될 수 있다.
단계 1106에서, 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 현재 블록의 최종 화면 내 예측 모드가 결정된다.
일 실시 예에 따르면, 현재 블록의 후보 화면 내 예측 모드들 중 왜곡도가 가장 작은 모드가 현재 블록의 최종 화면 내 예측 모드로 결정될 수 있다. 이때, 현재 블록에 인접한 템플릿에 포함된 복원 샘플과 복원 샘플에 대응되는 예측 샘플의 차이에 기초하여 후보 화면 내 예측 모드의 왜곡도가 결정될 수 있다. 그리고 예측 샘플은 템플릿에 인접한 템플릿 참조 샘플 및 후보 화면 내 예측 모드의 예측 방향에 기초하여 결정될 수 있다.
일 실시 예에 따르면, 현재 블록의 후보 화면 내 예측 모드들 중 현재 블록의 최종 화면 내 예측 모드를 나타내는 화면 내 예측 모드 개선 인덱스 정보가 비트스트림으로부터 획득될 수 있다. 그리고 화면 내 예측 모드 개선 인덱스 정보에 기초하여 현재 블록의 최종 화면 내 예측 모드가 결정될 수 있다.
일 실시 예에 따르면, 화면 내 예측 모드 개선 인덱스 정보는 최종 화면 내 예측 모드가 초기 화면 내 예측 모드로부터 + 방향 및 - 방향 중 어느 방향에 있는지 나타내는 화면 내 예측 모드 개선 부호 정보와 최종 화면 내 예측 모드와 초기 화면 내 예측 모드의 인덱스 차이를 나타내는 화면 내 예측 모드 개선 인덱스 차이 정보를 포함할 수 있다. 따라서, 화면 내 예측 모드 개선 인덱스 부호 정보에 따른 부호와 화면 내 예측 모드 개선 인덱스 차이 정보에 따른 인덱스 차이에 따라, 현재 블록의 최종 화면 내 예측 모드가 유도될 수 있다.
일 실시 예에 따르면, 화면 내 예측 모드 개선 인덱스 차이 정보가 나타내는 인덱스 차이의 심볼들 각각에 대하여 소정 길이의 코드워드가 할당된다. 이 때, 초기 화면 내 예측 모드와 후보 화면 내 예측 모드의 인덱스 차이에 기초하여, 후보 화면 내 예측 모드에 할당된 코드워드의 길이가 결정될 수 있다. 예를 들어, 작은 인덱스 차이의 심볼에 대하여 짧은 길이의 코드워드가 할당될 수 있다.
단계 1108에서, 현재 블록의 최종 화면 내 예측 모드에 기초하여, 현재 블록이 예측된다.
일 실시 예에 따르면, 영상 복호화 방법은 상기 현재 블록에 화면 내 예측 개선이 수행되는지 여부를 결정하는 단계를 더 포함할 수 있다. 상기 현재 블록에 화면 내 예측 개선이 수행될 경우, 단계 1104 내지 1108이 수행될 수 있다. 상기 현재 블록에 화면 내 예측 개선이 수행되지 않을 경우, 단계 1104 내지 1108이 생략되고, 상기 현재 블록의 초기 화면 내 예측 모드에 기초하여 상기 현재 블록이 예측될 수 있다.
일 실시 예에 따르면, 초기 화면 내 예측 모드가 비방향성 화면 내 예측 모드일 경우, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않는 것으로 결정될 수 있다.
일 실시 예에 따르면, 초기 화면 내 예측 모드의 인덱스가 소정 범위에 포함되지 않은 경우, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않는 것으로 결정될 수 있다.
일 실시 예에 따르면, 현재 블록의 너비, 높이, 넓이, 및 종횡비 중 적어도 하나에 따라, 현재 블록에 화면 내 예측 개선이 수행되는지 여부가 결정될 수 있다.
단계 1102 내지 1108에서 수행된 예측 방법에 따라, 현재 블록이 부호화 또는 복호화될 수 있다. 일부 실시 예의 화면 내 예측 모드 개선 인덱스 정보는 부호화기에서는 예측 결과에 따라 부호화된다. 그리고 화면 내 예측 모드 개선 인덱스 정보는 복호화기에서 복호화되어, 최종 화면 내 예측 모드 도출에 이용될 수 있다.
그리고 단계 1102 내지 1108에서 수행된 예측 방법에 따라 부호화기에 의하여 생성된 비트스트림은 기록매체에 저장되거나 부호화기 외부로 전송될 수 있다.
도 12은 본 발명에 따른 실시 예가 적용될 수 있는 컨텐츠 스트리밍 시스템을 예시적으로 나타내는 도면이다.
도 12에 도시된 바와 같이, 본 발명의 실시 예가 적용된 컨텐츠 스트리밍 시스템은 크게 인코딩 서버, 스트리밍 서버, 웹 서버, 미디어 저장소, 사용자 장치 및 멀티미디어 입력 장치를 포함할 수 있다.
상기 인코딩 서버는 스마트폰, 카메라, CCTV 등과 같은 멀티미디어 입력 장치들로부터 입력된 컨텐츠를 디지털 데이터로 압축하여 비트스트림을 생성하고 이를 상기 스트리밍 서버로 전송하는 역할을 한다. 다른 예로, 스마트폰, 카메라, CCTV 등과 같은 멀티미디어 입력 장치들이 비트스트림을 직접 생성하는 경우, 상기 인코딩 서버는 생략될 수도 있다.
상기 비트스트림은 본 발명의 실시예가 적용된 영상 부호화 방법 및/또는 영상 부호화 장치에 의해 생성될 수 있고, 상기 스트리밍 서버는 상기 비트스트림을 전송 또는 수신하는 과정에서 일시적으로 상기 비트스트림을 저장할 수 있다.
상기 스트리밍 서버는 웹 서버를 통한 사용자 요청에 기반하여 멀티미디어 데이터를 사용자 장치에 전송하고, 상기 웹 서버는 사용자에게 어떠한 서비스가 있는지를 알려주는 매개체 역할을 할 수 있다. 사용자가 상기 웹 서버에 원하는 서비스를 요청하면, 상기 웹 서버는 이를 스트리밍 서버에 전달하고, 상기 스트리밍 서버는 사용자에게 멀티미디어 데이터를 전송할 수 있다. 이때, 상기 컨텐츠 스트리밍 시스템은 별도의 제어 서버를 포함할 수 있고, 이 경우 상기 제어 서버는 상기 컨텐츠 스트리밍 시스템 내 각 장치 간 명령/응답을 제어하는 역할을 수행할 수 있다.
상기 스트리밍 서버는 미디어 저장소 및/또는 인코딩 서버로부터 컨텐츠를 수신할 수 있다. 예를 들어, 상기 인코딩 서버로부터 컨텐츠를 수신하는 경우, 상기 컨텐츠를 실시간으로 수신할 수 있다. 이 경우, 원활한 스트리밍 서비스를 제공하기 위하여 상기 스트리밍 서버는 상기 비트스트림을 일정 시간동안 저장할 수 있다.
상기 사용자 장치의 예로는, 휴대폰, 스마트 폰(smart phone), 노트북 컴퓨터(laptop computer), 디지털방송용 단말기, PDA(personal digital assistants), PMP(portable multimedia player), 네비게이션, 슬레이트 PC(slate PC), 태블릿 PC(tablet PC), 울트라북(ultrabook), 웨어러블 디바이스(wearable device, 예를 들어, 워치형 단말기 (smartwatch), 글래스형 단말기 (smart glass), HMD(head mounted display)), 디지털 TV, 데스크탑 컴퓨터, 디지털 사이니지 등이 있을 수 있다.
상기 컨텐츠 스트리밍 시스템 내 각 서버들은 분산 서버로 운영될 수 있으며, 이 경우 각 서버에서 수신하는 데이터는 분산 처리될 수 있다.
상기의 실시 예들은 부호화 장치 및 복호화 장치에서 동일한 방법 또는 상응하는 방법으로 수행될 수 있다. 또한, 상기 실시 예들 중 적어도 하나 혹은 적어도 하나의 조합을 이용해서 영상을 부호화/복호화할 수 있다.
상기 실시 예들이 적용되는 순서는 부호화 장치와 복호화 장치에서 상이할 수 있다. 또는, 상기 실시 예들이 적용되는 순서는 부호화 장치와 복호화 장치에서 동일할 수 있다.
상기 실시 예들은 휘도 및 색차 신호 각각에 대하여 수행될 수 있다. 또는, 휘도 및 색차 신호에 대한 상기 실시예들이 동일하게 수행될 수 있다.
상기 실시 예들에서, 방법들은 일련의 단계 또는 유닛으로서 순서도를 기초로 설명되고 있으나, 본 발명은 단계들의 순서에 한정되는 것은 아니며, 어떤 단계는 상술한 바와 다른 단계와 다른 순서로 또는 동시에 발생할 수 있다. 또한, 당해 기술 분야에서 통상의 지식을 가진 자라면 순서도에 나타난 단계들이 배타적이지 않고, 다른 단계가 포함되거나, 순서도의 하나 또는 그 이상의 단계가 본 발명의 범위에 영향을 미치지 않고 삭제될 수 있음을 이해할 수 있을 것이다.
상기 실시예들은 다양한 컴퓨터 구성요소를 통하여 수행될 수 있는 프로그램 명령어의 형태로 구현되어 컴퓨터 판독 가능한 기록 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능한 기록 매체는 프로그램 명령어, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 컴퓨터 판독 가능한 기록 매체에 기록되는 프로그램 명령어는 본 발명을 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 분야의 당업자에게 공지되어 사용 가능한 것일 수도 있다.
상기 실시예에 따른 부호화 방법에 의해 생성된 비트스트림은 비 일시적인 컴퓨터 판독 가능한 기록 매체에 저장될 수 있다. 또한, 상기 비 일시적인 컴퓨터 판독 가능한 기록 매체에 저장되는 비트스트림은 상기 실시예에 따른 복호화 방법에 의해 복호화될 수 있다.
여기서, 컴퓨터 판독 가능한 기록 매체의 예에는, 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체, CD-ROM, DVD와 같은 광기록 매체, 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 ROM, RAM, 플래시 메모리 등과 같은 프로그램 명령어를 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령어의 예에는, 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드도 포함된다. 상기 하드웨어 장치는 본 발명에 따른 처리를 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.
이상에서 본 발명이 구체적인 구성요소 등과 같은 특정 사항들과 한정된 실시예 및 도면에 의해 설명되었으나, 이는 본 발명의 보다 전반적인 이해를 돕기 위해서 제공된 것일 뿐, 본 발명이 상기 실시예들에 한정되는 것은 아니며, 본 발명이 속하는 기술분야에서 통상적인 지식을 가진 자라면 이러한 기재로부터 다양한 수정 및 변형을 꾀할 수 있다.
따라서, 본 발명의 사상은 상기 설명된 실시예에 국한되어 정해져서는 아니 되며, 후술하는 특허청구범위뿐만 아니라 이 특허청구범위와 균등하게 또는 등가적으로 변형된 모든 것들은 본 발명의 사상의 범주에 속한다고 할 것이다.
본 발명은 영상을 부호화/복호화하는 장치 및 비트스트림을 저장한 기록 매체에 이용될 수 있다.
Claims (18)
- 영상 복호화 방법에 있어서,현재 블록의 초기 화면 내 예측 모드를 결정하는 단계;상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계;상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계; 및상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계를 포함하는 영상 복호화 방법.
- 제1항에 있어서,상기 영상 복호화 방법은,상기 현재 블록에 화면 내 예측 개선이 수행되는지 여부를 결정하는 단계를 더 포함하고,상기 현재 블록에 화면 내 예측 개선이 수행될 경우, 상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계, 상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계, 및 상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계가 수행되고,상기 현재 블록에 화면 내 예측 개선이 수행되지 않을 경우, 상기 현재 블록의 초기 화면 내 예측 모드에 기초하여 상기 현재 블록이 예측되는 것을 특징으로 하는 영상 복호화 방법.
- 제2항에 있어서,상기 초기 화면 내 예측 모드가 비방향성 화면 내 예측 모드일 경우, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않는 것으로 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제2항에 있어서,상기 초기 화면 내 예측 모드의 인덱스가 소정 범위에 포함되지 않은 경우, 상기 현재 블록에 화면 내 예측 개선이 수행되지 않는 것으로 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제2항에 있어서,상기 현재 블록의 너비, 높이, 넓이, 및 종횡비 중 적어도 하나에 따라, 상기 현재 블록에 화면 내 예측 개선이 수행되는지 여부가 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제1항에 있어서,상기 현재 블록의 참조 블록에 화면 내 예측 개선이 적용된 경우, 상기 참조 블록의 초기 화면 내 예측 모드에 기초하여, 상기 현재 블록의 초기 화면 내 예측 모드가 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제1항에 있어서,상기 하나 이상의 인접 후보 모드는,상기 현재 블록의 제1 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 사이의 예측 방향을 가진 제1 인접 후보 모드, 및상기 현재 블록의 제2 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 사이의 예측 방향을 가진 제2 인접 후보 모드를 포함하고,상기 제1 인접 화면 내 예측 모드는,상기 초기 화면 내 예측 모드의 인덱스보다 소정의 값 만큼 작은 인덱스를 가지고,상기 제2 인접 화면 내 예측 모드는,상기 초기 화면 내 예측 모드의 인덱스보다 소정의 값 만큼 큰 인덱스를 가지는 것을 특징으로 하는 영상 복호화 방법.
- 제7항에 있어서,상기 제1 인접 후보 모드는 상기 현재 블록의 제1 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 방향 차이를 상기 제1 인접 후보 모드의 개수에 따라 균등 분할하여 결정되고,상기 제2 인접 후보 모드는 상기 현재 블록의 제2 인접 화면 내 예측 모드의 예측 방향과 상기 초기 화면 내 예측 모드의 예측 방향의 방향 차이를 상기 제2 인접 후보 모드의 개수에 따라 균등 분할하여 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제7항에 있어서,상기 초기 화면 내 예측 모드가 소정 범위의 방향성 모드들 중 가장 작은 인덱스의 화면 내 예측 모드인 경우, 상기 하나 이상의 인접 후보 모드는, 상기 제2 인접 화면 내 예측 모드만 포함하고,상기 초기 화면 내 예측 모드가 소정 범위의 방향성 모드들 중 가장 큰 인덱스의 화면 내 예측 모드인 경우, 상기 하나 이상의 인접 후보 모드는, 상기 제1 인접 화면 내 예측 모드만 포함하는 것을 특징으로 하는 영상 복호화 방법.
- 제1항에 있어서,상기 현재 블록의 후보 화면 내 예측 모드들 중 왜곡도가 가장 작은 모드가 상기 현재 블록의 최종 화면 내 예측 모드로 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제10항에 있어서,상기 현재 블록에 인접한 템플릿에 포함된 복원 샘플과 상기 복원 샘플에 대응되는 예측 샘플의 차이에 기초하여 상기 후보 화면 내 예측 모드의 왜곡도가 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제11항에 있어서,상기 예측 샘플은 상기 템플릿에 인접한 템플릿 참조 샘플 및 상기 후보 화면 내 예측 모드의 예측 방향에 기초하여 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제1항에 있어서,상기 영상 복호화 방법은,상기 현재 블록의 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 나타내는 화면 내 예측 모드 개선 인덱스 정보를 비트스트림으로부터 획득하는 단계를 더 포함하고,상기 현재 블록의 최종 화면 내 예측 모드는 상기 화면 내 예측 모드 개선 인덱스 정보에 기초하여 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 제13항에 있어서,상기 화면 내 예측 모드 개선 인덱스 정보는,상기 최종 화면 내 예측 모드가 상기 초기 화면 내 예측 모드로부터 + 방향 및 - 방향 중 어느 방향에 있는지 나타내는 화면 내 예측 모드 개선 부호 정보, 및상기 최종 화면 내 예측 모드와 상기 초기 화면 내 예측 모드의 인덱스 차이를 나타내는 화면 내 예측 모드 개선 인덱스 차이 정보를 포함하는 것을 특징으로 하는 영상 복호화 방법.
- 제14항에 있어서,상기 화면 내 예측 모드 개선 인덱스 차이 정보에 있어서,상기 초기 화면 내 예측 모드와 상기 후보 화면 내 예측 모드의 인덱스 차이에 기초하여, 상기 후보 화면 내 예측 모드에 할당된 코드워드의 길이가 결정되는 것을 특징으로 하는 영상 복호화 방법.
- 영상 부호화 방법에 있어서,현재 블록의 초기 화면 내 예측 모드를 결정하는 단계;상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계;상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계; 및상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계를 포함하는 영상 부호화 방법.
- 영상 부호화 방법에 의하여 생성된 비트스트림을 저장한 컴퓨터로 판독가능한 기록매체에 있어서,영상 부호화 방법에 있어서,현재 블록의 초기 화면 내 예측 모드를 결정하는 단계;상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계;상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계; 및상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계를 포함하는 기록매체.
- 영상 부호화 방법에 의하여 생성된 비트스트림을 전송하는 비트스트림 전송 방법에 있어서,상기 영상 부호화 방법에 기초하여 영상을 부호화하는 단계; 및상기 부호화된 영상이 포함된 비트스트림을 전송하는 단계를 포함하고,상기 영상 부호화 방법은,현재 블록의 초기 화면 내 예측 모드를 결정하는 단계;상기 현재 블록의 초기 화면 내 예측 모드에 기초하여, 상기 초기 화면 내 예측 모드에 인접한 하나 이상의 인접 후보 모드를 결정하는 단계;상기 하나 이상의 인접 후보 모드를 포함하는 후보 화면 내 예측 모드들 중 상기 현재 블록의 최종 화면 내 예측 모드를 결정하는 단계; 및상기 현재 블록의 최종 화면 내 예측 모드에 기초하여 상기 현재 블록을 예측하는 단계를 포함하는 비트스트림 전송 방법.
Priority Applications (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| CN202480025049.4A CN121128165A (zh) | 2023-06-08 | 2024-06-05 | 图像编码/解码的方法和装置以及用于存储比特流的记录介质 |
Applications Claiming Priority (4)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| KR10-2023-0073307 | 2023-06-08 | ||
| KR20230073307 | 2023-06-08 | ||
| KR1020240073540A KR20240174498A (ko) | 2023-06-08 | 2024-06-05 | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 |
| KR10-2024-0073540 | 2024-06-05 |
Publications (1)
| Publication Number | Publication Date |
|---|---|
| WO2024253427A1 true WO2024253427A1 (ko) | 2024-12-12 |
Family
ID=93796150
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| PCT/KR2024/007711 Pending WO2024253427A1 (ko) | 2023-06-08 | 2024-06-05 | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 |
Country Status (1)
| Country | Link |
|---|---|
| WO (1) | WO2024253427A1 (ko) |
Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| KR101585565B1 (ko) * | 2011-06-17 | 2016-01-14 | 미디어텍 인크. | 인트라 예측 모드의 코딩을 위한 방법 및 장치 |
| US20190166370A1 (en) * | 2016-05-06 | 2019-05-30 | Vid Scale, Inc. | Method and system for decoder-side intra mode derivation for block-based video coding |
| KR20200007044A (ko) * | 2017-06-22 | 2020-01-21 | 후아웨이 테크놀러지 컴퍼니 리미티드 | 인트라-프레임 예측 방법 및 장치 |
| KR20220159464A (ko) * | 2021-04-26 | 2022-12-02 | 텐센트 아메리카 엘엘씨 | 디코더 측 인트라 모드 도출 |
| KR20230058166A (ko) * | 2021-08-02 | 2023-05-02 | 텐센트 아메리카 엘엘씨 | 개선된 인트라 예측을 위한 방법 및 장치 |
-
2024
- 2024-06-05 WO PCT/KR2024/007711 patent/WO2024253427A1/ko active Pending
Patent Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| KR101585565B1 (ko) * | 2011-06-17 | 2016-01-14 | 미디어텍 인크. | 인트라 예측 모드의 코딩을 위한 방법 및 장치 |
| US20190166370A1 (en) * | 2016-05-06 | 2019-05-30 | Vid Scale, Inc. | Method and system for decoder-side intra mode derivation for block-based video coding |
| KR20200007044A (ko) * | 2017-06-22 | 2020-01-21 | 후아웨이 테크놀러지 컴퍼니 리미티드 | 인트라-프레임 예측 방법 및 장치 |
| KR20220159464A (ko) * | 2021-04-26 | 2022-12-02 | 텐센트 아메리카 엘엘씨 | 디코더 측 인트라 모드 도출 |
| KR20230058166A (ko) * | 2021-08-02 | 2023-05-02 | 텐센트 아메리카 엘엘씨 | 개선된 인트라 예측을 위한 방법 및 장치 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| WO2024039155A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2023239147A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2023200214A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2023200206A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024253427A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025110783A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024253506A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025135613A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024253365A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2026019073A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025084817A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025192990A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2026063631A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024262870A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025005615A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024210648A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025023735A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025037911A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025009816A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024210624A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024253465A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024258110A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2025192907A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024262883A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 | |
| WO2024053963A1 (ko) | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| 121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 24819578 Country of ref document: EP Kind code of ref document: A1 |
|
| NENP | Non-entry into the national phase |
Ref country code: DE |