KR20110036401A - Method and apparatus for encoding video, and method and apparatus for decoding video - Google Patents
Method and apparatus for encoding video, and method and apparatus for decoding video Download PDFInfo
- Publication number
- KR20110036401A KR20110036401A KR1020090094050A KR20090094050A KR20110036401A KR 20110036401 A KR20110036401 A KR 20110036401A KR 1020090094050 A KR1020090094050 A KR 1020090094050A KR 20090094050 A KR20090094050 A KR 20090094050A KR 20110036401 A KR20110036401 A KR 20110036401A
- Authority
- KR
- South Korea
- Prior art keywords
- pixel
- prediction
- coding unit
- unit
- value
- Prior art date
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/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/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/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/182—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being a pixel
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Description
본 발명은 예측된 영상 데이터의 후처리를 통해 영상의 압축 효율을 향상시키는 영상의 부호화 방법 및 장치, 그 복호화 방법 및 장치에 관한 것이다.The present invention relates to a video encoding method and apparatus for improving the compression efficiency of an image through post-processing of predicted image data, and a decoding method and apparatus thereof.
MPEG-1, MPEG-2, MPEG-4, H.264/MPEG-4 AVC(Advanced Video Coding)와 같은 영상 압축 방식에서는 영상을 부호화하기 위해서 하나의 픽처를 매크로 블록으로 나눈다. 그리고, 인터 예측 및 인트라 예측에서 이용가능한 모든 부호화 모드에서 각각의 매크로 블록을 부호화한 다음, 매크로 블록의 부호화에 소요되는 비트율과 원 매크로 블록과 복호화된 매크로 블록과의 왜곡 정도에 따라서 부호화 모드를 하나 선택하여 매크로 블록을 부호화한다.In video compression schemes such as MPEG-1, MPEG-2, MPEG-4, and H.264 / MPEG-4 Advanced Video Coding (AVC), a picture is divided into macro blocks to encode an image. Each macroblock is encoded in all encoding modes available for inter prediction and intra prediction, and then one encoding mode is selected according to the bit rate required for encoding the macro block and the degree of distortion of the original macro block and the decoded macro block. Select to encode the macro block.
고해상도 또는 고화질 비디오 컨텐트를 재생, 저장할 수 있는 하드웨어의 개발 및 보급에 따라, 고해상도 또는 고화질 비디오 컨텐트를 효과적으로 부호화하거나 복호화하는 비디오 코덱의 필요성이 증대하고 있다. 기존의 비디오 코덱에 따르면, 비디오는 소정 크기의 매크로블록에 기반하여 제한된 예측 모드에 따라 부호화되고 있다.With the development and dissemination of hardware capable of playing and storing high resolution or high definition video content, there is an increasing need for a video codec for efficiently encoding or decoding high resolution or high definition video content. According to the existing video codec, video is encoded according to a limited prediction mode based on a macroblock of a predetermined size.
본 발명이 해결하고자 하는 과제는 예측 블록에 대한 후처리를 통해 예측 블록 내부의 각 픽셀의 픽셀값을 변경하여 새로운 예측 블록을 생성함으로써 영상의 압축 효율을 향상시키는 영상의 부호화 방법 및 장치, 그 복호화 방법 및 장치를 제공하는 것이다.The problem to be solved by the present invention is to encode a video encoding method and apparatus for improving the compression efficiency of the image by changing the pixel value of each pixel in the prediction block through post-processing on the prediction block, decoding It is to provide a method and apparatus.
본 발명의 일 실시예에 따른 영상의 부호화 방법은 부호화되는 현재 부호화 단위에 대한 제 1 예측 부호화 단위를 생성하는 단계; 상기 제 1 예측 부호화 단위를 구성하는 각 픽셀과 적어도 하나의 주변 픽셀을 이용하여 상기 각 픽셀의 픽셀값을 변경하여 제 2 예측 부호화 단위를 생성하는 단계; 및 상기 현재 부호화 단위와 상기 제 2 예측 부호화 단위의 차이값을 부호화하는 단계를 포함하는 것을 특징으로 한다.An image encoding method according to an embodiment of the present invention includes generating a first prediction coding unit for a current coding unit to be encoded; Generating a second prediction coding unit by changing a pixel value of each pixel by using each pixel constituting the first prediction coding unit and at least one neighboring pixel; And encoding a difference value between the current coding unit and the second prediction coding unit.
본 발명의 일 실시예에 따른 영상의 부호화 장치는 부호화되는 현재 부호화 단위에 대한 제 1 예측 부호화 단위를 생성하는 예측부; 상기 제 1 예측 부호화 단위를 구성하는 각 픽셀과 적어도 하나의 주변 픽셀을 이용하여 상기 각 픽셀의 픽셀값을 변경하여 제 2 예측 부호화 단위를 생성하는 후처리부; 및 상기 현재 부호화 단위와 상기 제 2 예측 부호화 단위의 차이값을 부호화하는 부호화부를 포함하는 것을 특징으로 한다.An image encoding apparatus according to an embodiment of the present invention includes a prediction unit generating a first prediction coding unit for a current coding unit to be encoded; A post processor configured to generate a second prediction coding unit by changing a pixel value of each pixel by using each pixel constituting the first prediction coding unit and at least one neighboring pixel; And an encoder which encodes a difference between the current coding unit and the second prediction coding unit.
본 발명의 일 실시예에 따른 영상 복호화 방법은 수신된 비트스트림으로부터 복호화되는 현재 복호화 단위의 예측 모드 정보를 추출하는 단계; 상기 추출된 예측 모드 정보에 따라서 상기 현재 복호화 단위에 대한 제 1 예측 복호화 단위를 생 성하는 단계; 상기 비트스트림으로부터 상기 제 1 예측 복호화 단위를 구성하는 각 픽셀과 상기 각 픽셀의 주변 픽셀들을 이용한 연산 정보를 추출하는 단계; 상기 추출된 연산 정보에 따라서 상기 제 1 예측 복호화 단위를 구성하는 각 픽셀과 상기 각 픽셀의 주변 픽셀들을 이용하여 상기 각 픽셀의 픽셀값을 변경하여 제 2 예측 복호화 단위를 생성하는 단계; 상기 비트스트림으로부터 상기 현재 복호화 단위와 상기 제 2 예측 복호화 단위의 차이값에 해당하는 레지듀얼을 추출하여 복원하는 단계; 및 상기 레지듀얼과 상기 제 2 예측 복호화 단위를 가산하여 상기 현재 복호화 단위를 복호화하는 단계를 포함하는 것을 특징으로 한다.An image decoding method according to an embodiment of the present invention includes extracting prediction mode information of a current decoding unit to be decoded from a received bitstream; Generating a first prediction decoding unit for the current decoding unit according to the extracted prediction mode information; Extracting operation information using each pixel constituting the first prediction decoding unit and neighboring pixels of the pixel from the bitstream; Generating a second prediction decoding unit by changing a pixel value of each pixel using each pixel constituting the first prediction decoding unit and peripheral pixels of each pixel according to the extracted operation information; Extracting and reconstructing a residual corresponding to a difference between the current decoding unit and the second prediction decoding unit from the bitstream; And decoding the current decoding unit by adding the residual and the second prediction decoding unit.
본 발명의 일 실시예에 따른 영상 복호화 장치는 수신된 비트스트림으로부터 복호화되는 현재 복호화 단위의 예측 모드 정보 및 상기 현재 복호화 단위에 대한 제 1 예측 복호화 단위를 구성하는 각 픽셀과 상기 각 픽셀의 주변 픽셀들을 이용한 연산 정보를 추출하는 엔트로피 디코더; 상기 추출된 예측 모드 정보에 따라서 상기 제 1 예측 복호화 단위를 생성하는 예측부; 상기 추출된 연산 정보에 따라서 상기 제 1 예측 복호화 단위를 구성하는 각 픽셀과 상기 각 픽셀의 주변 픽셀들을 이용하여 상기 각 픽셀의 픽셀값을 변경하여 제 2 예측 복호화 단위를 생성하는 후처리부; 상기 비트스트림으로부터 상기 현재 복호화 단위와 상기 제 2 예측 복호화 단위의 차이값에 해당하는 레지듀얼을 복원하는 역변환 및 역양자화부; 및 상기 레지듀얼과 상기 제 2 예측 복호화 단위를 가산하여 상기 현재 복호화 단위를 복호화하는 가산부를 포함하는 것을 특징으로 한다.An image decoding apparatus according to an embodiment of the present invention includes each pixel constituting prediction mode information of a current decoding unit decoded from a received bitstream and a first prediction decoding unit for the current decoding unit, and neighboring pixels of each pixel. An entropy decoder for extracting operation information using the apparatus; A prediction unit generating the first prediction decoding unit according to the extracted prediction mode information; A post processor configured to generate a second prediction decoding unit by changing a pixel value of each pixel using each pixel constituting the first prediction decoding unit and peripheral pixels of each pixel according to the extracted operation information; An inverse transform and inverse quantizer for restoring a residual corresponding to a difference between the current decoding unit and the second prediction decoding unit from the bitstream; And an adder configured to add the residual and the second prediction decoding unit to decode the current decoding unit.
이하 첨부된 도면을 참조하여 본 발명의 바람직한 실시예들에 따른 영상 부호화 장치 및 영상 복호화 장치, 영상 부호화 방법 및 영상 복호화 방법을 설명한다.Hereinafter, an image encoding apparatus, an image decoding apparatus, an image encoding method, and an image decoding method according to exemplary embodiments of the present invention will be described with reference to the accompanying drawings.
도 1은 본 발명의 일 실시예에 따른 영상 부호화 장치의 블록도이다.1 is a block diagram of an image encoding apparatus according to an embodiment of the present invention.
도 1을 참조하면, 본 발명의 일 실시예에 따른 영상 부호화 장치(100)는 최대 부호화 단위 분할부(110), 부호화 심도 결정부(120), 영상 데이터 부호화부(130) 및 부호화 정보 부호화부(140)를 포함한다.Referring to FIG. 1, an image encoding
최대 부호화 단위 분할부(110)는 최대 크기의 부호화 단위인 최대 부호화 단위에 기반하여 현재 픽처 또는 현재 슬라이스를 분할한다. 현재 픽처 또는 현재 슬라이스는 적어도 하나의 최대 부호화 단위로 분할된다. 분할된 영상 데이터는 적어도 하나의 최대 부호화 단위별로 부호화 심도 결정부(120)로 출력될 수 있다.The maximum
본 발명의 일 실시예에 따르면, 최대 부호화 단위 및 심도를 이용해 부호화 단위가 표현될 수 있다. 최대 부호화 단위는 현재 픽처의 부호화 단위 중 크기가 가장 큰 부호화 단위를 나타내며, 심도는 부호화 단위가 계층적으로 축소된 서브 부호화 단위의 크기를 나타낸다. 심도가 커지면서, 부호화 단위는 최대 부호화 단위로부터 최소 부호화 단위까지 축소될 수 있으며, 최대 부호화 단위의 심도는 최소 심도로 정의되고, 최소 부호화 단위의 심도는 최대 심도로 정의될 수 있다. 최대 부호화 단위는 심도가 커짐에 따라 심도별 부호화 단위의 크기는 감소하므로, k 심도의 서브 부호화 단위는 k+1 이상의 심도를 갖는 복수 개의 서브 부호화 단위를 포함할 수 있다.According to an embodiment of the present invention, a coding unit may be expressed using a maximum coding unit and a depth. The maximum coding unit represents a coding unit having the largest size among the coding units of the current picture, and the depth represents the size of a sub coding unit in which the coding unit is hierarchically reduced. As the depth increases, the coding unit may be reduced from the maximum coding unit to the minimum coding unit, the depth of the maximum coding unit may be defined as the minimum depth, and the depth of the minimum coding unit may be defined as the maximum depth. As the maximum coding unit decreases as the depth increases, the size of the coding unit for each depth decreases, and thus, a sub-coding unit having a depth of k may include a plurality of sub-coding units having a depth of k + 1 or more.
전술한 바와 같이 부호화 단위의 최대 크기에 따라, 현재 픽처의 영상 데이터를 최대 부호화 단위로 분할하며, 각각의 최대 부호화 단위는 심도별로 축소되는 부호화 단위들을 포함할 수 있다. 본 발명의 일 실시예에 따른 최대 부호화 단위는 심도별로 축소되므로, 최대 부호화 단위에 포함된 공간 영역(spatial domain)의 영상 데이터가 심도에 따라 계층적으로 분류될 수 있다. As described above, the image data of the current picture is divided into the largest coding units according to the maximum size of the coding units, and each maximum coding unit may include coding units reduced by depth. Since the maximum coding unit is reduced for each depth according to an embodiment of the present invention, image data of a spatial domain included in the maximum coding unit may be hierarchically classified according to the depth.
최대 부호화 단위로부터 최상위 부호화 단위까지 현재 부호화 단위의 높이 및 너비를 계층적으로 축소한 총 횟수를 제한하는 최대 심도 및 부호화 단위의 최대 크기가 미리 설정되어 있을 수 있다. 이러한 최대 부호화 단위 및 최대 심도는 픽처 또는 슬라이스 단위로 설정될 수 있다. 즉, 픽처 또는 슬라이스마다 상이한 최대 부호화 단위 및 최대 심도를 갖을 수 있으며, 최대 심도에 따라 최대 영상 부호화 단위에 포함된 최소 부호화 단위 크기를 가변적으로 설정할 수 있다. 이와 같이 픽처 또는 슬라이스마다 최대 부호화 단위 및 최대 심도를 가변적으로 설정할 수 있게 함으로써, 평탄한 영역의 영상은 보다 큰 최대 부호화 단위를 이용하여 부호화함으로써 압축률을 향상시키고, 복잡도가 큰 영상은 보다 작은 크기의 부호화 단위를 이용하여 영상의 압축 효율을 향상시킬 수 있다.The maximum depth and the maximum size of the coding unit that limit the total number of hierarchically reduced heights and widths of the current coding unit from the maximum coding unit to the highest coding unit may be preset. The maximum coding unit and the maximum depth may be set in picture or slice units. That is, each picture or slice may have a different maximum coding unit and maximum depth, and the minimum coding unit size included in the maximum image coding unit may be variably set according to the maximum depth. In this way, the maximum coding unit and the maximum depth can be variably set for each picture or slice, so that a flat area image is encoded using a larger maximum coding unit, thereby improving the compression rate, and a large complexity image is encoded with a smaller size. By using the unit, the compression efficiency of the image can be improved.
부호화 심도 결정부(120)는 최대 부호화 단위마다 상이한 최대 심도를 결정한다. 최대 심도는 R-D 코스트(Rate-Distortion Cost) 계산에 기초해 결정될 수 있다. 결정된 최대 심도는 부호화 정보 부호화부(140)로 출력되고, 최대 부호화 단위별 영상 데이터는 영상 데이터 부호화부(130)로 출력된다. The coding depth determiner 120 determines a different maximum depth for each maximum coding unit. The maximum depth may be determined based on the rate-distortion cost calculation. The determined maximum depth is output to the
최대 부호화 단위 내의 영상 데이터는 최대 심도 이하의 적어도 하나의 심도 에 따라 심도별 부호화 단위에 기반하여 부호화되고, 각각의 심도별 부호화 단위에 기반한 부호화 결과가 비교된다. 심도별 부호화 단위의 부호화 오차의 비교 결과 부호화 오차가 가장 작은 심도가 선택될 수 있다. 각각의 최대화 부호화 단위마다 적어도 하나의 부호화 심도가 결정될 수 있다. Image data in the largest coding unit is encoded based on coding units according to depths according to at least one depth less than or equal to the maximum depth, and encoding results based on the coding units for each depth are compared. As a result of comparing the encoding error of the coding units according to depths, a depth having the smallest encoding error may be selected. At least one coding depth may be determined for each maximum coding unit.
최대 부호화 단위의 크기는 심도가 증가함에 따라 부호화 단위가 계층적으로 분할되어 축소되며 부호화 단위의 개수는 증가한다. 또한, 하나의 최대 부호화 단위에 포함되는 동일한 심도의 부호화 단위들이라 하더라도, 각각의 데이터에 대한 부호화 오차를 측정하고 상위 심도로의 축소 여부가 결정된다. 따라서, 하나의 최대 부호화 단위에 포함되는 데이터라 하더라도 위치에 따라 심도별 부호화 오차가 다르므로 위치에 따라 부호화 심도가 달리 결정될 수 있다. 다시 말해, 최대 부호화 단위는 상이한 심도에 따라 상이한 크기의 서브 부호화 단위로 분할될 수 있다.하나의 최대 부호화 단위에 대해 부호화 심도가 하나 이상 설정될 수 있으며, 최대 부호화 단위의 데이터는 하나 이상의 부호화 심도의 부호화 단위에 따라 분할될 수 있다.As the depth of the maximum coding unit increases, the coding unit is hierarchically divided and reduced, and the number of coding units increases. In addition, even if the coding units of the same depth included in one maximum coding unit, the coding error for each data is measured and it is determined whether to reduce to the higher depth. Therefore, even in the data included in one largest coding unit, since the encoding error for each depth is different according to the position, the coding depth may be differently determined according to the position. In other words, the maximum coding unit may be divided into sub-coding units having different sizes according to different depths. One or more coding depths may be set for one maximum coding unit, and the data of the maximum coding unit may have one or more coding depths. It may be divided according to coding units of.
또한, 최대 부호화 단위에 포함된 상이한 크기의 서브 부호화 단위들은 상이한 크기의 처리 단위에 기초해 예측 또는 주파수 변환될 수 있다. 다시 말해, 영상 부호화 장치(100)는 영상 부호화를 위한 복수의 처리 단계들을 다양한 크기 및 다양한 형태의 처리 단위에 기초해 수행할 수 있다. 영상 데이터의 부호화를 위해서는 예측, 주파수 변환, 엔트로피 부호화 등의 처리 단계를 거치는데, 모든 단계에 걸쳐서 동일한 크기의 처리 단위가 이용될 수도 있으며, 단계별로 상이한 크기 의 처리 단위를 이용할 수 있다.In addition, sub-coding units of different sizes included in the largest coding unit may be predicted or frequency-converted based on processing units of different sizes. In other words, the image encoding
예를 들어 영상 부호화 장치(100)는 부호화 단위를 예측하기 위해, 부호화 단위와 다른 처리 단위를 선택할 수 있다. 일 예로, 부호화 단위의 크기가 2Nx2N(단, N은 양의 정수)인 경우, 예측을 위한 처리 단위는 2Nx2N, 2NxN, Nx2N, NxN 등일 수 있다. 다시 말해, 부호화 단위의 높이 또는 너비 중 적어도 하나를 반분하는 형태의 처리 단위를 기반으로 움직임 예측이 수행될 수도 있다. 이하, 예측의 기초가 되는 데이터 단위는 '예측 단위'라 한다.For example, the image encoding
예측 모드는 인트라 모드, 인터 모드 및 스킵 모드 중 적어도 하나일 수 있으며, 특정 예측 모드는 특정 크기 또는 형태의 예측 단위에 대해서만 수행될 수 있다. 예를 들어, 인트라 모드는 정방형인 2Nx2N, NxN 크기의 예측 단위에 대해서만 수행될 수 있다. 또한, 스킵 모드는 2Nx2N 크기의 예측 단위에 대해서만 수행될 수 있다. 부호화 단위 내부에 복수의 예측 단위가 있다면, 각각의 예측 단위에 대해 예측을 수행하여 부호화 오차가 가장 작은 예측 모드가 선택될 수 있다.The prediction mode may be at least one of an intra mode, an inter mode, and a skip mode, and the specific prediction mode may be performed only for a prediction unit of a specific size or shape. For example, the intra mode may be performed only for a prediction unit having a square size of 2N × 2N or N × N. In addition, the skip mode may be performed only for a prediction unit having a size of 2N × 2N. If there are a plurality of prediction units in the coding unit, a prediction mode having the smallest encoding error may be selected by performing prediction for each prediction unit.
또한, 영상 부호화 장치(100)는 부호화 단위와 다른 크기의 처리 단위에 기초해 영상 데이터를 주파수 변환할 수 있다. 부호화 단위의 주파수 변환을 위해서 부호화 단위보다 작거나 같은 크기의 데이터 단위를 기반으로 주파수 변환이 수행될 수 있다. 이하, 주파수 변환의 기초가 되는 처리 단위를 '변환 단위'라 한다.In addition, the
부호화 심도 결정부(120)는 라그랑자 곱(Lagrangian Multiplier) 기반의 율-왜곡 최적화 기법(Rate-Distortion Optimization)을 이용하여 심도별 부호화 단위의 부호화 오차를 측정하여 최적의 부호화 오차를 갖는 최대 부호화 단위의 분할 형태를 결정할 수 있다. 다시 말해, 부호화 심도 결정부(120)는 최대 부호화 단위가 어떠한 형태의 복수의 서브 부호화 단위로 분할되는지 결정할 수 있는데, 여기서 복수의 서브 부호화 단위는 심도에 따라 크기가 상이하다.The coding depth determiner 120 measures a coding error of coding units according to depths using a Lagrangian Multiplier-based rate-distortion optimization technique to have an optimal coding error. The partition form of can be determined. In other words, the coded depth determiner 120 may determine which type of sub-coding unit is divided into a maximum coding unit, wherein the plurality of sub-coding units vary in size according to depth.
영상 데이터 부호화부(130)는, 부호화 심도 결정부(120)에서 결정된 적어도 하나의 부호화 심도에 기초하여 최대 부호화 단위의 영상 데이터를 부호화하여 비트스트림을 출력한다. 부호화 심도 결정부(120)에서 최소 부호화 오차를 측정하기 위해 부호화가 이미 수행되었으므로, 이를 이용해 부호화된 데이터 스트림을 출력할 수도 있다.The
부호화 정보 부호화부(140)는, 부호화 심도 결정부(120)에서 결정된 적어도 하나의 부호화 심도에 기초하여, 최대 부호화 단위마다 심도별 부호화 모드에 관한 정보를 부호화하여 비트스트림을 출력한다. 심도별 부호화 모드에 관한 정보는, 부호화 심도 정보, 부호화 심도의 부호화 단위의 예측 단위의 분할 타입 정보, 예측 단위별 예측 모드 정보, 변환 단위의 크기 정보 등을 포함할 수 있다.The
부호화 심도 정보는, 현재 심도로 부호화하지 않고 상위 심도의 부호화 단위로 부호화할지 여부를 나타내는 심도별 축소 정보를 이용하여 정의될 수 있다. 현재 부호화 단위의 현재 심도가 부호화 심도라면, 현재 부호화 단위는 현재 심도의 부호화 단위로 부호화되므로 현재 심도의 축소 정보는 더 이상 상위 심도로 축소되지 않도록 정의될 수 있다. 반대로, 현재 부호화 단위의 현재 심도가 부호화 심도가 아니라면 상위 심도의 부호화 단위를 이용한 부호화를 시도해보아야 하므로, 현재 심도의 축소 정보는 상위 심도의 부호화 단위로 축소되도록 정의될 수 있다.The coded depth information may be defined using depth-specific reduction information indicating whether to encode in a coding unit of a higher depth without encoding to the current depth. If the current depth of the current coding unit is a coded depth, since the current coding unit is encoded in a coding unit of the current depth, the reduced information of the current depth may no longer be reduced to a higher depth. On the contrary, if the current depth of the current coding unit is not the coding depth, encoding should be attempted using the coding unit of the higher depth, and thus the reduced information of the current depth may be defined to be reduced to the coding unit of the higher depth.
현재 심도가 부호화 심도가 아니라면, 상위 심도의 부호화 단위로 축소된 부호화 단위에 대해 부호화가 수행된다. 현재 심도의 부호화 단위 내에 상위 심도의 부호화 단위가 하나 이상 존재하므로, 각각의 상위 심도의 부호화 단위마다 반복적으로 부호화가 수행되어, 동일한 심도의 부호화 단위마다 재귀적(recursive) 부호화가 수행될 수 있다.If the current depth is not the coded depth, encoding is performed on the coding unit reduced to the coding unit of the higher depth. Since at least one coding unit of the higher depth exists in the coding unit of the current depth, encoding may be repeatedly performed for each coding unit of each higher depth, and recursive coding may be performed for each coding unit of the same depth.
하나의 최대 부호화 단위 안에 적어도 하나의 부호화 심도가 결정되며 부호화 심도마다 적어도 하나의 부호화 모드에 관한 정보가 결정되어야 하므로, 하나의 최대 부호화 단위에 대해서는 적어도 하나의 부호화 모드에 관한 정보가 결정될 수 있다. 또한, 최대 부호화 단위의 데이터는 심도에 따라 계층적으로 분할되어 위치 별로 부호화 심도가 다를 수 있으므로, 데이터에 대해 부호화 심도 및 부호화 모드에 관한 정보가 설정될 수 있다.Since at least one coding depth is determined in one maximum coding unit and information about at least one coding mode should be determined for each coding depth, information about at least one coding mode may be determined for one maximum coding unit. In addition, since the data of the largest coding unit is hierarchically divided according to the depth, the coding depth may be different for each location, and thus information about the coded depth and the coding mode may be set for the data.
따라서, 일 실시예에 따른 부호화 정보 부호화부(140)는, 최대 부호화 단위에 포함되어 있는 최소 부호화 단위마다 해당 부호화 정보를 설정할 수 있다. 즉, 부호화 심도의 부호화 단위는 동일한 부호화 정보를 보유하고 있는 최소 부호화 단위를 하나 이상 포함하고 있다. 이를 이용하여, 인근 최소 부호화 단위들이 동일한 심도별 부호화 정보를 갖고 있다면, 동일한 최대 부호화 단위에 포함되는 최소 부호화 단위일 수 있다.Therefore, the
영상 부호화 장치(100)의 가장 간단한 형태의 실시예에 따르면, 심도별 부호화 단위는 한 계층 하위 심도의 부호화 단위의 높이 및 너비를 반분한 크기의 부호화 단위이다. 즉, 현재 심도(k)의 부호화 단위의 크기가 2Nx2N이라면, 상위 심 도(k+1)의 부호화 단위의 크기는 NxN 이다. 따라서, 2Nx2N 크기의 현재 부호화 단위는 NxN 크기의 상위 심도 부호화 단위를 최대 4개 포함할 수 있다.According to an embodiment of the simplest form of the
따라서, 일 실시예에 따른 영상 복호화 장치(100)는 현재 픽처의 특성을 고려하여 결정된 최대 부호화 단위의 크기 및 최대 심도를 기반으로, 각각의 최대 부호화 단위마다 최적의 형태 분할 형태를 결정할 수 있다. 또한, 각각의 최대 부호화 단위마다 다양한 예측 모드, 주파수 변환 방식 등으로 부호화할 수 있으므로, 다양한 영상 크기의 부호화 단위의 영상 특성을 고려하여 최적의 부호화 모드가 결정될 수 있다.Accordingly, the
영상의 해상도가 매우 높거나 데이터량이 매우 큰 영상을 종래의 16x16 크기의 매크로블록 단위로 부호화한다면, 픽처당 매크로블록의 수가 과도하게 많아진다. 이에 따라, 매크로블록마다 생성되는 압축 정보도 많아지므로 압축 정보의 전송 부담이 커지고 데이터 압축 효율이 감소하는 경향이 있다. 따라서, 본 발명의 일 실시예에 따른 영상 부호화 장치는, 영상의 크기를 고려하여 부호화 단위의 최대 크기를 증가시키면서, 영상 특성을 고려하여 부호화 단위를 조절할 수 있으므로, 영상 압축 효율이 증대될 수 있다.If an image having a very high resolution or a very large data amount is encoded in a conventional 16 × 16 macroblock unit, the number of macroblocks per picture becomes excessively large. Accordingly, since the compressed information generated for each macroblock increases, the transmission burden of the compressed information increases, and the data compression efficiency tends to decrease. Accordingly, the image encoding apparatus according to an embodiment of the present invention may adjust the coding unit in consideration of the image characteristics while increasing the maximum size of the coding unit in consideration of the size of the image, thereby increasing image compression efficiency. .
도 2 는 본 발명의 일 실시예에 따른 영상 복호화 장치의 블록도를 도시한다.2 is a block diagram of an image decoding apparatus according to an embodiment of the present invention.
도 2를 참조하면, 본 발명의 일 실시예에 따른 영상 복호화 장치(200)는 영상 데이터 획득부(210), 부호화 정보 추출부(220) 및 영상 데이터 복호화부(230)를 포함한다. Referring to FIG. 2, the
영상 관련 데이터 획득부(210)는 영상 복호화 장치(200)가 수신한 비트열을 파싱하여, 최대 부호화 단위별로 영상 데이터를 획득하여 영상 데이터 복호화부(230)로 출력한다. 영상 관련 데이터 획득부(210)는 현재 픽처 또는 슬라이스에 대한 헤더로부터 현재 픽처 또는 슬라이스의 최대 부호화 단위에 대한 정보를 추출할 수 있다. 본 발명의 일 실시예에 따른 영상 복호화 장치(200)는 최대 부호화 단위 단위별로 영상 데이터를 복호화한다. The image related
부호화 정보 추출부(220)는 영상 복호화 장치(200)가 수신한 비트열을 파싱하여, 현재 픽처에 대한 헤더로부터 최대 부호화 단위별 부호화 심도 및 부호화 모드에 관한 정보를 추출한다. 추출된 부호화 심도 및 부호화 모드에 관한 정보는 영상 데이터 복호화부(230)로 출력된다.The encoding information extracting unit 220 parses the bit string received by the
최대 부호화 단위별 부호화 심도 및 부호화 모드에 관한 정보는, 하나 이상의 부호화 심도 정보에 대해 설정될 수 있으며, 부호화 심도별 부호화 모드에 관한 정보는, 부호화 단위별 예측 단위의 분할 타입 정보, 예측 모드 정보 및 변환 단위의 크기 정보 등을 포함할 수 있다. 또한, 부호화 심도 정보로서, 심도별 축소 정보가 추출될 수도 있다.The information about the coded depth and the encoding mode for each largest coding unit may be set for one or more coded depth information, and the information about the coding mode for each coded depth may include split type information of a prediction unit for each coding unit, prediction mode information, and the like. The size information of the transformation unit may be included. In addition, reduced coded information for each depth may be extracted as the coded depth information.
최대 부호화 단위의 분할 형태에 대한 정보는 최대 부호화 단위에 포함된 심도에 따라 상이한 크기의 서브 부호화 단위에 대한 정보를 포함할 수 있으며, 부호화 모드에 관한 정보는 서브 부호화 단위별 예측 단위에 대한 정보, 예측 모드에 대한 정보 및 변환 단위에 대한 정보 등을 포함할 수 있다. The information about the split form of the largest coding unit may include information about sub-coding units having different sizes according to the depth included in the maximum coding unit, and the information about the encoding mode may include information about a prediction unit for each sub-coding unit, Information on the prediction mode and information on the transformation unit may be included.
영상 데이터 복호화부(230)는 부호화 정보 추출부에서 추출된 정보에 기초하 여 각각의 최대 부호화 단위의 영상 데이터를 복호화하여 현재 픽처를 복원한다. 최대 부호화 단위의 분할 형태에 대한 정보에 기초하여, 영상 데이터 복호화부(230)는 최대 부호화 단위에 포함된 서브 부호화 단위를 복호화할 수 있다. 복호화 과정은 인트라 예측 및 움직임 보상을 포함하는 움직임 예측 과정, 및 주파수 역변환 과정을 포함할 수 있다.The
영상 데이터 복호화부(230)는 최대 부호화 단위별 부호화 심도 및 부호화 모드에 관한 정보에 기초하여 각각의 최대 부호화 단위의 영상 데이터를 복호화하여 현재 픽처를 복원한다. 최대 부호화 단위별 부호화 심도 정보에 기초하여, 영상 데이터 복호화부(230)는 적어도 하나의 부호화 심도의 부호화 단위마다 영상 데이터를 복호화할 수 있다. 복호화 과정은 인트라 예측 및 움직임 보상을 포함하는 예측 과정 및 역변환 과정을 포함할 수 있다.The
영상 데이터 복호화부(230)는, 부호화 단위별 예측을 위해 부호화 심도별 부호화 단위의 예측 단위의 분할 타입 정보 및 예측 모드 정보에 기초하여, 부호화 단위마다 각각의 예측 단위 및 예측 모드로 인트라 예측 또는 움직임 보상을 수행할 수 있다. 또한, 영상 데이터 복호화부(230)는, 최대 부호화 단위별 역변환을 위해, 부호화 심도별 부호화 단위의 변환 단위의 크기 정보에 기초하여, 부호화 단위마다 각각의 변환 단위로 역변환을 수행할 수 있다.The
영상 데이터 복호화부(230)는 심도별 축소 정보를 이용하는 현재 최대 부호화 단위의 부호화 심도를 결정할 수 있다. 만약, 축소 정보가 현재 심도로 복호화할 것을 나타내고 있다면 현재 심도가 부호화 심도이다. 따라서, 영상 데이터 복호 화부(230)는 현재 최대 부호화 단위의 영상 데이터에 대해 현재 심도의 부호화 단위를 예측 단위의 분할 타입, 예측 모드 및 변환 단위 크기 정보를 이용하여 복호화할 수 있다. 즉, 최소 부호화 단위에 대해 설정되어 있는 부호화 정보를 관찰하여, 동일한 축소 정보를 포함한 부호화 정보를 보유하고 있는 최소 부호화 단위를 모아, 하나의 데이터 단위로 복호화할 수 있다. The
일 실시예에 따른 영상 복호화 장치(200)는, 부호화 과정에서 최대 부호화 단위마다 재귀적으로 부호화를 수행하여 최소 부호화 오차를 발생시킨 부호화 단위에 대한 정보를 획득하여, 현재 픽처에 대한 복호화에 이용할 수 있다. 즉, 최대 부호화 단위마다 최적 부호화 단위로 영상 데이터의 복호화가 가능해진다. 따라서, 높은 해상도의 영상 또는 데이터량이 과도하게 많은 영상이라도 부호화단으로부터 전송된 최적 부호화 모드에 관한 정보를 이용하여, 영상의 특성에 적응적으로 결정된 부호화 단위의 크기 및 부호화 모드에 따라 효율적으로 영상 데이터를 복호화하여 복원할 수 있다.The
도 3은 본 발명의 일 실시예에 따른 계층적 부호화 단위를 도시한다.3 illustrates a hierarchical coding unit according to an embodiment of the present invention.
도 3을 참조하면, 본 발명에 따른 계층적 부호화 단위는 너비x높이가 64x64인 부호화 단위부터, 32x32, 16x16, 8x8, 및 4x4를 포함할 수 있다. 정사각형 형태의 부호화 단위 이외에도, 너비x높이가 64x32, 32x64, 32x16, 16x32, 16x8, 8x16, 8x4, 4x8인 부호화 단위들이 존재할 수 있다.Referring to FIG. 3, the hierarchical coding unit according to the present invention may include 32x32, 16x16, 8x8, and 4x4 starting from a coding unit having a width x height of 64x64. In addition to the square coding units, there may be coding units having a width x height of 64x32, 32x64, 32x16, 16x32, 16x8, 8x16, 8x4, and 4x8.
도 3에서 비디오 데이터(310)에 대해서는, 해상도는 1920x1080, 최대 부호화 단위의 크기는 64, 최대 심도가 2로 설정되어 있다. 또한, 비디오 데이터(320)에 대해서는, 해상도는 1920x1080, 부호화 단위의 최대 크기는 64, 최대 심도가 4로 설정되어 있다. 또한, 비디오 데이터(330)에 대해서는, 해상도는 352x288, 부호화 단위의 최대 크기는 16, 최대 심도가 2로 설정되어 있다.In FIG. 3, the
해상도가 높거나 데이터량이 많은 경우 압축률 향상뿐만 아니라 영상 특성을 정확히 반영하기 위해 부호화 사이즈의 최대 크기가 상대적으로 큰 것이 바람직하다. 따라서, 비디오 데이터(330)에 비해, 해상도가 높은 비디오 데이터(310, 320)는 부호화 사이즈의 최대 크기가 64로 선택될 수 있다.When the resolution is high or the amount of data is large, it is desirable that the maximum size of the coding size be relatively large in order to not only improve the compression ratio but also accurately reflect the image characteristics. Accordingly, the
최대 심도는 계층적 부호화 단위에서 총 계층수를 나타낸다. 따라서, 비디오 데이터(310)의 최대 심도는 2이므로, 비디오 데이터(310)의 부호화 단위(315)는 장축 크기가 64인 최대 부호화 단위로부터, 심도가 두 계층 증가하여 장축 크기가 32, 16인 부호화 단위들까지 포함할 수 있다. 반면, 비디오 데이터(330)의 최대 심도는 2이므로, 비디오 데이터(330)의 부호화 단위(335)는 장축 크기가 16인 부호화 단위들로부터, 심도가 두 계층 증가하여 장축 크기가 8, 4인 부호화 단위들까지 포함할 수 있다. The maximum depth represents the total number of layers in the hierarchical coding unit. Accordingly, since the maximum depth of the
비디오 데이터(320)의 최대 심도는 4이므로, 비디오 데이터(320)의 부호화 단위(325)는 장축 크기가 64인 최대 부호화 단위로부터, 심도가 네 계층 증가하여 장축 크기가 32, 16, 8, 4인 부호화 단위들까지 포함할 수 있다.심도가 증가할수록 더 작은 서브 부호화 단위에 기초해 영상을 부호화하므로 보다 세밀한 장면을 포함하고 있는 영상을 부호화하는데 적합해진다.Since the maximum depth of the
도 4 는 본 발명의 일 실시예에 따른 부호화 단위에 기초한 영상 부호화부의 블록도를 나타낸 것이다.4 is a block diagram of an image encoder based on coding units, according to an embodiment of the present invention.
도 4를 참조하면, 인트라 예측부(410)는 현재 프레임(405) 중 인트라 모드의 예측 단위에 대해 인트라 예측을 수행하고, 움직임 추정부(420) 및 움직임 보상부(425)는 인터 모드의 예측 단위에 대해 현재 프레임(405) 및 참조 프레임(495)을 이용해 인터 예측 및 움직임 보상을 수행한다.Referring to FIG. 4, the
인트라 예측부(410), 움직임 추정부(420) 및 움직임 보상부(425)로부터 출력된 예측 단위에 기초해 레지듀얼 값들이 생성되고, 생성된 레지듀얼 값들은 주파수 변환부(430) 및 양자화부(440)를 거쳐 양자화된 변환 계수로 출력된다. 특히 도 12를 참조하여 후술되는 바와 같이 본 발명의 일 실시예에 따른 인트라 예측부(410)는 인트라 예측된 부호화 단위의 각 픽셀을 그 주변 픽셀을 이용하여 변경하는 후처리를 수행하고, 후처리된 부호화 단위와 원 부호화 단위의 차이값인 레지듀얼 값들은 주파수 변환부(430) 및 양자화부(440)를 거쳐 양자화된 변환 계수로 출력될 수 있다.Residual values are generated based on the prediction unit output from the
양자화된 변환 계수는 역양자화부(460), 주파수 역변환부(470)를 통해 다시 레지듀얼 값으로 복원되고, 복원된 레지듀얼 값들은 디블로킹부(480) 및 루프 필터링부(490)를 거쳐 후처리되어 참조 프레임(495)으로 출력된다. 양자화된 변환 계수는 엔트로피 부호화부(450)를 거쳐 비트스트림(455)으로 출력될 수 있다.The quantized transform coefficients are restored to the residual values through the
본 발명의 일 실시예에 따른 영상 부호화 방법에 따라 부호화하기 위해, 영상 부호화부(400)의 구성 요소들인 인트라 예측부(410), 움직임 추정부(420), 움직임 보상부(425), 주파수 변환부(430), 양자화부(440), 엔트로피 부호화부(450), 역 양자화부(460), 주파수 역변환부(470), 디블로킹부(480) 및 루프 필터링부(490)는 모두 최대 부호화 단위, 심도에 따른 서브 부호화 단위, 예측 단위 및 변환 단위에 기초해 영상 부호화 과정들을 처리한다. 특히, 인트라 예측부(410), 움직임 추정부(420) 및 움직임 보상부(425)는 부호화 단위의 최대 크기 및 심도를 고려하여 부호화 단위 내의 예측 단위 및 예측 모드를 결정하며, 주파수 변환부(430)는 부호화 단위의 최대 크기 및 심도를 고려하여 변환 단위의 크기를 고려하여야 한다.In order to encode according to an image encoding method according to an embodiment of the present invention, the components of the
도 5 는 본 발명의 일 실시예에 따른 부호화 단위에 기초한 영상 복호화부의 블록도를 나타낸 것이다.5 is a block diagram of an image decoder based on coding units, according to an embodiment of the present invention.
도 5를 참조하면, 비트스트림(505)이 파싱부(510)를 거쳐 복호화 대상인 부호화된 영상 데이터 및 복호화를 위해 필요한 부호화 정보가 파싱된다. 부호화된 영상 데이터는 엔트로피 복호화부(520) 및 역양자화부(530)를 거쳐 역양자화된 데이터로 출력되고, 주파수 역변환부(540)를 거쳐 레지듀얼 값들로 복원된다. 레지듀얼 값들은 인트라 예측부(550)의 인트라 예측의 결과 또는 움직임 보상부(560)의 움직임 보상 결과와 가산되어 부호화 단위 별로 복원된다. 복원된 부호화 단위는 디블로킹부(570) 및 루프 필터링부(580)를 거쳐 다음 부호화 단위 또는 다음 픽처의 예측에 이용된다.Referring to FIG. 5, the
본 발명의 일 실시예에 따른 영상 복호화 방법에 따라 복호화하기 위해 영상 복호화부(400)의 구성 요소들인 파싱부(510), 엔트로피 복호화부(520), 역양자화부(530), 주파수 역변환부(540), 인트라 예측부(550), 움직임 보상부(560), 디블로킹부(570) 및 루프 필터링부(580)가 모두 최대 부호화 단위, 심도에 따른 서브 부 호화 단위, 예측 단위 및 변환 단위에 기초해 영상 복호화 과정들을 처리한다. 특히, 인트라 예측부(550), 움직임 보상부(560)는 부호화 단위의 최대 크기 및 심도를 고려하여 부호화 단위 내의 예측 단위 및 예측 모드를 결정하며, 주파수 역변환부(540)는 부호화 단위의 최대 크기 및 심도를 고려하여 변환 단위의 크기를 고려하여야 한다.Parsing
도 6은 본 발명의 일 실시예에 따른 심도별 부호화 단위 및 예측 단위를 도시한다.6 is a diagram of deeper coding units according to depths, and prediction units, according to an embodiment of the present invention.
일 실시예에 따른 영상 부호화 장치(100) 및 일 실시예에 따른 영상 복호화 장치(200)는 영상 특성을 고려하기 위해 계층적인 부호화 단위를 사용한다. 부호화 단위의 최대 높이 및 너비, 최대 심도는 영상의 특성에 따라 적응적으로 결정될 수도 있으며, 사용자의 요구에 따라 다양하게 설정될 수도 있다. 미리 설정된 부호화 단위의 최대 크기에 따라, 심도별 부호화 단위의 크기가 결정될 수도 있다.The
본 발명의 일 실시예에 따른 부호화 단위의 계층 구조(600)는 부호화 단위의 최대 높이 및 너비가 64이며, 최대 심도가 4인 경우를 도시하고 있다. 일 실시예에 따른 부호화 단위의 계층 구조(600)의 세로축을 따라서 심도가 증가하므로 심도별 부호화 단위의 높이 및 너비가 각각 축소된다. 또한, 부호화 단위의 계층 구조(600)의 가로축을 따라, 각각의 심도별 부호화 단위의 예측 기반이 되는 부분적 데이터 단위인 예측 단위가 도시되어 있다.The
최대 부호화 단위(610)는 부호화 단위의 계층 구조(600) 중 최대 부호화 단위로서 심도가 0이며, 부호화 단위의 크기, 즉 높이 및 너비가 64x64이다. 세로축 을 따라 심도가 증가하며, 크기 32x32인 심도 1의 부호화 단위(620), 크기 16x16인 심도 2의 부호화 단위(630), 크기 8x8인 심도 3의 부호화 단위(640), 크기 4x4인 심도 4의 부호화 단위(650)가 존재한다. 크기 4x4인 심도 4의 부호화 단위(650)는 최소 부호화 단위이다.The
또한 도 6을 참조하면, 각각의 심도별로 가로축을 따라, 부호화 단위의 예측 단위로서, 부분적 데이터 단위들이 도시되어 있다. 즉, 심도 0의 크기 64x64의 최대 부호화 단위(610)의 예측 단위는, 크기 64x64의 부호화 단위(610)에 포함되는 크기 64x64의 부분적 데이터 단위(610), 크기 64x32의 부분적 데이터 단위들(612), 크기 32x64의 부분적 데이터 단위들(614), 크기 32x32의 부분적 데이터 단위들(616)일 수 있다. Referring to FIG. 6, partial data units are shown as prediction units of coding units along a horizontal axis for each depth. That is, the prediction unit of the
심도 1의 크기 32x32의 부호화 단위(620)의 예측 단위는, 크기 32x32의 부호화 단위(620)에 포함되는 크기 32x32의 부분적 데이터 단위(620), 크기 32x16의 부분적 데이터 단위들(622), 크기 16x32의 부분적 데이터 단위들(624), 크기 16x16의 부분적 데이터 단위들(626)일 수 있다. The prediction unit of the
심도 2의 크기 16x16의 부호화 단위(630)의 예측 단위는, 크기 16x16의 부호화 단위(630)에 포함되는 크기 16x16의 부분적 데이터 단위(630), 크기 16x8의 부분적 데이터 단위들(632), 크기 8x16의 부분적 데이터 단위들(634), 크기 8x8의 부분적 데이터 단위들(636)일 수 있다. The prediction unit of the
심도 3의 크기 8x8의 부호화 단위(640)의 예측 단위는, 크기 8x8의 부호화 단위(640)에 포함되는 크기 8x8의 부분적 데이터 단위(640), 크기 8x4의 부분적 데 이터 단위들(642), 크기 4x8의 부분적 데이터 단위들(644), 크기 4x4의 부분적 데이터 단위들(646)일 수 있다. The prediction unit of the
마지막으로, 심도 4의 크기 4x4의 부호화 단위(650)는 최소 부호화 단위이며 최상위 심도의 부호화 단위이고, 해당 예측 단위도 크기 4x4의 데이터 단위(650)이다.Finally, the
일 실시예에 따른 영상 부호화 장치의 부호화 심도 결정부(120)는, 최대 부호화 단위(610)의 부호화 심도를 결정하기 위해, 최대 부호화 단위(610)에 포함되는 각각의 심도의 부호화 단위마다 부호화를 수행하여야 한다. In order to determine the coded depth of the
동일한 범위 및 크기의 데이터를 포함하기 위한 심도별 부호화 단위의 개수는, 심도가 증가할수록 심도별 부호화 단위의 개수도 증가한다. 예를 들어, 심도 1의 부호화 단위 한 개가 포함하는 데이터에 대해서, 심도 2의 부호화 단위는 네 개가 필요하다. 따라서, 동일한 데이터의 부호화 결과를 심도별로 비교하기 위해서, 한 개의 심도 1의 부호화 단위 및 네 개의 심도 2의 부호화 단위를 이용하여 각각 부호화되어야 한다.As the number of deeper coding units includes data of the same range and size, the number of deeper coding units increases as the depth increases. For example, four coding units of
각각의 심도별 부호화를 위해서는, 부호화 단위의 계층 구조(600)의 가로축을 따라, 심도별 부호화 단위의 예측 단위들마다 부호화를 수행하여, 해당 심도에서 가장 작은 부호화 오차인 대표 부호화 오차가 선택될 수다. 또한, 부호화 단위의 계층 구조(600)의 세로축을 따라 심도를 증가시키며, 각각의 심도마다 부호화를 수행하여, 심도별 대표 부호화 오차를 비교하여 최소 부호화 오차가 검색될 수 있다. 최대 부호화 단위(610) 중 최소 부호화 오차가 발생하는 심도가 최대 부호화 단위(610)의 부호화 심도 및 분할 타입으로 선택될 수 있다. For each depth coding, encoding may be performed for each prediction unit of a coding unit according to depths along a horizontal axis of the
도 7은 본 발명의 일 실시예에 따른, 부호화 단위 및 변환 단위의 관계를 도시한다. 7 illustrates a relationship between coding units and transformation units, according to an embodiment of the present invention.
본 발명의 일 실시예에 따른 영상 부호화 장치(100) 및 영상 복호화 장치(200)는, 최대 부호화 단위마다 최대 부호화 단위보다 작거나 같은 크기의 부호화 단위로 영상을 분할하여 부호화하거나 복호화한다. 부호화 과정 중 주파수 변환을 위한 변환 단위의 크기는 각각의 부호화 단위보다 크지 않은 데이터 단위를 기반으로 선택될 수 있다. 예를 들어, 현재 부호화 단위(710)가 64x64 크기일 때, 32x32 크기의 변환 단위(720)를 이용하여 주파수 변환이 수행될 수 있다. 또한, 64x64 크기의 부호화 단위(710)의 데이터를 64x64 크기 이하의 32x32, 16x16, 8x8, 4x4 크기의 변환 단위들로 각각 주파수 변환을 수행하여 부호화한 후, 원본과의 오차가 가장 적은 변환 단위가 선택될 수 있다.The
도 8은 본 발명의 일 실시예에 따라, 심도별 부호화 정보들을 도시한다.8 illustrates encoding information according to depths, according to an embodiment of the present invention.
본 발명의 일 실시예에 따른 영상 부호화 장치(100)의 부호화 정보 부호화부는 부호화 모드에 관한 정보로서, 각각의 부호화 심도의 부호화 단위마다 분할 타입에 관한 정보(800), 예측 모드에 관한 정보(810), 변환 단위 크기에 대한 정보(820)를 부호화하여 전송할 수 있다.The encoding information encoder of the
분할 타입에 대한 정보(800)는, 현재 부호화 단위의 움직임 예측을 위해 예측 단위로서, 현재 부호화 단위가 분할된 타입에 대한 정보를 나타낸다. 예를 들어, 심도 0 및 크기 2Nx2N의 현재 부호화 단위 CU_0는, 크기 2Nx2N의 예측 단 위(802), 크기 2NxN의 예측 단위(804), 크기 Nx2N의 예측 단위(806), 크기 NxN의 예측 단위(808) 중 어느 하나의 타입으로 분할되어 예측 단위로 이용될 수 있다. 이 경우 현재 부호화 단위의 분할 타입에 관한 정보(800)는 크기 2Nx2N의 예측 단위(802), 크기 2NxN의 예측 단위(804), 크기 Nx2N의 예측 단위(806) 및 크기 NxN의 예측 단위(808) 중 하나를 나타내도록 설정된다.The information about the split type 800 represents information about a type in which the current coding unit is split as a prediction unit for motion prediction of the current coding unit. For example, the current coding unit CU_0 of
예측 모드에 관한 정보(810)는, 각각의 예측 단위의 움직임 예측 모드를 나타낸다. 예를 들어 예측 모드에 관한 정보(810)를 통해, 분할 타입에 관한 정보(800)가 가리키는 예측 단위가 인트라 모드(812), 인터 모드(814) 및 스킵 모드(816) 중 하나로 움직임 예측이 수행되는지 여부가 설정될 수 있다.The information 810 about the prediction mode indicates a motion prediction mode of each prediction unit. For example, through the information 810 about the prediction mode, the prediction unit indicated by the information 800 about the partition type is performed by the motion prediction as one of the
또한, 변환 단위 크기에 관한 정보(820)는 현재 부호화 단위를 어떠한 변환 단위를 기반으로 주파수 변환을 수행할지 여부를 나타낸다. 예를 들어, 변환 단위는 제 1 인트라 변환 단위 크기(822), 제 2 인트라 변환 단위 크기(824), 제 1 인터 변환 단위 크기(826), 제 2 인트라 변환 단위 크기(828) 중 하나일 수 있다.In addition, the information about the transform unit size 820 indicates whether to transform the current coding unit based on the transform unit. For example, the transform unit may be one of a first intra
본 발명의 일 실시예에 따른 영상 복호화 장치(200)의 부호화 정보 추출부는, 각각의 심도별 부호화 단위마다 분할 타입에 관한 정보(800), 예측 모드에 관한 정보(810), 변환 단위 크기에 대한 정보(820)를 추출하여 복호화에 이용할 수 있다.The encoding information extracting unit of the
도 9 는 본 발명의 일 실시예에 따른 심도별 부호화 단위를 도시한다. 9 is a diagram of deeper coding units according to depths, according to an embodiment of the present invention.
심도의 증가 여부를 나타내기 위해 축소 정보가 이용될 수 있다. 축소 정보는 현재 심도의 부호화 단위가 상위 심도의 부호화 단위로 축소될지 여부를 나타낸 다. Reduced information may be used to indicate whether the depth is increased. The reduced information indicates whether the coding unit of the current depth is reduced to the coding unit of the higher depth.
심도 0 및 2N_0x2N_0 크기의 부호화 단위의 움직임 예측을 위한 예측 단위(910)는 2N_0x2N_0 크기의 분할 타입(912), 2N_0xN_0 크기의 분할 타입(914), N_0x2N_0 크기의 분할 타입(916), N_0xN_0 크기의 분할 타입(918)을 포함할 수 있다. The
분할 타입마다, 한 개의 2N_0xN_0 크기의 예측 단위, 두 개의 2N_0xN_0 크기의 예측 단위, 두 개의 N_0x2N_0 크기의 예측 단위, 네 개의 N_0xN_0 크기의 예측 단위마다 반복적으로 움직임 예측을 통한 부호화가 수행되어야 한다. 크기 2N_0xN_0 및 크기 N_0xN_0의 예측 단위에 대해서는, 인트라 모드 및 인터 모드로 움직임 예측이 수행될 수 있으며, 크기 N_0x2N_0 및 크기 N_0xN_0의 예측 단위로는 인터 모드로만 움직임 예측이 수행될 수 있다. 스킵 모드는 크기 2N_0xN_0의 예측 단위에 대해서만 수행될 수 있다.For each split type, coding through motion prediction should be performed repeatedly for one prediction unit of 2N_0xN_0 size, two prediction units of 2N_0xN_0 size, two prediction units of N_0x2N_0 size, and four prediction units of N_0xN_0 size. For prediction units of size 2N_0xN_0 and size N_0xN_0, motion prediction may be performed in intra mode and inter mode, and motion prediction may be performed only in inter mode as prediction units of size N_0x2N_0 and size N_0xN_0. The skip mode may be performed only for prediction units of size 2N_0xN_0.
크기 N_0xN_0의 분할 타입(918)에 의한 부호화 오차가 가장 작다면, 심도 0를 1로 증가(920)시키고, 심도 2 및 크기 N_0xN_0의 분할 타입의 부호화 단위들(922, 924, 926, 928)에 대해 반복적으로 최소 부호화 오차를 검색해 나갈 수 있다. If the encoding error due to the
동일한 심도의 부호화 단위들(922, 924, 926, 928)에 대해 부호화가 반복적으로 수행되므로, 이중 하나만 예를 들어 심도 1의 부호화 단위의 부호화를 설명한다. 심도 1 및 크기 2N_1x2N_1 (=N_0xN_0)의 부호화 단위의 움직임 예측을 위한 예측 단위(930)는, 크기 2N_1x2N_1의 분할 타입(932), 크기 2N_1xN_1의 분할 타 입(934), 크기 N_1x2N_1의 분할 타입(936), 크기 N_1xN_1의 분할 타입(938)을 포함할 수 있다. 분할 타입마다, 한 개의 크기 2N_1x2N_1의 예측 단위, 두 개의 크기 2N_1xN_1의 예측 단위, 두 개의 크기 N_1x2N_1의 예측 단위, 네 개의 크기 N_1xN_1의 예측 단위마다 반복적으로 움직임 예측을 통한 부호화가 수행되어야 한다.Since encoding is repeatedly performed on
또한, 크기 N_1xN_1 크기의 분할 타입(938)에 의한 부호화 오차가 가장 작다면, 심도 1을 심도 2로 증가(940)시키면서, 심도 2 및 크기 N_2xN_2의 부호화 단위들(942, 944, 946, 948)에 대해 반복적으로 최소 부호화 오차를 검색해 나갈 수 있다. In addition, if the encoding error due to the
최대 심도가 d인 경우, 심도별 축소 정보는 심도 d-1일 때까지 설정될 수 있다. 즉, 심도 d-1 및 크기 2N_(d-1)x2N_(d-1)의 부호화 단위의 움직임 예측을 위한 예측 단위(950)는, 크기 2N_(d-1)x2N_(d-1)의 분할 타입(952), 크기 2N_(d-1)xN_(d-1)의 분할 타입(954), 크기 N_(d-1)x2N_(d-1)의 분할 타입(956), 크기 N_(d-1)xN_(d-1)의 분할 타입(958)을 포함할 수 있다. When the maximum depth is d, depth reduction information for each depth may be set until the depth d-1. That is, the
분할 타입마다, 한 개의 크기 2N_(d-1)x2N_(d-1)의 예측 단위, 두 개의 크기 2N_(d-1)xN_(d-1)의 예측 단위, 두 개의 크기 N_(d-1)x2N_(d-1)의 예측 단위, 네 개의 크기 N_(d-1)xN_(d-1)의 예측 단위마다 반복적으로 움직임 예측을 통한 부호화가 수행되어야 한다. 최대 심도가 d이므로, 심도 d-1의 부호화 단위(952)는 더 이상 축소 과정을 거치지 않는다.For each split type, one prediction unit of size 2N_ (d-1) x2N_ (d-1), two prediction units of size 2N_ (d-1) xN_ (d-1), two sizes N_ (d-1) For each prediction unit of) x2N_ (d-1) and prediction units of four sizes N_ (d-1) xN_ (d-1), encoding through motion prediction should be performed repeatedly. Since the maximum depth is d, the
본 발명의 일 실시예에 따른 영상 부호화 장치(100)는 부호화 단위(912)를 위한 부호화 심도를 결정하기 위해, 심도별 부호화 오차를 비교하여 가장 작은 부 호화 오차가 발생하는 심도를 선택한다. 예를 들어, 심도 0의 부호화 단위에 대한 부호화 오차는 분할 타입(912, 914, 916, 918)마다 움직임 예측을 수행하여 부호화한 후 가장 작은 부호화 오차가 발생하는 예측 단위가 결정된다. 마찬가지로 심도 0, 1, ..., d-1 마다 부호화 오차가 가장 작은 예측 단위가 검색될 수 있다. 심도 d에서는, 크기 2N_dx2N_d의 부호화 단위이면서 예측 단위(960)를 기반으로 한 움직임 예측을 통해 부호화 오차가 결정될 수 있다. 이와 같이 심도 0, 1, ..., d-1, d의 모든 심도별 최소 부호화 오차를 비교하여 오차가 가장 작은 심도가 선택되어 부호화 심도로 결정될 수 있다. 부호화 심도 및 해당 심도의 예측 단위는 부호화 모드에 관한 정보로써 부호화되어 전송될 수 있다. 또한, 심도 0으로부터 부호화 심도에 이르기까지 부호화 단위가 축소되어야 하므로, 부호화 심도의 축소 정보만이 '0'으로 설정되고, 부호화 심도를 제외한 심도별 축소 정보는 '1'로 설정되어야 한다. The
본 발명의 일 실시예에 따른 영상 복호화 장치(200)의 부호화 정보 추출부(220)는 부호화 단위(912)에 대한 부호화 심도 및 예측 단위에 관한 정보를 추출하여 부호화 단위(912)를 복호화하는데 이용할 수 있다. 일 실시예에 따른 영상 복호화 장치(200)는 심도별 축소 정보를 이용하여 축소 정보가 '0'인 심도를 부호화 심도로 파악하고, 해당 심도에 대한 부호화 모드에 관한 정보를 이용하여 복호화에 이용할 수 있다.The encoding information extracting unit 220 of the
도 10a 및 10b는 본 발명의 일 실시예에 따른, 부호화 단위, 예측 단위 및 주파수 변환 단위의 관계를 도시한다.10A and 10B illustrate a relationship between a coding unit, a prediction unit, and a frequency transformation unit, according to an embodiment of the present invention.
부호화 단위(1010)는, 최대 부호화 단위(1000)에 대해 일 실시예에 따른 영상 부호화 장치(100)가 결정한 부호화 심도별 부호화 단위들이다. 예측 단위(1060)는 부호화 단위(1010) 중 각각의 부호화 심도별 부호화 단위의 예측 단위들이며, 변환 단위(1070)는 각각의 부호화 심도별 부호화 단위의 변환 단위들이다.The coding units 1010 are coding units according to coding depths determined by the
심도별 부호화 단위들(1010)은 최대 부호화 단위(1000)의 심도가 0이라고 하면, 부호화 단위들(1012, 1054)은 심도가 1, 부호화 단위들(1014, 1016, 1018, 1028, 1050, 1052)은 심도가 2, 부호화 단위들(1020, 1022, 1024, 1026, 1030, 1032, 1038)은 심도가 3, 부호화 단위들(1040, 1042, 1044, 1046)은 심도가 4이다. If the depth-based coding units 1010 have a depth of 0, the
예측 단위들(1060) 중 일부(1014, 1016, 1022, 1032, 1048, 1050, 1052, 1054)는 부호화 단위가 분할된 타입이다. 즉, 예측 단위(1014, 1022, 1050, 1054)는 2NxN의 분할 타입이며, 예측 단위(1016, 1048, 1052)는 Nx2N의 분할 타입, 예측 단위(1032)는 NxN의 분할 타입이다. 즉, 심도별 부호화 단위들(1010)의 예측 단위는 각각의 부호화 단위보다 작거나 같다. Some of the prediction units 1060 1014, 1016, 1022, 1032, 1048, 1050, 1052, and 1054 are types in which coding units are split. That is, the
변환 단위들(1070) 중 일부(1052, 1054)의 영상 데이터에 대해서는 부호화 단위에 비해 작은 크기의 데이터 단위로 주파수 변환 또는 주파수 역변환이 수행된다. 또한, 변환 단위(1014, 1016, 1022, 1032, 1048, 1050, 1052, 1054)는 예측 단위들(1060) 중 해당 예측 단위와 비교해보면, 서로 다른 크기 또는 형태의 데이터 단위이다. 즉, 본 발명의 일 실시예에 따른 영상 부호화 장치(100) 및 영상 복호화 장치(200)는 동일한 부호화 단위에 대한 예측 및 주파수 변환/역변환 작업이라 할지라도, 각각 별개의 데이터 단위를 기반으로 수행할 수 있다.For the image data of some of the transformation units 1070 1052 and 1054, frequency conversion or frequency inverse transformation is performed in a data unit having a smaller size than the coding unit. In addition, the
도 11 은 본 발명의 일 실시예에 따른 부호화 단위별 부호화 정보를 도시한다.11 is a diagram of encoding information according to coding units, according to an embodiment of the present invention.
본 발명의 일 실시예에 따른 영상 부호화 장치(100)의 부호화 정보 부호화부(140)는 부호화 단위별 부호화 정보를 부호화하고, 본 발명의 일 실시예에 따른 영상 복호화 장치(200)의 부호화 정보 추출부(220)는 부호화 단위별 부호화 정보를 추출할 수 있다.The
부호화 정보는 부호화 단위에 대한 축소 정보, 분할 타입 정보, 예측 모드 정보, 변환 단위 크기 정보를 포함할 수 있다. 도 11에 도시되어 있는 부호화 정보들은 본 발명의 일 실시예에 따른 영상 부호화 장치(100) 및 영상 복호화 장치(200)에서 설정할 수 있는 일 예에 불과하며, 도시된 것에 한정되지 않는다.The encoding information may include reduction information about the coding unit, split type information, prediction mode information, and transformation unit size information. The encoding information illustrated in FIG. 11 is only an example that may be set in the
축소 정보는 해당 부호화 단위의 부호화 심도를 나타낼 수 있다. 즉, 축소 정보에 따라 더 이상 축소되지 않는 심도가 부호화 심도이므로, 부호화 심도에 대해서 분할 타입 정보, 예측 모드, 변환 단위 크기 정보가 정의될 수 있다. 축소 정보에 따라 한 단계 더 축소되어야 하는 경우에는, 축소된 4개의 상위 심도의 부호화 단위마다 독립적으로 부호화가 수행되어야 한다.The reduced information may indicate a coded depth of the corresponding coding unit. That is, since the depth that is no longer reduced according to the reduced information is a coded depth, split type information, a prediction mode, and transform unit size information may be defined for the coded depth. If it is necessary to further reduce the size according to the reduced information, encoding should be performed independently for each coding unit of the reduced four higher depths.
분할 타입 정보는, 부호화 심도의 부호화 단위의 변환 단위의 분할 타입을 2Nx2N, 2NxN, Nx2N 및 NxN 중 하나로 나타낼 수 있다. 예측 모드는, 움직임 예측 모드를 인트라 모드, 인터 모드 및 스킵 모드 중 하나로 나타낼 수 있다. 인트라 모드는 분할 타입 2Nx2N 및 NxN에서만 정의될 수 있으며, 스킵 모드는 분할 타입 2Nx2N에서만 정의될 수 있다. 변환 단위 크기는 인트라 모드에서 두 종류의 크기, 인터 모드에서 두 종류의 크기로 설정될 수 있다.The split type information may indicate the split type of the transform unit of the coding unit of the coded depth as one of 2Nx2N, 2NxN, Nx2N, and NxN. The prediction mode may indicate the motion prediction mode as one of an intra mode, an inter mode, and a skip mode. Intra mode can be defined only in split type 2Nx2N and NxN, and skip mode can be defined only in split type 2Nx2N. The conversion unit size may be set to two kinds of sizes in the intra mode and two kinds of sizes in the inter mode.
부호화 단위 내의 최소 부호화 단위마다, 소속되어 있는 부호화 심도의 부호화 단위별 부호화 정보를 수록하고 있을 수 있다. 따라서, 인접한 최소 부호화 단위들끼리 각각 보유하고 있는 부호화 정보들을 확인하면, 동일한 부호화 심도의 부호화 단위에 포함되는지 여부가 확인될 수 있다. 또한, 최소 부호화 단위가 보유하고 있는 부호화 정보를 이용하면 해당 부호화 심도의 부호화 단위를 확인할 수 있으므로, 최대 부호화 단위 내의 부호화 심도들의 분포가 유추될 수 있다.For each of the minimum coding units in the coding unit, encoding information for each coding unit of the coded depth to which they belong may be stored. Therefore, when the encoding information held by the adjacent minimum coding units are respectively checked, it may be determined whether the information is included in the coding unit having the same coding depth. In addition, since the coding unit of the corresponding coding depth may be identified by using the encoding information held by the minimum coding unit, the distribution of the coded depths within the maximum coding unit may be inferred.
이하, 도 4의 본 발명의 일 실시예에 따른 영상 부호화 장치(100)의 인트라 예측부(410) 및 도 5의 영상 복호화 장치(200)의 인트라 예측부(550)에서 수행되는 인트라 예측에 대하여 구체적으로 설명한다. 이하의 설명에서, 부호화 단위는 영상의 부호화 단계에서 지칭되는 용어이며, 영상의 복호화 단계의 측면에서 부호화 단위는 복호화 단위로 정의될 수 있다. 즉, 부호화 단위와 복호화 단위라는 용어는 영상의 부호화 단계 및 복호화 단계 중 어느 단계에서 지칭되느냐의 차이만 있을 뿐이며 부호화 단계에서의 부호화 단위는 복호화 단계에서의 복호화 단위로 불리울 수 있다. 용어의 통일성을 위하여 특별한 경우를 제외하고는 부호화 단계 및 복호화 단계에서 동일하게 부호화 단위로 통일하여 부르기로 한다.Hereinafter, intra prediction performed by the
도 12는 본 발명의 일 실시예에 따른 인트라 예측 장치(1200)의 구성을 나타낸 블록도이다.12 is a block diagram illustrating a configuration of an intra prediction apparatus 1200 according to an embodiment of the present invention.
도 12를 참조하면, 본 발명의 일 실시예에 따른 인트라 예측 장치(1200)는 예측부(1210) 및 후처리부(1220)를 포함한다. 예측부(1210)는 현재 부호화 단위의 크기에 따라 정해지는 인트라 예측 모드들을 적용하여 현재 부호화 단위에 대한 인트라 예측을 수행하여 제 1 예측 부호화 단위를 출력한다. 후처리부(1200)는 제 1 예측 부호화 단위를 구성하는 각 픽셀의 주변 픽셀을 이용하여 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경하는 후처리를 수행함으로써 후처리된 제 2 예측 부호화 단위를 출력한다.Referring to FIG. 12, an intra prediction apparatus 1200 according to an embodiment of the present invention includes a
도 13은 본 발명의 일 실시예에 따른 부호화 단위의 크기에 따른 인트라 예측 모드들의 개수를 도시한다.13 illustrates the number of intra prediction modes according to the size of a coding unit, according to an embodiment of the present invention.
본 발명의 일 실시예에 따르면 부호화 단위(복호화 단계에서는 복호화 단위)의 크기에 따라서 부호화 단위에 적용할 인트라 예측 모드들의 개수를 다양하게 설정할 수 있다. 일 예로 도 13을 참조하면 인트라 예측되는 부호화 단위의 크기를 NxN이라고 할 때, 2x2, 4x4, 8x8, 16x16, 32x32, 64x64, 128x128 크기의 부호화 단위 각각에 대하여 실제 수행되는 인트라 예측 모드의 개수는 각각 5, 9, 9, 17, 33, 5, 5개(Example 2의 경우)로 설정될 수 있다. 이와 같이 부호화 단위의 크기에 따라서 실제 수행되는 인트라 예측 모드의 개수를 차별화하는 이유는 부호화 단위의 크기에 따라서 예측 모드 정보를 부호화하기 위한 오버헤드가 다르기 때문이다. 다시 말해서, 작은 크기의 부호화 단위의 경우 전체 영상에서 차지하는 부분이 작음에도 불구하고 이러한 작은 부호화 단위의 예측 모드 등의 부가 정보를 전송하기 위한 오버헤드가 증가할 수 있다. 따라서, 작은 부호화 단위를 너무 많은 예측 모드로 부호화하는 경우 비트량이 증가하여 압축 효율이 저하될 수 있다. 또한, 큰 크기를 갖는 부호화 단위, 예를 들어 64x64 이상의 크기를 갖는 부호화 단 위는 일반적으로 영상의 평탄한 영역에 대한 부호화 단위로서 선택되는 경우가 많기 때문에, 이러한 평탄한 영역을 부호화하는데 많이 선택되는 큰 크기의 부호화 단위를 너무 많은 예측 모드로 부호화하는 것 역시 압축 효율 측면에서 비효율적일 수 있다. According to an embodiment of the present invention, the number of intra prediction modes to be applied to the coding unit may be variously set according to the size of the coding unit (the decoding unit in the decoding step). As an example, referring to FIG. 13, when the size of an intra prediction coding unit is NxN, the number of intra prediction modes that are actually performed on each of coding units having a size of 2x2, 4x4, 8x8, 16x16, 32x32, 64x64, and 128x128 may be respectively. 5, 9, 9, 17, 33, 5, 5 (in the case of Example 2) can be set. The reason for differentiating the number of intra prediction modes that are actually performed according to the size of the coding unit is that the overhead for encoding the prediction mode information varies according to the size of the coding unit. In other words, although a small coding unit occupies a small portion of the entire image, overhead for transmitting additional information such as a prediction mode of the small coding unit may increase. Therefore, when a small coding unit is encoded in too many prediction modes, the bit amount may increase, thereby reducing the compression efficiency. In addition, a coding unit having a large size, for example, a coding unit having a size of 64x64 or more is generally selected as a coding unit for a flat region of an image, and thus a large size that is frequently selected for encoding such a flat region. Encoding the coding unit of in too many prediction modes may also be inefficient in terms of compression efficiency.
따라서, 본 발명의 일 실시예에 따르면, 부호화 단위가 크게 N1xN1(2≤N1≤8, N1은 정수), N2xN2(16≤N2≤32, N2는 정수), N3xN3(64≤N3, N3는 정수)의 적어도 3종류의 크기로 분류되며, N1xN1 크기를 갖는 부호화 단위마다 수행될 인트라 예측 모드의 개수를 A1(A1은 양의 정수), N2xN2 크기를 갖는 부호화 단위마다 수행될 인트라 예측 모드의 개수를 A2(A2는 양의 정수), N3xN3 크기를 갖는 부호화 단위마다 수행될 인트라 예측 모드의 개수를 A3(A3는 양의 정수)라고 할 때, A3≤A1≤A2 관계를 만족하도록 각 부호화 단위의 크기에 따라서 수행될 인트라 예측 모드의 개수를 설정하는 것이 바람직하다. 즉, 현재 픽처가 작은 크기의 부호화 단위, 중간 크기의 부호화 단위, 큰 크기의 부호화 단위로 크게 분류된다고 할 때, 중간 크기의 부호화 단위가 가장 많은 수의 예측 모드를 갖으며, 작은 크기의 부호화 단위 및 큰 크기의 부호화 단위는 상대적으로 보다 작은 수의 예측 모드를 갖도록 설정하는 것이 바람직하다. 다만, 이에 한정되지 않고 작은 크기 및 큰 크기의 부호화 단위에 대하여도 보다 많은 수의 예측 모드를 갖도록 설정할 수도 있을 것이다. 도 13에 도시된 각 부호화 단위의 크기에 따른 예측 모드의 개수는 일 실시예에 불과하며, 각 부호화 단위의 크기에 따른 예측 모드의 개수는 변경될 수 있다.Therefore, according to an embodiment of the present invention, the coding unit is largely N1xN1 (2≤N1≤8, N1 is an integer), N2xN2 (16≤N2≤32, N2 is an integer), N3xN3 (64≤N3, N3 is an integer) The number of intra prediction modes to be performed for each coding unit having an N1xN1 size, A1 (A1 is a positive integer), and the number of intra prediction modes to be performed for each coding unit having an N2xN2 size. When A2 (A2 is a positive integer) and the number of intra prediction modes to be performed for each coding unit having the size of N3xN3 is A3 (A3 is a positive integer), the size of each coding unit is satisfied to satisfy the relationship A3≤A1≤A2. It is preferable to set the number of intra prediction modes to be performed according to. That is, assuming that the current picture is largely classified into a small coding unit, a medium coding unit, and a large coding unit, the medium coding unit has the largest number of prediction modes and the small coding unit. And a coding unit having a large size is preferably set to have a relatively smaller number of prediction modes. However, the present invention is not limited thereto and may have a larger number of prediction modes for smaller and larger coding units. The number of prediction modes according to the size of each coding unit illustrated in FIG. 13 is only an embodiment, and the number of prediction modes according to the size of each coding unit may be changed.
도 14a는 본 발명의 일 실시예에 따른 소정 크기의 부호화 단위에 적용되는 인트라 예측 모드의 일 예를 설명하기 위한 도면이다. 14A is a diagram illustrating an example of an intra prediction mode applied to a coding unit of a predetermined size, according to an embodiment of the present invention.
도 13 및 도 14a를 참조하면, 일 예로 4×4 크기를 갖는 부호화 단위의 인트라 예측시에 수직(Vertical) 모드(모드 0), 수평(Horizontal) 모드(모드 1), DC(Direct Current) 모드(모드 2), 대각선 왼쪽(Diagonal Down-Left) 모드(모드 3), 대각선 오른쪽(Diagonal Down-Right) 모드(모드 4), 수직 오른쪽(Vertical-Right) 모드(모드 5), 수평 아래쪽(Horizontal-Down) 모드(모드 6), 수직 왼쪽( Vertical-Left) 모드(모드 7) 및 수평 위쪽(Horizontal-Up) 모드(모드 8)를 갖을 수 있다.13 and 14A, for example, a vertical mode (mode 0), a horizontal mode (mode 1), and a direct current (DC) mode during intra prediction of a coding unit having a size of 4 × 4. (Mode 2), Diagonal Down-Left Mode (Mode 3), Diagonal Down-Right Mode (Mode 4), Vertical-Right Mode (Mode 5), Horizontal Down (Horizontal) -Down mode (mode 6), vertical left (Right-Left) mode (mode 7) and horizontal-up (Horizontal-Up) mode (mode 8).
도 14b는 도 14a의 인트라 예측 모드들의 방향을 나타내는 도면이다. 도 14b에서 화살표의 끝에 있는 숫자는 그 방향으로 예측을 수행할 경우 해당 모드값을 나타낸다. 여기서 모드 2는 방향성이 없는 DC 예측 모드로서 도시되어 있지 않다. 14B is a diagram illustrating the directions of intra prediction modes of FIG. 14A. In FIG. 14B, the number at the end of the arrow indicates the mode value when the prediction is performed in the direction.
도 14c는 도 14a에 도시된 부호화 단위에 대한 인트라 예측 방법을 도시한 도면이다. FIG. 14C illustrates an intra prediction method for the coding unit illustrated in FIG. 14A.
도 14c를 참조하면, 부호화 단위의 크기에 의하여 결정된 이용가능한 인트라 예측 모드에 따라서 현재 부호화 단위의 주변 픽셀인 A - M을 이용하여 예측 부호화 단위를 생성한다. 예를 들어, 도 14a의 모드 0, 즉 수직 모드에 따라, 4×4 크기의 현재 부호화 단위를 예측 부호화하는 동작을 설명한다. 먼저 4×4 크기의 현재 부호화 단위의 위쪽에 인접한 화소 A 내지 D의 화소값을 4×4 현재 부호화 단위의 화소값으로 예측한다. 즉, 화소 A의 값을 4×4 현재 부호화 단위의 첫 번째 열 에 포함된 4개의 화소값으로, 화소 B의 값을 4×4 현재 부호화 단위의 두 번째 열에 포함된 4개의 화소값으로, 화소 C의 값을 4×4 현재 부호화 단위의 세 번째 열에 포함된 4개의 화소값으로, 화소 D의 값을 4×4 현재 부호화 단위의 네 번째 열에 포함된 4개의 화소값으로 예측한다. 다음, 상기 화소 A 내지 D를 이용하여 예측된 4×4 현재 부호화 단위와 원래의 4×4 현재 부호화 단위에 포함된 화소의 실제값을 감산하여 오차값을 구한 후 그 오차값을 부호화한다.Referring to FIG. 14C, a prediction coding unit is generated using A-M which is a neighboring pixel of the current coding unit according to an available intra prediction mode determined by the size of the coding unit. For example, an operation of predictively encoding the current coding unit having a size of 4x4 according to
도 15는 본 발명의 일 실시예에 따른 소정 크기의 부호화 단위에 적용되는 인트라 예측 모드의 다른 예를 설명하기 위한 도면이다. FIG. 15 illustrates another example of an intra prediction mode applied to a coding unit of a predetermined size, according to an embodiment of the present invention.
도 13 및 도 15를 참조하면, 일 예로 2×2 크기를 갖는 부호화 단위의 인트라 예측시에 수직(Vertical) 모드, 수평(Horizontal) 모드, DC(Direct Current) 모드, 플레인(plane) 모드 및 대각선 오른쪽(Diagonal Down-Right) 모드의 총 5개의 모드가 존재할 수 있다.13 and 15, for example, in an intra prediction of a coding unit having a size of 2 × 2, a vertical mode, a horizontal mode, a direct current mode, a plane mode, and a diagonal line There may be a total of five modes of Diagonal Down-Right mode.
한편, 도 13에 도시된 바와 같이 32x32 크기를 갖는 부호화 단위가 33개의 인트라 예측 모드를 갖는다고 할 때, 33개의 인트라 예측 모드의 방향을 설정할 필요가 있다. 본 발명의 일 실시예에서는 도 14 및 도 15에 도시된 바와 같은 인트라 예측 모드 이외에, 다양한 방향의 인트라 예측 모드를 설정하기 위하여 부호화 단위 내의 픽셀을 중심으로 참조 픽셀로서 이용될 주변 픽셀을 선택하기 위한 예측 방향을 dx, dy 파라메터를 이용하여 설정한다. 일 예로, 33개의 예측 모드들을 각각 mode N(N은 0부터 32까지의 정수)이라고 정의할 때, mode 0은 수직 모드, mode 1은 수평 모드, mode 2는 DC 모드, mode 3는 플레인 모드로 설정하고 mode 4 ~ mode31 각각은 다음의 표 1에 표기된 바와 같은 (1,-1), (1,1), (1,2), (2,1), (1,-2), (2,1), (1,-2), (2,-1), (2,-11), (5,-7), (10,-7), (11,3), (4,3), (1,11), (1,-1), (12,-3), (1,-11), (1,-7), (3,-10), (5,-6), (7,-6), (7,-4), (11,1), (6,1), (8,3), (5,3), (5,7), (2,7), (5,-7), (4,-3) 중 하나의 값으로 표현되는 (dx, dy)를 이용하여 tan-1(dy/dx)의 방향성을 갖는 예측 모드로 정의할 수 있다. Meanwhile, as illustrated in FIG. 13, when a coding unit having a size of 32x32 has 33 intra prediction modes, it is necessary to set 33 intra prediction modes. According to an embodiment of the present invention, in addition to the intra prediction modes as shown in FIGS. 14 and 15, a peripheral pixel to be used as a reference pixel to be used as a reference pixel centered on pixels in a coding unit to set intra prediction modes in various directions. The prediction direction is set using the dx and dy parameters. For example, when 33 prediction modes are defined as mode N (N is an integer from 0 to 32),
마지막 mode 32는 도 17을 이용하여 후술되는 바와 같이 쌍선형(bilinear) 보간을 이용하는 쌍선형 모드로 설정될 수 있다.The
도 16은 본 발명의 일 실시예에 따른 다양한 방향성을 갖는 인트라 예측 모드들을 설명하기 위한 참조도이다.16 is a reference diagram for explaining intra prediction modes having various directions according to an embodiment of the present invention.
표 1을 참조하여 전술한 바와 같이, 본 발명의 일 실시예에 따른 인트라 예측 모드들은 복수 개의 (dx, dy) 파라메터들을 이용하여 tan-1(dy/dx)의 다양한 방향성을 갖을 수 있다.As described above with reference to Table 1, intra prediction modes according to an embodiment of the present invention may have various directionalities of tan −1 (dy / dx) using a plurality of (dx, dy) parameters.
도 16을 참조하면, 현재 부호화 단위 내부의 예측하고자 하는 현재 픽셀(P)을 중심으로 표 1에 표기된 모드별 (dx, dy)의 값에 따라 정해지는 tan-1(dy/dx)의 각도를 갖는 연장선(150) 상에 위치한 주변 픽셀(A, B)를 현재 픽셀(P)의 예측자로 이용할 수 있다. 이 때, 예측자로서 이용되는 주변 픽셀은 이전에 부호화되고 복원된, 현재 부호화 단위의 상측 및 좌측의 이전 부호화 단위의 픽셀인 것이 바람직하다. 또한, 연장선(160)이 정수 위치의 주변 픽셀이 아닌 정수 위치 주변 픽셀의 사이를 통과하는 경우 연장선(160)에 더 가까운 주변 픽셀을 현재 픽셀(P)의 예측자로 이용할 수 있다. 또한, 도시된 바와 같이 연장선(160)과 만나는 상측의 주변 픽셀(A) 및 좌측의 주변 픽셀(B)의 두 개의 주변 픽셀이 존재하는 경우 상측의 주변 픽셀(A) 및 좌측의 주변 픽셀(B)의 평균값을 현재 픽셀(P)의 예측자로 이용하거나, 또는 dx*dy 값이 양수인 경우에는 상측의 주변 픽셀(A)을 이용하고 dx*dy 값이 음수인 경우에는 좌측의 주변 픽셀(B)을 이용할 수 있다. Referring to FIG. 16, an angle of tan −1 (dy / dx) determined according to values of (dx, dy) for each mode shown in Table 1 around the current pixel P to be predicted in the current coding unit is determined. Peripheral pixels A and B positioned on the extension line 150 may be used as predictors of the current pixel P. In this case, the neighboring pixel used as the predictor is preferably a pixel of the previous coding unit on the left side and the current coding unit, which has been previously encoded and reconstructed. In addition, when the
표 1에 표기된 바와 같은 다양한 방향성을 갖는 인트라 예측 모드는 부호화단과 복호화단에서 미리 설정되어서, 각 부호화 단위마다 설정된 인트라 예측 모드의 해당 인덱스만이 전송되도록 하는 것이 바람직하다.The intra prediction modes having various directionalities as shown in Table 1 are preferably set in the encoding end and the decoding end so that only corresponding indexes of the intra prediction modes set for each coding unit are transmitted.
도 17은 본 발명의 일 실시예에 따른 쌍선형 모드를 설명하기 위한 참조도이다.17 is a reference diagram for describing a bilinear mode according to an embodiment of the present invention.
도 17을 참조하면, 쌍선형(Bi-linear) 모드는 현재 부호화 단위 내부의 예측하고자 하는 현재 픽셀(P)를 중심으로 현재 픽셀(P)와 그 상하좌우 경계의 픽셀값, 현재 픽셀(P)의 상하좌우 경계까지의 거리를 고려한 기하 평균값을 계산하여 그 결과값을 현재 픽셀(P)의 예측자로 이용하는 것이다. 즉, 쌍선형 모드에서는 현재 픽셀(P)의 예측자로서 현재 픽셀(P)의 상하좌우 경계에 위치한 픽셀 A(171), 픽셀 B(172), 픽셀 D(176) 및 픽셀 E(177)과 현재 픽셀(P)의 상하좌우 경계까지의 거리의 기하 평균값을 이용한다. 이 때, 쌍선형 모드 역시 인트라 예측 모드 중의 하나이므로 예측시의 참조 픽셀로서 이전에 부호화된 후 복원된 상측과 좌측의 주변 픽셀을 이용하여야 한다. 따라서, 픽셀 A(161) 및 픽셀 (B)로서 현재 부호화 단위 내부의 해당 픽셀값을 그대로 이용하는 것이 아니라 상측 및 좌측의 주변 픽셀을 이용하여 생성된 가상의 픽셀값을 이용한다.Referring to FIG. 17, in the bi-linear mode, the pixel value of the current pixel P, the upper, lower, left, and right boundaries of the current pixel P within the current coding unit, and the current pixel P The geometric mean value is calculated by considering the distance to the top, bottom, left, and right edges of and used as the predictor of the current pixel P. That is, in the bilinear mode, as a predictor of the current pixel P, pixels A 171,
구체적으로, 먼저 다음의 수학식과 같이 현재 부호화 단위에 인접한 상측 최좌측의 주변 픽셀(RightUpPixel, 174) 및 좌측 최하측의 주변 픽셀(LeftDownPixel,175)의 평균값을 계산함으로써 현재 부호화 단위의 우측 최하단 위치의 가상의 픽셀 C(173)을 계산한다.Specifically, first, by calculating the average value of the upper leftmost peripheral pixel (RightUpPixel, 174) and the left lowermost peripheral pixel (LeftDownPixel, 175) adjacent to the current coding unit, as shown in the following equation, The
C=0.5(LeftDownPixel+RightUpPixel)C = 0.5 (LeftDownPixel + RightUpPixel)
다음 현재 픽셀(P)의 좌측 경계까지의 거리(W1) 및 우측 경계까지의 거리(W2)를 고려하여 현재 픽셀(P)를 하단으로 연장하였을 때 최하측 경계선에 위치하는 가상의 픽셀 A(171)의 값을 다음의 수학식과 같이 계산한다.The
A=(C*W1+LeftDownPixel*W2)/(W1+W2)A = (C * W1 + LeftDownPixel * W2) / (W1 + W2)
유사하게 현재 픽셀(P)의 상측 경계까지의 거리(h1) 및 하측 경계까지의 거리(h2)를 고려하여 현재 픽셀(P)를 우측으로 연장하였을 때 최우측 경계선에 위치하는 가상의 픽셀 B(172)의 값을 다음의 수학식과 같이 계산한다.Similarly, when the current pixel P is extended to the right in consideration of the distance h1 to the upper boundary of the current pixel P and the distance h2 to the lower boundary, the virtual pixel B located at the rightmost boundary line ( The value of 172 is calculated as in the following equation.
B=(C*h1+RightUpPixel*h2)/(h1+h2)B = (C * h1 + RightUpPixel * h2) / (h1 + h2)
상기 수학식들을 이용하여 현재 픽셀 P(170)의 하측 경계선상의 가상의 픽셀 A(171) 및 우측 경계선상의 가상의 픽셀 B(172)의 값이 결정되면 A+B+D+E의 평균값을 현재 픽셀 P(170)의 예측자로서 이용할 수 있다. 이와 같은 쌍선형 예측 과정은 현재 부호화 단위 내부의 모든 픽셀에 대하여 적용되어, 쌍선형 예측 모드에 따른 현재 부호화 단위의 예측 부호화 단위가 생성된다.When the values of the
본 발명의 일 실시예에 따르면 부호화 단위의 크기에 따라서 다양하게 설정된 인트라 예측 모드들에 따라서 예측 부호화를 수행함으로써 영상의 특성에 따라서 보다 효율적인 압축을 가능하게 한다.According to an embodiment of the present invention, the prediction encoding is performed according to intra prediction modes that are variously set according to the size of a coding unit, thereby enabling more efficient compression according to the characteristics of an image.
전술한 바와 같이, 도 12의 인트라 예측부(1200)의 예측부(1210)로부터 부호화 단위의 크기에 따라서 다양하게 설정된 인트라 예측 모드들을 적용하여 출력되는 예측 부호화 단위는 적용된 인트라 예측 모드에 따라서 일정한 방향성을 갖는다. 이러한 예측 부호화 단위 내부의 방향성은 부호화되는 현재 부호화 단위의 픽셀들이 일정한 방향성을 갖는 경우에는 예측 효율이 향상될 수 있지만 현재 부호화 단위의 픽셀들이 방향성을 갖지 않는 경우에는 예측 효율이 떨어질 수 있다. 따라서, 후처리부(1220)는 인트라 예측을 통해 생성된 예측 부호화 단위에 대한 후처리 동작으로서, 예측 부호화 단위 내부의 각 픽셀과 적어도 하나의 주변 픽셀을 이용하여 예측 부호화 단위 내부의 각 픽셀의 픽셀값을 변경하여 새로운 예측 부호화 단위를 생성함으로써 영상의 예측 효율을 향상시킨다.As described above, the prediction coding unit output by applying the intra prediction modes that are variously set according to the size of the coding unit from the
이하, 도 12의 후처리부(1220)에서 수행되는 예측 부호화 단위의 후처리 동작에 대하여 설명한다.Hereinafter, the post processing operation of the prediction coding unit performed by the
후처리부(1220)는 예측부(1210)에서 생성된 제 1 예측 부호화 단위를 구성하는 각 픽셀과 적어도 하나의 주변 픽셀을 이용한 연산을 통해 제 1 예측 부호화 단위를 구성하는 각 픽셀의 픽셀값을 변경하여 제 2 예측 부호화 단위를 생성한다. 여기서, 예측부(1220)는 전술한 바와 같이 부호화 단위의 크기에 따른 이용가능한 인트라 예측 모드들을 적용하여 제 1 예측 부호화 단위를 생성한다.The
도 18은 본 발명의 일 실시예에 따른 제 1 예측 부호화 단위의 후처리 동작을 설명하기 위한 참조도이다. 도 18에서 도면 부호 1810 내지 1860은 후처리부(1220)에 의하여 처리되는 제 1 예측 부호화 단위 내부의 각 픽셀값이 변경되는 과정을 시간 순서로 나타낸 것이다.18 is a reference diagram for explaining a post-processing operation of a first prediction coding unit according to an embodiment of the present invention. In FIG. 18,
도 18을 참조하면, 본 발명의 일 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위 내부의 변경하고자 하는 픽셀과 그 주변 픽셀들의 픽셀값들의 가중 평균값을 계산하여 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경한다. 예를 들어, 도 18에서 제 1 예측 부호화 단위(1810)의 변경하고자 하는 픽셀(1821)의 픽셀값을 f[1][1], 상측에 위치한 픽셀(1822)의 픽셀값을 f[0][1], 좌측에 위치한 픽셀(1823)의 픽셀값을 f[1][0]이라고 하면, 픽셀(1821)의 픽셀값 f[1][1]을 변경한 값을 f'[1][1]이라고 하면, f'[1][1]은 다음의 수학식 1과 같이 계산될 수 있다.Referring to FIG. 18, the post-processor 1220 according to an embodiment of the present invention calculates a weighted average value of pixel values of pixels to be changed in the first prediction coding unit and pixels of the neighboring pixels to determine a weighted average value of the first prediction coding unit. Change the pixel value of each pixel. For example, in FIG. 18, f [1] [1] is the pixel value of the
도 18에 도시된 바와 같이, 본 발명의 일 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위 내부의 각 픽셀들에 대해서 최좌상측으로부터 최우하측 방향으로 변경하고자 하는 픽셀과 그 상측 및 좌측에 위치한 픽셀들의 가중 평균값을 계산하여 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경한다. 그러나, 본 발명에 따른 예측 부호화 단위의 후처리 동작은 최좌상측으로부터 최우하측 방향으로 한정되는 것이 아니라, 최우상측으로부터 최좌하측 방향으로, 또는 최우하측으로부터 최좌상측 방향으로, 또는 최좌하측으로부터 최우상측 방향으로 제 1 예측 부호화 단위의 각 픽셀들에 대하여 순차적으로 수행될 수 있다. 예를 들어 후처리부(1220)는 도 18에 도시된 처리 순서와 반대로 최우하측으로부터 최좌상측 방향으로 제 1 예측 부호화 단위의 픽셀들을 변경하는 경우에는 변경하고자 하는 픽셀과 그 하측 및 우측에 위치한 픽셀들의 가중 평균값을 계산하여 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경한다. As illustrated in FIG. 18, the post-processor 1220 according to an embodiment of the present invention may include pixels to be changed from the upper left side to the lower right side with respect to each pixel in the first prediction coding unit, and upper and lower sides thereof. The pixel value of each pixel of the first prediction coding unit is changed by calculating a weighted average value of pixels located on the left side. However, the post-processing operation of the prediction coding unit according to the present invention is not limited to the left-most side from the left-most side, but is from the right-most side to the left-most side, or from the right-most side to the left-most side, or the left-most side. From each of the pixels of the first prediction coding unit may be sequentially performed in the top-right direction. For example, when the
도 19 및 도 20은 본 발명의 일 실시예에 따른 후처리부(1220)의 동작을 설명하기 위한 참조도이다. 도 19에서 도면 부호 1910은 현재 변경하고자 하는 제 1 예측 부호화 단위의 제 1 픽셀을 나타내며, 도면 부호 1911 내지 1918은 제 1 픽셀(1910)의 주변에 위치한 주변 픽셀들을 나타낸다.19 and 20 are reference diagrams for describing an operation of the
도 19를 참조하면, 본 발명의 일 실시예에 따른 후처리부(1220)는 도 18에 도시된 바와 같이 제 1 예측 부호화 단위의 상측 및 좌측에 위치한 주변 픽셀에 한정되지 않고, 주변 픽셀들(1911 내지 1918) 중 선택된 소정 개수의 주변 픽셀들을 이용하여 제 1 픽셀(1910)에 대한 후처리를 수행할 수 있다. 즉, 도 20을 참조하면, 현재 부호화 단위의 제 1 픽셀(c)를 중심으로 그 주변 픽셀들(P1 내지 P8) 중에서 소정 개수의 주변 픽셀들을 선택하고, 선택된 주변 픽셀과 제 1 픽셀(c)을 이용한 소정의 연산을 통해 제 1 픽셀(c)의 픽셀값을 변경한다. 예를 들어, 제 1 예측 부호화 단위의 크기를 mxn(m 및 n은 양의 정수), 제 1 예측 부호화 단위 내부의 변경하고자 하는 i(i는 0부터 m-1까지의 정수)번째 열 및 j(j는 0부터 n-1까지의 정수)번째 행에 위치한 제 1 픽셀(1910)의 픽셀값을 f[i][j], 제 1 픽셀(1910)의 주변 픽셀들(1911 내지 1918) 중 제1 픽셀(1910)의 후처리를 위해 선택된 n개(n은 2 또는 3)의 픽셀들의 값을 각각 f1 내지 fn이라고 하면, 후처리부(1220)는 다음의 수학식 2와 같이 제 1 픽셀(1910)의 픽셀값 f[i][j]를 f'[i][j]로 변경한다.Referring to FIG. 19, the
후처리부(1220)는 제 1 예측 부호화 단위(1900) 내부의 모든 픽셀들에 대하여 전술한 수학식 2를 적용하여 픽셀값을 변경함으로써 제 2 예측 부호화 단위를 생성한다. 전술한 수학식 2에서는 3개까지의 주변 픽셀들을 이용하는 경우를 예시하였으나, 이에 한정되지 않고 후처리부(1220)는 4개 이상의 주변 픽셀들을 이용하 여 후처리 동작을 수행할 수 있다.The
본 발명의 제 2 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위의 변경되는 각 픽셀과, 각 픽셀의 주변에 위치한 픽셀들의 가중 조화 평균값을 통해 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경함으로써 제 2 예측 블록을 생성한다.The
예를 들어, 본 발명의 제 2 실시예에 따른 후처리부(1220)는 다음의 수학식 3과 같이 상측 및 좌측의 주변 픽셀을 이용하여 제 1 예측 부호화 단위의 i번째 열 및 j번째 행에 위치한 픽셀의 픽셀값 f[i][j]를 f'[i][j]로 변경한다.For example, the
수학식 3에서, α, β, γ는 임의의 양의 정수값을 갖을 수 있으며, 일 예로 α=2, β=2, γ=1 일 수 있다.In
본 발명의 제 3 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위의 변경되는 각 픽셀과 각 픽셀의 주변 픽셀들의 가중 기하 평균값을 통해 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경함으로써 제 2 예측 부호화 단위를 생성한다.The
예를 들어, 본 발명의 제 3 실시예에 따른 후처리부(1220)는 다음의 수학식 4와 같이 상측 및 좌측의 주변 픽셀을 이용하여 제 1 예측 부호화 단위의 i번째 열 및 j번째 행에 위치한 픽셀의 픽셀값 f[i][j]를 f'[i][j]로 변경한다.For example, the post-processor 1220 according to the third embodiment of the present invention is located in the i-th column and the j-th row of the first prediction coding unit by using the upper and left peripheral pixels as shown in
수학식 4에서, α, β, γ는 임의의 양의 정수값을 갖을 수 있으며, 일 예로 α=1, β=1, γ=2 일 수 있다. 전술한 수학식 2 내지 4에서는 모두 변경하고자 하는 픽셀 f[i][j]에 상대적으로 큰 가중치를 부여한다.In
전술한 바와 같이 본 발명의 제 1 실시예 내지 제 3 실시예에서 후처리부(1220)는 변경하고자 하는 픽셀의 상측 및 좌측의 주변 픽셀에 한정되지 않고 도 19에 도시된 바와 같은 주변 픽셀들(1911 내지 1918) 중 선택된 소정 개수의 주변 픽셀들을 이용하여 후처리 동작을 수행할 수 있다. As described above, in the first to third embodiments of the present invention, the
본 발명의 제 4 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위의 변경하고자 하는 픽셀과 그 주변 픽셀들 중 선택된 하나의 주변 픽셀의 평균값으로 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경함으로써 제 2 예측 부호화 단위를 생성한다.The
예를 들어, 본 발명의 제 4 실시예에 따른 후처리부(1220)는 다음의 수학식 5와 같이 상측의 주변 픽셀을 이용하여 제 1 예측 부호화 단위의 i번째 열 및 j번째 행에 위치한 픽셀의 픽셀값 f[i][j]를 f'[i][j]로 변경할 수 있다.For example, the
유사하게 본 발명의 제 5 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위의 변경되는 픽셀과 그 좌측에 위치한 주변 픽셀의 평균값으로 제 1 예측 부호하 단위의 각 픽셀의 픽셀값을 변경함으로써 제 2 예측 부호화 단위를 생성한다.Similarly, the
즉, 본 발명의 제 5 실시예에 따른 후처리부(1220)는 다음의 수학식 6과 같이 제 1 예측 부호화 단위의 i번째 열 및 j번째 행에 위치한 픽셀의 픽셀값 f[i][j]를 f'[i][j]로 변경한다.That is, the post-processor 1220 according to the fifth embodiment of the present invention performs pixel values f [i] [j] of pixels located in the i th column and the j th row of the first prediction coding unit as shown in
본 발명의 제 6 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위의 변경하고자하는 픽셀, 그 주변 픽셀들 사이의 중간값(median)으로 픽셀값을 변경함으로써 제 2 예측 부호화 단위를 생성한다. 예를 들어, 다시 도 19를 참조하면, 제 1 예측 부호화 단위(1900)의 i번째 열 및 j번째 행에 위치한 제 1 픽셀(1910)의 픽셀값 f[i][j], 제 2 픽셀(1912)의 픽셀값 f[i][j-1], 제 3 픽셀(1911)의 픽셀값 f[i-1][j]들이 다음의 크기 순서; f[i][j-1]>f[i-1][j]>f[i][j]를 갖는다고 가정한다. 이 경우 본 발명의 제 6 실시예에 따른 후처리부(1220)는 변경하고자 하는 제 1 픽셀(510)의 픽셀값 f[i][j]를 중간값인 f[i-1][j]으로 변경한다.The
본 발명의 제 7 실시예 내지 제 9 실시예에 따른 후처리부(1220)는 변경되는 픽셀의 주변 픽셀들을 이용하는 대신에 현재 부호화 단위 이전에 부호화된 후 복원된 인접한 부호화 단위들의 픽셀값을 이용하여 제 2 예측 부호화 단위를 생성한다.The
다시 도 19를 참조하면, 본 발명의 제 7 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위(1900) 내부의 변경하고자 하는 i번째 열 및 j번째 행에 위치한 제 1 픽셀(1910)과 동일한 열에 위치하면서 현재 부호화 단위의 상측 인접 부호화 단위에 위치한 픽셀(1921)의 평균값을 다음의 수학식 7과 같이 계산하여 제 1 픽셀(1910)의 픽셀값을 f'[i][j]로 변경한다.Referring back to FIG. 19, the post-processor 1220 according to the seventh embodiment of the present invention may include the
수학식 7에서 f[-1][j]는 제 1 픽셀(1910)과 동일한 열에 위치하면서 현재 부호화 단위의 상측 인접 부호화 단위에 위치한 픽셀(1921)의 픽셀값을 나타낸다.In
유사하게 본 발명의 제 8 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위(1900) 내부의 변경하고자 하는 i번째 열 및 j번째 행에 위치한 제 1 픽셀(1910)과 동일한 행에 위치하면서 현재 부호화 단위의 좌측 인접 부호화 단위에 위치한 픽셀(1922)의 평균값을 다음의 수학식 8과 같이 계산하여 제 1 픽셀(1910)의 픽셀값을 f'[i][j]로 변경한다.Similarly, the
수학식 8에서 f[i][-1]는 제 1 픽셀(1910)과 동일한 행에 위치하면서 현재 부호화 단위의 좌측 인접 부호화 단위에 위치한 픽셀(1922)의 픽셀값을 나타낸다.In
본 발명의 제 9 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위(1900) 내부의 변경하고자 하는 i번째 열 및 j번째 행에 위치한 제 1 픽셀(1910), 제 1 픽셀(1910)과 동일한 열에 위치하면서 현재 부호화 단위의 상측 인접 부호화 단위에 위치한 픽셀(1921) 및 동일한 행에 위치하면서 현재 부호화 단위의 좌측 인접 부호화 단위에 위치한 픽셀(1922)의 가중 평균값을 다음의 수학식 9와 같이 계산하여 제 1 픽셀(1910)의 픽셀값을 f'[i][j]로 변경한다.The post-processor 1220 according to the ninth embodiment of the present invention may include the
본 발명의 제 10 실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위(1900) 내부의 변경하고자 하는 제 1 픽셀의 픽셀값 f[i][j]를 다음의 수학식 10 내지 13 중 하나를 이용하여 f'[i][j]로 변경한다.The
수학식 10은 제 1 예측 부호화 단위의 열 단위로 픽셀값들을 아래 방향으로 점차 증가하는 값으로 변경하는 것이며, 수학식 11은 제 1 예측 부호화 단위의 행 단위로 픽셀값들을 오른쪽 방향으로 점차 증가하는 값으로 변경하는 것이다. 수학식 12는 제 1 예측 부호화 단위의 열 단위로 각 픽셀값들을 아래 방향으로 점차 감소하는 값으로 변경하는 것이며, 수학식 13은 제 1 예측 부호화 단위의 행 단위로 각 픽셀값들을 오른쪽 방향으로 점차 감소하는 값으로 변경하는 것이다.Equation 10 changes pixel values to a value gradually increasing in a downward direction in units of columns of a first prediction coding unit, and
본 발명의 제 11실시예에 따른 후처리부(1220)는 제 1 예측 부호화 단위 내부의 변경하고자 하는 i번째 열 및 j번째 행에 위치한 제 1 픽셀의 픽셀값을 f[i][j], 제 1 예측 부호화 단위의 최좌상측에 위치한 픽셀의 픽셀값을 f[0][0], 제 1 픽셀과 동일한 j번째 열에 위치하며 제 1 예측 부호화 단위의 최상측행에 위치한 픽셀의 픽셀값을 f[0][j], 제 1 픽셀과 동일한 i번째 행에 위치하며 제 1 예측 부호화 단위의 최좌측열에 위치한 픽셀의 픽셀값을 f[i][0], 라고 할 때, 다음의 수학식 14와 같이 제 1 픽셀의 픽셀값을 f'[i][j]로 변경한다.The
수학식 14는 일종의 파동 방정식(wave equation)에 기초한 것으로, 제 1 예측 부호화 내부의 픽셀값을 스무딩(smoothing)하기 위해서 제 1 예측 부호화 단위의 최상측행의 픽셀값과 최좌측열의 픽셀값을 경계 조건으로 하여서 G[i][j]를 계산하고, G[i][j]와 f[i][j]의 평균값을 계산함으로써 제 1 예측 부호화 단위의 픽셀들의 픽셀값을 변경하는 것이다.Equation (14) is based on a kind of wave equation, which is a boundary condition between the pixel value of the leftmost column and the pixel value of the leftmost column of the first prediction coding unit in order to smooth the pixel value inside the first prediction coding. By calculating G [i] [j] and calculating the average value of G [i] [j] and f [i] [j], the pixel values of the pixels of the first prediction coding unit are changed.
본 발명의 제 1 실시예 내지 제 11 실시예들과 같이 다양한 연산 모드를 적용하여 생성된 제 2 예측 부호화 단위들을 부호화한 비트스트림의 코스트가 비교되어, 최소 코스트를 갖는 제 2 예측 부호화 단위를 생성하는데 이용된 연산 정보가 비트스트림의 헤더 영역에 부가된다. 연산 정보를 비트스트림에 부가할 때 소정 개수의 부호화 단위들에 대한 부호화가 완료된 이후 결정된 연산 정보의 분포에 기초하여, 많이 이용되는 연산 정보에 적은 비트를 할당하는 가변 길이 부호화 방식을 적용함으로써 서로 다른 연산을 구분하여 표시할 수 있다. 예를 들어, 본 발명의 제 1 실시예에 따른 연산이 대부분의 부호화 단위에서 가장 작은 코스트를 발생시키는 최적의 연산이라고 할 때, 제 1 실시예에 따른 연산을 나타내는 인덱스에 가장 작은 비트를 할당하여 제 1 실시예에 따른 연산을 다른 실시예에 따른 연산들 과 구별되도록 할 수 있다.As in the first to eleventh embodiments of the present invention, the costs of bitstreams encoding the second prediction coding units generated by applying various operation modes are compared to generate a second prediction coding unit having a minimum cost. The operation information used to add is added to the header area of the bitstream. When the operation information is added to the bitstream, the variable length coding scheme of allocating a small bit to the operation information that is frequently used is different based on the distribution of the operation information determined after the encoding of the predetermined number of coding units is completed. Operations can be displayed separately. For example, when an operation according to the first embodiment of the present invention is an optimal operation that generates the smallest cost in most coding units, the smallest bit is assigned to the index representing the operation according to the first embodiment. The operation according to the first embodiment may be distinguished from the operations according to the other embodiments.
한편, 부호화 단위를 더 작은 서브 부호화 단위들로 나누어 예측을 수행하는 경우, 각 서브 부호화 단위 별로 서로 다른 연산을 적용하여 제 2 예측 부호화 단위를 생성할 수도 있고, 계산을 간소화하고 오버 헤드의 비율을 낮추기 위해서 동일한 부호화 단위에 포함되는 서브 부호화 단위들에는 동일한 연산이 적용되도록 할 수 있다.On the other hand, when performing prediction by dividing a coding unit into smaller sub-coding units, a second prediction coding unit may be generated by applying a different operation to each sub-coding unit, simplifying the calculation and reducing the overhead ratio. In order to decrease, the same operation may be applied to sub-coding units included in the same coding unit.
최적의 연산 모드를 결정하기 위한 코스트로는 율-왜곡 최적화(Rate-Distortion Optimization) 방식이 이용될 수 있다. 본 발명의 일 실시예에 따른 부호화 방법은 다른 부호화 단위의 참조 데이터로 이용되는 인트라 예측 부호화 단위에 적용되기 때문에 율-왜곡 최적화 방식에서 왜곡값(distortion)에 높은 가중치를 두어 코스트를 계산하는 것이 바람직하다. 즉, 종래 율-왜곡 최적화 방식은 다음의 수학식 15와 같이 부호화된 영상과 원영상의 차이값인 왜곡값 및 발생되는 비트레이트에 기초하여 코스트를 계산한다.A rate-distortion optimization method may be used as a cost for determining an optimal operation mode. Since the encoding method according to an embodiment of the present invention is applied to an intra prediction coding unit used as reference data of another coding unit, it is preferable to calculate the cost by giving a high weight to the distortion value in the rate-distortion optimization method. Do. That is, the conventional rate-distortion optimization method calculates the cost based on the distortion value and the generated bit rate, which are the difference between the encoded image and the original image, as shown in Equation 15 below.
이에 반하여 본 발명의 일 실시예에 따른 부호화 방식에서는 다음의 수학식 16과 같이 종래 율-왜곡 최적화 방식에 비하여 왜곡값에 보다 높은 가중치를 할당하여 최적의 연산 모드를 결정하는 것이 바람직하다. In contrast, in the encoding method according to the embodiment of the present invention, it is preferable to assign the higher weight to the distortion value to determine the optimal operation mode as compared with the conventional rate-distortion optimization method as shown in
도 21은 본 발명의 일 실시예에 따른 영상 부호화 방법을 나타낸 플로우 차트이다.21 is a flowchart illustrating an image encoding method according to an embodiment of the present invention.
도 21을 참조하면, 단계 2110에서 부호화되는 현재 부호화 단위에 대한 제 1 예측 부호화 단위를 생성한다. 여기서, 제 1 예측 부호화 단위는 일반적인 인트라 예측 방식 및 전술한 바와 같이 부호화 단위의 크기에 따라서 다양한 방향성을 갖는 인트라 예측 모드들을 적용하여 생성된 인트라 예측 블록이다.Referring to FIG. 21, a first prediction coding unit for the current coding unit encoded in
단계 2120에서, 제 1 예측 부호화 단위를 구성하는 각 픽셀과 적어도 하나의 주변 픽셀을 이용하여 제 1 예측 부호화 단위의 각 픽셀의 픽셀값을 변경하여 제 2 예측 부호화 단위를 생성한다. 전술한 후처리부(1220)의 제 1 실시예 내지 제 11 실시예에서 설명한 바와 같이, 제 1 예측 부호화 단위의 변경하고자 하는 픽셀을 중심으로 그 주변 픽셀들에 다양한 연산 모드를 적용하여 제 1 예측 부호화 단위의 각 픽셀들의 픽셀값을 변경함으로써 제 2 예측 부호화 단위를 생성한다.In
단계 2130에서, 현재 부호화 단위와 제 2 예측 부호화 단위의 차이값인 레지듀얼을 변환, 양자화 및 엔트로피 부호화하여 비트스트림을 생성한다. 생성된 비트스트림의 소정 영역에는 제 2 예측 부호화 단위를 생성하는데 이용된 연산 정보를 부가함으로써 복호화 장치에서 현재 부호화 단위에 대한 제 2 예측 부호화 단위를 생성할 수 있도록 한다.In
도 22는 본 발명의 일 실시예에 따른 영상 복호화 방법을 나타낸 플로우 차트이다.22 is a flowchart illustrating an image decoding method according to an embodiment of the present invention.
도 22를 참조하면, 단계 2210에서 수신된 비트스트림으로부터 복호화되는 현 재 복호화 단위의 예측 모드 정보를 추출한다.Referring to FIG. 22, prediction mode information of a current decoding unit decoded from a bitstream received in
단계 2220에서, 추출된 예측 모드 정보에 따라서 현재 복호화 단위에 대한 제 1 예측 복호화 단위를 생성한다.In
단계 2230에서, 비트스트림으로부터 제 1 예측 복호화 단위를 구성하는 각 픽셀과 각 픽셀의 주변 픽셀들을 이용한 연산 정보를 추출한다.In
단계 2240에서, 추출된 연산 정보에 따라서 제 1 예측 복호화 단위를 구성하는 각 픽셀과 각 픽셀의 주변 픽셀들을 이용하여 각 픽셀의 픽셀값을 변경하여 제 2 예측 복호화 단위를 생성한다.In
단계 2250에서, 비트스트림으로부터 현재 복호화 단위와 제 2 예측 복호화 단위의 차이값에 해당하는 레지듀얼을 추출하여 복원한다.In
단계 2260에서, 레지듀얼과 제 2 예측 복호화 단위를 가산하여 현재 복호화 단위를 복호화한다.In
본 발명에 따른 영상의 부호화, 복호화 방법은 또한 컴퓨터로 읽을 수 있는 기록매체에 컴퓨터가 읽을 수 있는 코드로서 구현하는 것이 가능하다. 컴퓨터가 읽을 수 있는 기록매체는 컴퓨터 시스템에 의하여 읽혀질 수 있는 데이터가 저장되는 모든 종류의 기록장치를 포함한다. 컴퓨터가 읽을 수 있는 기록매체의 예로는 ROM, RAM, CD-ROM, 자기 테이프, 플로피디스크, 광 데이터 저장장치 등이 포함된. 또한 컴퓨터가 읽을 수 있는 기록매체는 네트워크로 연결된 컴퓨터 시스템에 분산되어, 분산방식으로 컴퓨터가 읽을 수 있는 코드가 저장되고 실행될 수 있다.The video encoding and decoding method according to the present invention can also be embodied as computer readable codes on a computer readable recording medium. The computer-readable recording medium includes all kinds of recording devices in which data that can be read by a computer system is stored. Examples of computer-readable recording media include ROM, RAM, CD-ROM, magnetic tape, floppy disks, optical data storage devices, and the like. The computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
이제까지 본 발명에 대하여 그 바람직한 실시예들을 중심으로 살펴보았다. 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자는 본 발명의 본질적인 특성에서 벗어나지 않는 범위에서 변형된 형태로 구현될 수 있음을 이해할 수 있을 것이다. 그러므로 개시된 실시예들은 한정적인 관점이 아니라 설명적인 관점에서 고려되어야 한다. 본 발명의 범위는 전술한 설명이 아니라 특허청구범위에 나타나 있으며, 그와 동등한 범위 내에 있는 모든 차이점은 본 발명에 포함된 것으로 해석되어야 할 것이다. So far I looked at the center of the preferred embodiment for the present invention. It will be understood by those skilled in the art that various changes in form and details may be made therein without departing from the spirit and scope of the invention as defined by the appended claims. Therefore, the disclosed embodiments should be considered in an illustrative rather than a restrictive sense. The scope of the present invention is shown in the claims rather than the foregoing description, and all differences within the scope will be construed as being included in the present invention.
도 1은 본 발명의 일 실시예에 따른 영상 부호화 장치의 블록도이다.1 is a block diagram of an image encoding apparatus according to an embodiment of the present invention.
도 2 는 본 발명의 일 실시예에 따른 영상 복호화 장치의 블록도를 도시한다.2 is a block diagram of an image decoding apparatus according to an embodiment of the present invention.
도 3은 본 발명의 일 실시예에 따른 계층적 부호화 단위를 도시한다.3 illustrates a hierarchical coding unit according to an embodiment of the present invention.
도 4 는 본 발명의 일 실시예에 따른 부호화 단위에 기초한 영상 부호화부의 블록도를 나타낸 것이다.4 is a block diagram of an image encoder based on coding units, according to an embodiment of the present invention.
도 5 는 본 발명의 일 실시예에 따른 부호화 단위에 기초한 영상 복호화부의 블록도를 나타낸 것이다.5 is a block diagram of an image decoder based on coding units, according to an embodiment of the present invention.
도 6은 본 발명의 일 실시예에 따른 심도별 부호화 단위 및 예측 단위를 도시한다.6 is a diagram of deeper coding units according to depths, and prediction units, according to an embodiment of the present invention.
도 7은 본 발명의 일 실시예에 따른, 부호화 단위 및 변환 단위의 관계를 도시한다. 7 illustrates a relationship between coding units and transformation units, according to an embodiment of the present invention.
도 8은 본 발명의 일 실시예에 따라, 심도별 부호화 정보들을 도시한다.8 illustrates encoding information according to depths, according to an embodiment of the present invention.
도 9 는 본 발명의 일 실시예에 따른 심도별 부호화 단위를 도시한다. 9 is a diagram of deeper coding units according to depths, according to an embodiment of the present invention.
도 10a 및 10b는 본 발명의 일 실시예에 따른, 부호화 단위, 예측 단위 및 주파수 변환 단위의 관계를 도시한다.10A and 10B illustrate a relationship between a coding unit, a prediction unit, and a frequency transformation unit, according to an embodiment of the present invention.
도 11 은 본 발명의 일 실시예에 따른 부호화 단위별 부호화 정보를 도시한다.11 is a diagram of encoding information according to coding units, according to an embodiment of the present invention.
도 12는 본 발명의 일 실시예에 따른 인트라 예측 장치(1200)의 구성을 나타 낸 블록도이다.12 is a block diagram illustrating a configuration of an intra prediction apparatus 1200 according to an embodiment of the present invention.
도 13은 본 발명의 일 실시예에 따른 부호화 단위의 크기에 따른 인트라 예측 모드들의 개수를 도시한다.13 illustrates the number of intra prediction modes according to the size of a coding unit, according to an embodiment of the present invention.
도 14a 내지 도 14c는 본 발명의 일 실시예에 따른 소정 크기의 부호화 단위에 적용되는 인트라 예측 모드의 일 예를 설명하기 위한 도면이다. 14A to 14C illustrate an example of an intra prediction mode applied to a coding unit having a predetermined size, according to an embodiment of the present invention.
도 15는 본 발명의 일 실시예에 따른 소정 크기의 부호화 단위에 적용되는 인트라 예측 모드의 다른 예를 설명하기 위한 도면이다.FIG. 15 illustrates another example of an intra prediction mode applied to a coding unit of a predetermined size, according to an embodiment of the present invention.
도 16은 본 발명의 일 실시예에 따른 다양한 방향성을 갖는 인트라 예측 모드들을 설명하기 위한 참조도이다.16 is a reference diagram for explaining intra prediction modes having various directions according to an embodiment of the present invention.
도 17은 본 발명의 일 실시예에 따른 쌍선형 모드를 설명하기 위한 참조도이다.17 is a reference diagram for describing a bilinear mode according to an embodiment of the present invention.
도 18은 본 발명의 일 실시예에 따른 제 1 예측 부호화 단위의 후처리 동작을 설명하기 위한 참조도이다.18 is a reference diagram for explaining a post-processing operation of a first prediction coding unit according to an embodiment of the present invention.
도 19는 본 발명의 일 실시예에 따른 후처리부(1220)의 동작을 설명하기 위한 참조도이다.19 is a reference diagram for explaining an operation of the
도 20은 본 발명의 일 실시예에 따른 후처리부(1220)에서 이용되는 주변 픽셀들을 설명하기 위한 참조도이다.20 is a reference diagram for explaining peripheral pixels used in the
도 21은 본 발명의 일 실시예에 따른 영상 부호화 방법을 나타낸 플로우 차트이다.21 is a flowchart illustrating an image encoding method according to an embodiment of the present invention.
도 22는 본 발명의 일 실시예에 따른 영상 복호화 방법을 나타낸 플로우 차 트이다.22 is a flowchart illustrating an image decoding method according to an embodiment of the present invention.
Claims (37)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020090094050A KR101464538B1 (en) | 2009-10-01 | 2009-10-01 | Method and apparatus for encoding video, and method and apparatus for decoding video |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020090094050A KR101464538B1 (en) | 2009-10-01 | 2009-10-01 | Method and apparatus for encoding video, and method and apparatus for decoding video |
Related Child Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR20130048513A Division KR101485463B1 (en) | 2013-04-30 | 2013-04-30 | Method and apparatus for encoding video, and method and apparatus for decoding video |
KR1020140058652A Division KR101606852B1 (en) | 2014-05-15 | 2014-05-15 | Method and apparatus for encoding video, and method and apparatus for decoding video |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20110036401A true KR20110036401A (en) | 2011-04-07 |
KR101464538B1 KR101464538B1 (en) | 2014-11-25 |
Family
ID=44044355
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020090094050A KR101464538B1 (en) | 2009-10-01 | 2009-10-01 | Method and apparatus for encoding video, and method and apparatus for decoding video |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR101464538B1 (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013002586A3 (en) * | 2011-06-28 | 2013-03-14 | 삼성전자 주식회사 | Method and apparatus for image encoding and decoding using intra prediction |
WO2014168642A1 (en) * | 2013-04-12 | 2014-10-16 | Intel Corportation | Simplified depth coding with modified intra-coding for 3d video coding |
US9307246B2 (en) | 2010-07-31 | 2016-04-05 | M & K Holdings Inc. | Apparatus for decoding moving picture |
US9497485B2 (en) | 2013-04-12 | 2016-11-15 | Intel Corporation | Coding unit size dependent simplified depth coding for 3D video coding |
US9571809B2 (en) | 2013-04-12 | 2017-02-14 | Intel Corporation | Simplified depth coding with modified intra-coding for 3D video coding |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TW366669B (en) * | 1996-10-30 | 1999-08-11 | Matsushita Electric Ind Co Ltd | Picture encoding device and picture encoding method, picture decoding device and picture decoding method, and data recording media |
-
2009
- 2009-10-01 KR KR1020090094050A patent/KR101464538B1/en active IP Right Grant
Cited By (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9307246B2 (en) | 2010-07-31 | 2016-04-05 | M & K Holdings Inc. | Apparatus for decoding moving picture |
US9609325B2 (en) | 2010-07-31 | 2017-03-28 | M & K Holdings Inc. | Apparatus for decoding an image |
US9491468B2 (en) | 2010-07-31 | 2016-11-08 | M&K Holdings Inc. | Apparatus for encoding an image |
US9451263B2 (en) | 2010-07-31 | 2016-09-20 | M & K Holdings Inc. | Intra prediction apparatus |
US9451264B2 (en) | 2010-07-31 | 2016-09-20 | M & K Holdings Inc. | Apparatus for encoding an image |
CN103765901B (en) * | 2011-06-28 | 2018-03-30 | 三星电子株式会社 | Method and apparatus for carrying out image coding and decoding using infra-frame prediction |
US10045043B2 (en) | 2011-06-28 | 2018-08-07 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
CN104918055A (en) * | 2011-06-28 | 2015-09-16 | 三星电子株式会社 | Method and an apparatus for image encoding and decoding using intra prediction |
KR20150059144A (en) * | 2011-06-28 | 2015-05-29 | 삼성전자주식회사 | Method and apparatus for video intra prediction encoding, and method and apparatus for video intra prediction decoding |
KR20150059145A (en) * | 2011-06-28 | 2015-05-29 | 삼성전자주식회사 | Method and apparatus for video intra prediction encoding, and method and apparatus for video intra prediction decoding |
US10506250B2 (en) | 2011-06-28 | 2019-12-10 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
CN104918055B (en) * | 2011-06-28 | 2019-07-26 | 三星电子株式会社 | Method and apparatus for using intra prediction to carry out image coding and decoding |
US10085037B2 (en) | 2011-06-28 | 2018-09-25 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
US9788006B2 (en) | 2011-06-28 | 2017-10-10 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
US9813727B2 (en) | 2011-06-28 | 2017-11-07 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
WO2013002586A3 (en) * | 2011-06-28 | 2013-03-14 | 삼성전자 주식회사 | Method and apparatus for image encoding and decoding using intra prediction |
CN105100808B (en) * | 2011-06-28 | 2018-06-15 | 三星电子株式会社 | For the method and apparatus that intra prediction is used to carry out image coding and decoding |
US10045042B2 (en) | 2011-06-28 | 2018-08-07 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
CN105100808A (en) * | 2011-06-28 | 2015-11-25 | 三星电子株式会社 | Method and apparatus for image encoding and decoding using intra prediction |
US10075730B2 (en) | 2011-06-28 | 2018-09-11 | Samsung Electronics Co., Ltd. | Method and apparatus for image encoding and decoding using intra prediction |
WO2014168642A1 (en) * | 2013-04-12 | 2014-10-16 | Intel Corportation | Simplified depth coding with modified intra-coding for 3d video coding |
US9571809B2 (en) | 2013-04-12 | 2017-02-14 | Intel Corporation | Simplified depth coding with modified intra-coding for 3D video coding |
US9497485B2 (en) | 2013-04-12 | 2016-11-15 | Intel Corporation | Coding unit size dependent simplified depth coding for 3D video coding |
Also Published As
Publication number | Publication date |
---|---|
KR101464538B1 (en) | 2014-11-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR101700358B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
JP5314136B2 (en) | Video encoding method and apparatus, and decoding method and apparatus thereof | |
KR20110018189A (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR101464538B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR101677277B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR101699529B1 (en) | Method and apparatus for decoding video | |
KR101649276B1 (en) | Method and apparatus for decoding video | |
KR101703332B1 (en) | Method and apparatus for decoding video | |
KR101989997B1 (en) | Method for decoding video, and computer readable medium | |
KR101766418B1 (en) | Method and apparatus for decoding video | |
KR101940255B1 (en) | Method and apparatus for encoding video, and computer readable medium | |
KR101824056B1 (en) | Method and apparatus for decoding video | |
KR101606856B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR20150092063A (en) | Method and apparatus for decoding video | |
KR101606855B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR101700369B1 (en) | Method and apparatus for decoding video | |
KR101606852B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR101683177B1 (en) | Method and apparatus for decoding video | |
KR101485463B1 (en) | Method and apparatus for encoding video, and method and apparatus for decoding video | |
KR20170093096A (en) | Method for decoding video, and computer readable medium |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A107 | Divisional application of patent | ||
A201 | Request for examination | ||
A302 | Request for accelerated examination | ||
E902 | Notification of reason for refusal | ||
A107 | Divisional application of patent | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20171030 Year of fee payment: 4 |
|
FPAY | Annual fee payment |
Payment date: 20181030 Year of fee payment: 5 |