KR102607327B1 - Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 - Google Patents
Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 Download PDFInfo
- Publication number
- KR102607327B1 KR102607327B1 KR1020227045016A KR20227045016A KR102607327B1 KR 102607327 B1 KR102607327 B1 KR 102607327B1 KR 1020227045016 A KR1020227045016 A KR 1020227045016A KR 20227045016 A KR20227045016 A KR 20227045016A KR 102607327 B1 KR102607327 B1 KR 102607327B1
- Authority
- KR
- South Korea
- Prior art keywords
- vertex
- encoding
- value
- decoding
- color
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 85
- 230000009466 transformation Effects 0.000 claims description 12
- 230000015654 memory Effects 0.000 claims description 11
- 230000011218 segmentation Effects 0.000 claims description 5
- 230000004044 response Effects 0.000 claims 6
- 230000005540 biological transmission Effects 0.000 claims 3
- 238000013507 mapping Methods 0.000 description 14
- 230000006870 function Effects 0.000 description 12
- 230000008569 process Effects 0.000 description 8
- 238000010586 diagram Methods 0.000 description 5
- 230000003044 adaptive effect Effects 0.000 description 4
- 239000011159 matrix material Substances 0.000 description 4
- 238000009877 rendering Methods 0.000 description 4
- 241000023320 Luma <angiosperm> Species 0.000 description 3
- 239000003086 colorant Substances 0.000 description 3
- 238000004891 communication Methods 0.000 description 3
- OSWPMRLSEDHDFF-UHFFFAOYSA-N methyl salicylate Chemical compound COC(=O)C1=CC=CC=C1O OSWPMRLSEDHDFF-UHFFFAOYSA-N 0.000 description 3
- 238000006243 chemical reaction Methods 0.000 description 2
- 230000002688 persistence Effects 0.000 description 2
- 229920001690 polydopamine Polymers 0.000 description 2
- 238000013139 quantization Methods 0.000 description 2
- 230000007704 transition Effects 0.000 description 2
- 230000006978 adaptation Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 238000011968 cross flow microfiltration Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000005192 partition Methods 0.000 description 1
- 238000007781 pre-processing Methods 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000011664 signaling Effects 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
- 238000000844 transformation Methods 0.000 description 1
- 239000013598 vector Substances 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/46—Colour picture communication systems
- H04N1/56—Processing of colour picture signals
- H04N1/60—Colour correction or control
- H04N1/6016—Conversion to subtractive colour signals
- H04N1/6019—Conversion to subtractive colour signals using look-up tables
-
- 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/597—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding specially adapted for multi-view video sequence encoding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/30—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using hierarchical techniques, e.g. scalability
-
- 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/13—Adaptive entropy coding, e.g. adaptive variable length coding [AVLC] or context adaptive binary arithmetic coding [CABAC]
-
- 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/184—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 bits, e.g. of the compressed video stream
-
- 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/186—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 colour or a chrominance component
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/44—Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/46—Embedding additional information in the video signal during the compression process
- H04N19/463—Embedding additional information in the video signal during the compression process by compressing encoding parameters before transmission
-
- 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/70—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/96—Tree coding, e.g. quad-tree coding
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
- Image Processing (AREA)
- Compression Of Band Width Or Redundancy In Fax (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
- Color Image Communication Systems (AREA)
- Image Analysis (AREA)
- Facsimile Image Signal Circuits (AREA)
- Color Television Systems (AREA)
Abstract
정점들의 격자로서 정의되는 LUT를 인코딩하기 위한 방법이 개시된다. 적어도 하나의 값이 격자의 각각의 정점에 속한다. 이 방법은 현재 정점에 대해: 상기 현재 정점의 적어도 하나의 값을, 예를 들어 이웃 정점들의 재구성 값들로부터 획득되는 다른 값으로부터 예측하는 단계; 및 현재 정점의 적어도 하나의 값과 비트스트림 내의 그의 예측 사이에서 계산된 적어도 하나의 오차를 비트스트림 내에 인코딩하는 단계를 포함한다.
Description
정점들의 격자로서 정의되는 탐색표를 인코딩하기 위한 방법이 개시되며, 적어도 하나의 값이 격자의 각각의 정점과 관련된다. 예를 들어, 값은 컬러 값이다. 대응하는 디코딩 방법, 인코딩 장치 및 디코딩 장치가 개시된다.
도 1에 도시된 바와 같이, 스케일링 가능 비디오 디코딩은 기본 계층(BL) 비트스트림 및 적어도 하나의 향상 계층(EL) 비트스트림의 디코딩(각각의 인코딩)으로 구성된다. 통상적으로, EL 픽처들은 (아마도 업샘플링된) 디코딩된 BL 픽처들로부터 예측된다. 그러나, EL 픽처들 및 BL 픽처들이 상이한 컬러 공간들을 이용하여 표현되고/되거나, 상이하게 컬러 등급화된 때, 예측은 덜 효율적이다. 예측을 개선하기 위해, 디코딩된 BL 픽처들에 대해 컬러 변환을 적용하는 것이 알려져 있다. 더 정확하게는, 컬러 변환은 컬러 정보를 이용하여 BL 컬러 공간(제1 컬러 공간)의 컬러들을 EL 컬러 공간(제2 컬러 공간)의 컬러들 상에 맵핑한다.
도 2에 도시된 바와 같이, 비디오 콘텐츠 배포에서, 디코딩된 픽처들에 대해 통상적으로 컬러 변환이 적용되며, 따라서 디코딩 및 변환된 픽처들은 최종 장치 렌더링 능력에 적합해진다.
이러한 컬러 변환은 컬러 맵핑 기능(CMF)으로도 알려져 있다. CMF는 예를 들어 3x3 이득 행렬 + 오프셋(이득 오프셋 모델)에 의해 근사화된다. 이 경우, CMF는 12개의 파라미터에 의해 정의된다. 그러나, CMF의 그러한 근사화는 선형 변환 모델을 가정하므로 매우 정확하지는 않다. 결과적으로, (3D LUT로도 알려진) 3D 탐색표가 CMF 모델에 대한 어떠한 선천성도 없이 그러한 CMF를 설명하는 데 사용된다. 3D LUT는 그의 크기가 필요한 정밀도에 따라 증가될 수 있으므로 훨씬 더 정밀하다. 그러나, 3D LUT는 그에 따라 거대한 데이터 세트를 표현할 수 있다. 따라서, 3D LUT를 수신기로 전송하는 것은 LUT의 인코딩을 필요로 한다.
CMF를 근사화하는 LUT는 제1 컬러 공간 내의 적어도 하나의 컬러 값을 제2 컬러 공간 내의 다른 컬러 값과 관련시킨다. LUT는 제1 컬러 공간을 LUT의 정점들에 의해 정해지는 영역들의 세트로 분할하는 것을 가능하게 한다. 예를 들어, 3D LUT는 제1 컬러 공간 내의 컬러 값들의 삼중쌍(triplet)을 컬러 값들의 세트와 관련시킨다. 컬러 값들의 세트는 제2 컬러 공간 내의 컬러 값들의 삼중쌍, 또는 제1 컬러 공간 내의 컬러 값들을 제2 컬러 공간 내의 컬러 값들로 변환하는 데 사용되는 컬러 변환을 나타내는 컬러 값들의 세트(예로서, 논리적으로 정의된 CMF 파라미터들)일 수 있다. 도 3에서, 정사각형 3D LUT는 NxNxN 정점들의 격자로서 표현된다. 3D LUT의 각각의 정점 V(c1,c2,c3)에 대해, 컬러 값들(Vc1, Vc2, Vc3)의 대응하는 삼중쌍이 저장될 필요가 있다. 3D LUT와 관련된 데이터의 양은 NxNxNxK이며, 여기서 K는 하나의 LUT 삼중쌍 값을 저장하는 데 사용되는 비트들의 양이다. 삼중쌍 값은 예를 들어 (R, G, B) 삼중쌍, (Y, U, V) 삼중쌍 또는 (Y, Cb, Cr) 삼중쌍 등이다. 모든 정점 값들을 인코딩하는 것은 거대한 양의 데이터를 표현하므로 효율적이지 못하다.
발명의 요약
본 발명의 목적은 종래 기술의 단점들 중 적어도 하나를 극복하는 것이다. 정점들의 격자로서 정의되는 LUT를 인코딩하기 위한 방법이 개시된다. 적어도 하나의 값이 상기 격자의 각각의 정점과 관련된다. 인코딩 방법은 현재 정점에 대해:
- 상기 현재 정점과 관련된 상기 적어도 하나의 값을 다른 값으로부터 예측하는 단계; 및
- 상기 현재 정점의 상기 적어도 하나의 값과 비트스트림 내의 그의 예측 사이에서 계산된 적어도 하나의 오차를 비트스트림 내에 인코딩하는 단계
를 포함한다.
유리하게는, 상기 다른 값은 이웃 정점들과 관련된 재구성 값들로부터 획득된다.
본 발명의 특정 특징에 따르면, 상기 값은 컬러 값이다. 특정 실시예에 따르면, 상기 컬러 값은 컬러 변환을 나타낸다. 본 발명의 특정 특징에 따르면, 상기 컬러 값은 이득 파라미터 또는 오프셋이다.
특정 실시예에 따르면, 상기 LUT는 옥트리(octree)를 이용하여 인코딩된 3D LUT이며, 3개의 값이 상기 격자의 각각의 정점과 관련된다. 이 경우, 예측에 사용되는 상기 이웃 정점들은 상기 현재 정점이 속하는 현재 옥턴트(octant)의 부모 옥턴트에 속한다.
본 발명의 특정 특징에 따르면, 상기 현재 정점과 관련된 상기 적어도 하나의 값을 이웃 정점들과 관련된 재구성 값들로부터 예측하는 단계는 상기 이웃 정점들의 대응하는 재구성 값들로부터 상기 적어도 하나의 값을 보간하는 단계를 포함한다.
특정 특징에 따르면, 상기 방법은 보간의 타입을 지시하는 인덱스를 상기 비트스트림 내에 인코딩하는 단계를 더 포함한다.
특정 실시예에 따르면, 적어도 하나의 오차를 인코딩하는 단계는 양자화기를 이용하여 상기 적어도 하나의 오차를 양자화된 오차로 양자화하고, 상기 양자화된 오차를 상기 비트스트림 내에 엔트로피 코딩하는 단계를 포함하고, 상기 방법은 상기 양자화기를 상기 비트스트림 내에 인코딩하는 단계를 더 포함한다.
본 발명의 특정 특징에 따르면, 플래그가 상기 현재 정점에 대해 인코딩되며, 상기 플래그는 적어도 하나의 오차가 상기 정점에 대해 인코딩되는지의 여부를 지시한다.
일 변형에 따르면, 플래그가 상기 현재 정점의 각각의 값에 대해 인코딩되며, 상기 플래그는 오차가 해당 값에 대해 인코딩되는지 또는 상기 오차가 인코딩되지 않고 0인 것으로 추정되는지를 지시한다.
유리하게는, 분할 플래그가 상기 현재 옥턴트에 대해 인코딩되며, 상기 분할 플래그는 그의 직접 자식들(immediate children)이 재귀적으로 인코딩되는지 또는 아직 인코딩되지 않은 모든 그의 자식들의 상기 정점들의 모든 상기 오차들이 0인 것으로 추정되는지를 지시한다.
정점들의 격자로서 정의되는 LUT를 디코딩하기 위한 방법도 개시된다. 적어도 하나의 값이 상기 격자의 각각의 정점과 관련된다. 상기 디코딩 방법은 현재 정점에 대해:
- 비트스트림으로부터 적어도 하나의 오차를 디코딩하는 단계;
- 상기 현재 정점과 관련된 상기 적어도 하나의 값을 다른 값으로부터 예측하는 단계; 및
- 상기 현재 정점의 상기 적어도 하나의 값을 그의 예측 및 상기 디코딩된 적어도 하나의 오차로부터 재구성하는 단계
를 포함한다.
유리하게는, 상기 다른 값은 이웃 정점들과 관련된 재구성 값들로부터 획득된다.
본 발명의 특정 특징에 따르면, 상기 값은 컬러 값이다. 특정 실시예에 따르면, 상기 컬러 값은 컬러 변환을 나타낸다. 본 발명의 특정 특징에 따르면, 상기 컬러 값은 이득 파라미터 또는 오프셋이다.
특정 실시예에 따르면, 상기 LUT는 옥트리를 이용하여 디코딩된 3D LUT이며, 3개의 값이 상기 격자의 각각의 정점과 관련되고, 상기 이웃 정점들은 상기 현재 정점이 속하는 현재 옥턴트의 부모 옥턴트에 속한다.
본 발명의 특정 특징에 따르면, 상기 현재 정점과 관련된 상기 적어도 하나의 값을 이웃 정점들과 관련된 재구성 값들로부터 예측하는 단계는 상기 이웃 정점들의 대응하는 재구성 값들로부터 상기 적어도 하나의 값을 보간하는 단계를 포함한다.
특정 특징에 따르면, 상기 방법은 보간의 타입을 지시하는 인덱스를 상기 비트스트림으로부터 디코딩하는 단계를 더 포함한다.
특정 실시예에 따르면, 적어도 하나의 오차를 디코딩하는 단계는 양자화된 오차를 상기 비트스트림으로부터 엔트로피 디코딩하고, 양자화기를 이용하여 상기 양자화된 오차를 디코딩된 오차로 역양자화하는 단계를 포함하고, 상기 방법은 상기 비트스트림으로부터 상기 양자화기를 디코딩하는 단계를 더 포함한다.
본 발명의 특정 특징에 따르면, 플래그가 상기 각각의 정점에 대해 디코딩되며, 상기 플래그는 적어도 하나의 오차가 상기 정점에 대해 인코딩되는지의 여부를 지시한다.
일 변형에 따르면, 플래그가 상기 현재 정점의 각각의 값에 대해 디코딩되며, 상기 플래그는 오차가 해당 값에 대해 디코딩되는지 또는 상기 오차가 0인 것으로 추정되는지를 지시한다.
유리하게는, 분할 플래그가 상기 현재 옥턴트에 대해 디코딩되며, 상기 분할 플래그는 그의 직접 자식들이 재귀적으로 디코딩되는지 또는 아직 디코딩되지 않은 모든 그의 자식들의 상기 정점들의 모든 상기 오차들이 0인 것으로 추정되는지를 지시한다.
정점들의 격자로서 정의되는 LUT를 인코딩하기 위한 인코더로서, 적어도 하나의 값이 상기 격자의 각각의 정점과 관련되며, 현재 정점에 대해:
- 현재 정점과 관련된 상기 적어도 하나의 값을 다른 값으로부터 예측하기 위한 수단; 및
- 상기 현재 정점의 상기 적어도 하나의 값과 비트스트림 내의 그의 예측 사이에서 계산된 적어도 하나의 오차를 비트스트림 내에 인코딩하기 위한 수단
을 포함하는 인코더.
유리하게는, 상기 다른 값은 이웃 정점들과 관련된 재구성 값들로부터 획득된다.
상기 인코더는 인코딩을 위한 상기 방법의 상기 단계들을 실행하도록 구성된다.
정점들의 격자로서 정의되는 LUT를 디코딩하기 위한 디코더로서, 적어도 하나의 값이 상기 격자의 각각의 정점과 관련되며,
- 비트스트림으로부터 현재 정점과 관련된 적어도 하나의 오차를 디코딩하기 위한 수단;
- 상기 현재 정점과 관련된 상기 적어도 하나의 값을 다른 값으로부터 예측하기 위한 수단; 및
- 상기 현재 정점의 상기 적어도 하나의 값을 그의 예측 및 상기 디코딩된 적어도 하나의 오차로부터 재구성하기 위한 수단
을 포함하는 디코더.
유리하게는, 상기 다른 값은 이웃 정점들과 관련된 재구성 값들로부터 획득된다.
상기 인코더는 디코딩을 위한 상기 방법의 상기 단계들을 실행하도록 구성된다.
정점들의 격자로서 정의되는 적어도 LUT를 인코딩하는 비트스트림이 개시된다. 적어도 하나의 값이 상기 격자의 각각의 정점과 관련되며, 상기 비트스트림은 현재 정점의 상기 적어도 하나의 값과 그의 예측 사이에서 계산되는 적어도 하나의 오차를 그 안에 인코딩하는 것을 포함한다.
본 발명의 다른 특징들 및 장점들은 그의 실시예들 중 일부에 대한 아래의 설명으로부터 명백해질 것이며, 이 설명은 도면들과 관련하여 이루어진다. 도면들에서:
도 1은 종래 기술에 따른, 범위 스케일링 가능성을 이용하는 스케일링 가능 비디오 디코더의 아키텍처를 나타낸다.
도 2는 종래 기술에 따른, 렌더링 표시 특성들에 적응하기 위한 컬러 변환을 포함하는 비디오 디코더의 아키텍처를 나타낸다.
도 3은 종래 기술에 따른, NxNxN 정점들의 격자로서 표현되는 직사각형 3D LUT를 개략적으로 나타낸다.
도 4는 본 발명의 일 실시예에 따른 인코딩 방법의 흐름도를 나타낸다.
도 5는 2D LUT를 개략적으로 나타낸다.
도 6은 본 발명의 다른 실시예에 따른 인코딩 방법의 흐름도를 나타낸다.
도 7은 좌측에 큐브의 옥턴트들로의 재귀적 세분을, 우측에 대응하는 옥트리를 나타낸다.
도 8은 본 발명에 따른, 정점의 컬러 값들의 보간을 나타낸다.
도 9는 불균일한 격자로서 표현되는 3D LUT를 개략적으로 나타낸다.
도 10은 본 발명의 일 실시예에 따른 디코딩 방법의 흐름도를 나타낸다.
도 11은 본 발명의 다른 실시예에 따른 디코딩 방법의 흐름도를 나타낸다.
도 12는 본 발명에 따른, LUT를 인코딩하기 위한 인코더를 개략적으로 나타낸다.
도 13은 본 발명에 따른, LUT를 디코딩하기 위한 디코더를 개략적으로 나타낸다.
도 14는 옥턴트의 8개의 정점의 위치를 나타낸다.
도 1은 종래 기술에 따른, 범위 스케일링 가능성을 이용하는 스케일링 가능 비디오 디코더의 아키텍처를 나타낸다.
도 2는 종래 기술에 따른, 렌더링 표시 특성들에 적응하기 위한 컬러 변환을 포함하는 비디오 디코더의 아키텍처를 나타낸다.
도 3은 종래 기술에 따른, NxNxN 정점들의 격자로서 표현되는 직사각형 3D LUT를 개략적으로 나타낸다.
도 4는 본 발명의 일 실시예에 따른 인코딩 방법의 흐름도를 나타낸다.
도 5는 2D LUT를 개략적으로 나타낸다.
도 6은 본 발명의 다른 실시예에 따른 인코딩 방법의 흐름도를 나타낸다.
도 7은 좌측에 큐브의 옥턴트들로의 재귀적 세분을, 우측에 대응하는 옥트리를 나타낸다.
도 8은 본 발명에 따른, 정점의 컬러 값들의 보간을 나타낸다.
도 9는 불균일한 격자로서 표현되는 3D LUT를 개략적으로 나타낸다.
도 10은 본 발명의 일 실시예에 따른 디코딩 방법의 흐름도를 나타낸다.
도 11은 본 발명의 다른 실시예에 따른 디코딩 방법의 흐름도를 나타낸다.
도 12는 본 발명에 따른, LUT를 인코딩하기 위한 인코더를 개략적으로 나타낸다.
도 13은 본 발명에 따른, LUT를 디코딩하기 위한 디코더를 개략적으로 나타낸다.
도 14는 옥턴트의 8개의 정점의 위치를 나타낸다.
도 4는 본 발명의 일 실시예에 따른 인코딩 방법의 흐름도를 나타낸다. 방법은 정점들의 격자로서 정의되는 LUT를 인코딩하기 위한 것이며, 여기서는 적어도 하나의 값, 예로서 컬러 값이 격자의 각각의 정점과 관련된다. 디코딩과 관련하여, 용어 "재구성" 및 "디코딩"은 매우 자주 동의어로서 사용된다. 아래에서, 용어 컬러 값은 RGB, YUV 또는 Y, Cb, Cr 값들과 같은 주어진 컬러 공간의 컬러 값들을 포함하며, CMF 파라미터들, 즉 행렬 파라미터들 및 오프셋 값들과 같은 컬러 변환을 나타내는 값들을 더 포함한다.
단계 40에서, 현재 정점의 적어도 하나의 컬러 값이 이웃 정점들과 관련된 재구성 컬러 값들로부터 예측된다.
일례로서, 정점 V0(c10,c20)을 값들 (V0c1, V0c2), 예로서 컬러 값들의 대응하는 쌍과 관련시키는 2D LUT가 도 5에 도시된다. 정점 V0과 관련된 값들은 예를 들어 값들 (Vic1, Vic2)i=1,..4의 대응하는 쌍을 갖는 공간적으로 이웃하는 정점들 V1(c11,c21), V2(c12,c22), V3(c13,c23) 및 V4(c14,c24)로부터 예측된다. 예측 P(Pc1, Pc2)는 다음과 같이 보간을 이용하여 계산된다.
Pc1= 0.25*(V1c1+ V2c1+ V3c1+V4c1)
Pc2=0.25*(V1c2+ V2c2+ V3c2+V4c2)
일 변형에 따르면, 2D LUT는 정점 V0(c10,c20)을 값들 (V0c1, V0c2)의 쌍 대신에 파라미터들 (m11, m12, m21, m22, o1, o2)의 세트와 관련시킨다. 이러한 파라미터들의 세트는 다음과 같이 V0의 값들 (c10,c20)으로부터 값들 (V0c1, V0c2)를 재구성하는 데 사용될 수 있다.
V0c1=m11* c10+m12* c20 +o1
V0c2=m21* c10+m22* c20 +o2
정점 V0과 관련된 파라미터들은 예를 들어 파라미터 (Vic1, Vic2)i=1,..4의 대응하는 쌍을 갖는 공간적으로 이웃하는 정점들 V1(c11,c21), V2(c12,c22), V3(c13,c23) 및 V4(c14,c24)로부터 예측된다. 예측 P(Pc1, Pc2)는 예를 들어 아래와 같이 보간을 이용하여 계산된다.
Pc1= 0.25*(V1c1+ V2c1+ V3c1+V4c1)
Pc2=0.25*(V1c2+ V2c2+ V3c2+V4c2)
단계 42에서, 적어도 하나의 오차가 현재 정점의 적어도 하나의 컬러 값과 그의 예측 사이에서 결정되며, 또한 비트스트림(F) 내에 인코딩된다. 오차는 현재 정점의 적어도 하나의 컬러 값으로부터 그의 예측을 뺌으로써 결정된다. 인코딩은 통상적으로 엔트로피 인코딩을 포함한다. 일 변형에 따르면, 인코딩은 양자화기(q)를 이용하여 오차를 양자화하고, 양자화된 오차를 엔트로피 인코딩하는 것을 포함한다.
일례로서, 2D LUT의 경우, 제1 및 제2 오차들이 정점 V0에 대해 계산된다. 제1 오차는 (V0c1 - Pc1) 과 동일하며, 제2 오차는 (V0c2 - Pc2)와 동일하다. 이어서, 오차들 또는 양자화된 오차들 (V0c1 - Pc1)/q 및 (V0c2 - Pc2)/q는 비트스트림(F) 내에 엔트로피 코딩된다. 엔트로피 코딩은 지수-Golomb, Huffman, CABAC("Context Adaptive Binary Arithmetic Coding"의 영문 두문자어)와 같은 전통적인 이진 코딩 기술들을 이용한다.
단계 40 및 42는 LUT의 모든 정점들이 인코딩될 때까지 LUT의 더 많은 정점을 인코딩하도록 반복된다.
옵션으로서, 인코딩 방법은 양자화기 값(q)을 비트스트림(F) 내에 인코딩하는 단계를 포함한다. 현재 정점의 적어도 하나의 컬러 값이 다른 정점들의 예측에 사용되도록 더 재구성된다. 각각의 재구성된 적어도 하나의 컬러 값은 양자화기가 사용되지 않는 경우에, 즉 q=1인 경우에 대응하는 오리지널 컬러 값과 동일하다. 그렇지 않은 경우, 적어도 하나의 재구성 컬러 값은 오차를 역양자화하고, 역양자화된 오차를 예측에 더함으로써 결정된다.
일 변형에 따르면, 인코딩 방법은 정점의 적어도 하나의 컬러 값을 예측하는 데 사용되는 보간 타입을 비트스트림(F) 내에 인코딩하는 단계를 더 포함한다. 더 정확하게는, 보간 타입을 식별하는 비트스트림으로부터 인덱스가 디코딩된다. 일례로서, 인덱스 0은 이선형 보간을 식별하고, 인덱스 1은 최근접 이웃 보간을 식별하고, 인덱스 2는 2개의 최근접 이웃을 이용하는 선형 보간을 식별한다.
일 변형에 따르면, LUT의 모든 정점들이 비트스트림(F) 내에 인코딩되지는 않는다. 예를 들어, 정점의 모든 오차들 또는 모든 양자화된 오차들의 절대값이 임계치(TH) 아래인 경우에는 어떠한 오차도 그 정점에 대해 인코딩되지 않으며, 예로서 TH=0 또는 TH=1이다. 따라서 이진 플래그가 각각의 정점에 대해 비트스트림 내에 인코딩되며, 이러한 이진 플래그는 적어도 하나의 오차가 그 정점에 대해 인코딩되는지 또는 오차들 중 어느 것도 인코딩되지 않고, 따라서 0인 것으로 추정되는지를 지시한다.
일 변형에 따르면, 이진 플래그가 각각의 정점의 각각의 컬러 값에 대해 인코딩되며, 이러한 이진 플래그는 오차가 그 컬러 값에 대해 인코딩되는지 또는 오차가 인코딩되지 않고 0인 것으로 추정되는지를 지시한다.
LUT의 크기도 옵션으로서 비트스트림 내에 인코딩된다.
도 6은 본 발명의 다른 실시예에 따른 인코딩 방법의 흐름도를 나타낸다. 이 방법은 옥트리를 이용하여 정점들의 격자로서 정의된 3D LUT를 인코딩하기 위한 것이며, 여기서는 컬러 값들의 삼중쌍과 같은 n개의 컬러 값들의 세트가 격자의 각각의 정점과 관련되고, 여기서 n은 정수≥1이다. 옥트리는 도 7에 도시된 바와 같이 3D 컬러 공간을 8개의 옥턴트로 재귀적으로 세분함으로써 그를 분할하기 위한 것이다. 레벨 N의 옥턴트는 레벨 N-1에서 그의 부모 옥턴트를 갖는다. 옥트리들은 쿼드트리들의 3D 유사물이다. 이 인코딩 방법은 현재 옥턴트에 속하는 격자의 현재 정점 V의 인코딩을 위해 개시된다. 아래에서 n=3이다.
단계 50에서, 좌표들 (r, g, b)의 현재 정점 V와 관련된 3개의 컬러 값 (Vr, Vg, Vb) 각각은 이웃 정점들, 즉 현재 정점의 부모 옥턴트에 속하는 정점들과 관련된 재구성 컬러 값들로부터 예측된다. 표기법을 간소화하기 위해 (c1, c2, c3) 대신에 (r, g, b)가 사용된다. 그러나, 본 발명은 (R, G, B) 컬러 공간으로 한정되지 않는다. 본 발명은 (Y,U,V), (Y,Cb,Cr) 등의 컬러 공간 표현들에 적용될 수 있다.
따라서, 예를 들어 도 8에 도시된 바와 같은 삼선형 보간을 이용하여 각각의 컬러 값에 대해 예측이 결정된다.
여기서, i=0, 1, j=0, 1 및 k=0, 1을 갖는 (ri, gj, bk)는 3D 컬러 공간 내의 부모 옥턴트의 정점들의 좌표들이고, (r, g, b)는 현재 정점의 좌표들이고, 은 정점 (ri, gj, bk)와 관련된 제1 컬러 값이고,
s0(t) = t1-t 및 s1(t) = t-t0이고, t= r, g 또는 b이다.
동일한 식들이 g 및 b에 대해 사용된다. 프리즘, 피라미드 또는 사면체와 같은 다른 타입의 보간이 사용될 수 있다.
격자는 도 9에 도시된 바와 같이 반드시 균일하지는 않다.
단계 52에서, 현재 정점에 대해, 각각의 컬러 컴포넌트에 대해 하나씩 3개의 오차: resr=(Vr-), resg=(Vg-) 및 resb=(Vb-)가 계산된다.
이어서, 오차들은 비트스트림 내에 엔트로피 코딩되거나, 엔트로피 코딩되기 전에 양자화된다. 엔트로피 코딩은 지수-Golomb, Huffman, CABAC("Context Adaptive Binary Arithmetic Coding"의 영문 두문자어)와 같은 전통적인 이진 코딩 기술들을 이용한다.
레벨 0의 옥턴트는 부모 옥턴트를 갖지 않는다. 같은 방식으로, 코딩 옥턴트 리스트 내의 제1 옥턴트는 선행 옥턴트를 갖지 않는다. 결과적으로, 이러한 옥턴트의 현재 정점 V와 관련된 3개의 컬러 값 (Vr, Vg, Vb)는 알려진 컬러 값, 예로서 값 128로부터 예측된다. 일 변형에 따르면, 상이한 알려진 값들이 레벨 0의 옥턴트의 상이한 정점들에 대해 사용된다. 다른 변형에 따르면, 알려진 컬러 값들로부터의 예측은 레벨 0의 옥턴트가 아닌 다른 옥턴트들에 대해서도 행해진다. 일 변형에 따르면, 이러한 옥턴트의 현재 정점 V와 관련된 3개의 컬러 값 (Vr, Vg, Vb) 각각은 동일 옥턴트에 속하는 이웃 정점들과 관련된 이미 재구성된 컬러 값들로부터 예측된다.
옵션으로서, 인코딩 방법은 양자화기 값(q)을 비트스트림 내에 인코딩하는 단계를 포함한다. 현재 정점의 3개의 컬러 값이 더 재구성되고, 다른 정점들의 예측에 사용될 수 있다. 각각의 재구성 컬러 값은 양자화기가 사용되지 않는 경우에(q=1) 오리지널 컬러 값과 동일하다. 그렇지 않은 경우, 각각의 재구성 컬러 값은 대응하는 오차를 역양자화하고, 역양자화된 오차를 대응하는 예측에 더함으로써 결정된다.
일 변형에 따르면, 인코딩 방법은 정점의 적어도 하나의 컬러 값을 예측하는 데 사용되는 보간 타입을 비트스트림 내에 인코딩하는 단계를 더 포함한다. 더 정확하게는, 보간 타입을 식별하는 인덱스가 비트스트림 내에 인코딩된다. 일례로서, 인덱스 0은 삼선형 보간을 식별하고, 인덱스 1은 프리즘 보간을 식별하고, 인덱스 2는 피라미드 보간을 식별하고, 인덱스 3은 사면체 보간을 식별한다.
일 변형에 따르면, LUT의 모든 정점들이 비트스트림 내에 인코딩되지는 않는다. 예를 들어, 정점의 모든 오차들 또는 모든 양자화된 오차들의 절대값이 임계치(TH) 아래인 경우에는 어떠한 오차도 그 정점에 대해 인코딩되지 않으며, 예로서 TH=0 또는 TH=1이다. 따라서 이진 플래그가 각각의 정점에 대해 비트스트림 내에 인코딩되며, 이러한 이진 플래그는 적어도 하나의 오차가 그 정점에 대해 인코딩되는지의 여부를 지시한다. 일 변형에 따르면, 이진 플래그가 각각의 정점의 각각의 컬러 값에 대해 인코딩되며, 이러한 이진 플래그는 오차가 그 컬러 값에 대해 인코딩되는지 또는 오차가 인코딩되지 않고, 0인 것으로 추정되는지를 지시한다.
LUT는 통상적으로 렌더링 표시 컬러 적응 또는 컬러 범위 스케일링 가능성과 같은 응용들에서 비디오의 픽처들을 변환하는 데 사용되도록 비트스트림 내에 인코딩된다. LUT는 인코딩되고, 비디오와 함께 전송될 수 있다. 인코딩 방법이 3D LUT의 일부 부분들이 응용에 의해 사용되지 않을 것이라는 것을 아는 경우, 3D LUT의 이러한 부분에 속하는 정점들은 인코딩되지 않는다. 같은 방식으로, 인코딩 방법이 3D LUT의 일부 부분들이 비디오의 최종 렌더링에 작은 영향을 준다는 것을 아는 경우, 3D LUT의 이러한 부분에 속하는 정점들은 인코딩되지 않는다.
방법은 전체 3D LUT를 인코딩하기 위해 재귀적으로 적용된다. 이 경우, 옥트리의 모든 옥턴트들이 인코딩된다. 현재 옥턴트의 모든 정점들이 인코딩되면, 현재 옥턴트의 자식 옥턴트의 정점들이 인코딩된다.
일 변형에서, 3D LUT는 인코딩 전에 사전 처리된다. 이러한 경우, 분할 플래그가 옥트리 내의 각각의 옥턴트와 관련되며, 처음에 거짓으로 설정된다. 전처리 단계 동안, 각각의 옥턴트에 대해 분할 플래그 값들이 결정된다. 현재 옥턴트의 인코딩될 적어도 하나의 정점이 아마도 TH보다 크게 양자화된 적어도 하나의 오차를 갖는 경우, 그의 부모 옥턴트의 분할 플래그는 "참"으로 설정된다. 따라서, 레벨 N의 현재 옥턴트의 분할 플래그는 그의 직접 자식들(즉, 레벨 N+1의 자식들)이 재귀적으로 인코딩되는지 또는 아직 인코딩되지 않은 모든 그의 자식들(즉, 레벨 N+k(k>0)의 자식들)의 정점들의 모든 오차들이 0인 것으로 추정되는지를 지시한다.
인코딩 단계 동안, 분할 플래그들 및 오차들이 비트스트림 내에 인코딩된다. 현재 옥턴트의 모든 정점들이 인코딩되면, 현재 옥턴트의 자식 옥턴트의 정점들은 현재 옥턴트 분할 플래그가 참인 경우에 인코딩된다. 2개의 옥턴트에 속하는 정점들은 우선적으로 한 번만 인코딩된다.
3D LUT는 예를 들어 VPS("비디오 파라미터 세트"), SPS("시퀀스 파라미터 세트"), PPS("픽처 파라미터 세트") 내에 또는 AVC, HEVC, SVC 또는 SHVC 비디오 코딩 표준들에서 정의되는 바와 같은 하나의 SEI 메시지("보완 향상 정보") 내에 인코딩된다. 3D LUT는 예를 들어 아래에 정의되는 것과 같은 SEI 메시지 내에 인코딩된다. LUT의 크기(S)도 옵션으로서 비트스트림 내에 인코딩된다. S는 하나의 방향에서의 정점들의 수이다.
일 변형에 따르면, 위에서 개시된 바와 같이, n개의 관련 컬러 값을 갖는 정점들로 구성되는 하나의 3D LUT를 인코딩하는 대신에 1개의 컬러 값을 갖는 정점들로 구성되는 n개의 3D LUT가 인코딩되며, 예로서 n=3이다.
일 변형에 따르면, 3D LUT 크기가 S=2일 때, 디코딩된 3D LUT로부터 3x3 이득 행렬 플러스 오프셋을 계산하여 3D LUT 대신에 CMF로서 사용하도록 디코더에 지시하는 플래그가 인코딩된다.
다른 변형에 따르면, n개의 관련 컬러 값을 갖는 정점들로 구성되는 하나의 3D LUT를 이용하여, 국지적으로 변환된 컬러 변환의 파라미터들을 인코딩한다. 예를 들어, 3D LUT의 각각의 정점은 컬러 변환을 나타내는 12개의 컬러 값과 관련된다. 3개의 컬러 값 (Vr, Vg, Vb)를 현재 정점 V와 관련시키는 대신, 컬러 변환을 나타내는 12개의 컬러 값이 정점 V(r,g,b)와 관련되며, i=0, 1 또는 2를 갖는 12개의 컬러 값 [ai, bi, ci, oi]는 아래의 식이 입증되도록 정의된다.
일 변형에 따르면, i=0, 1 또는 2를 갖는 파라미터들 [ai, bi, ci]만이 정점들과 관련된다.
사실상, 크기 2의 3D LUT(8개의 정점을 갖는 하나의 단일 옥턴트)의 경우, 3D LUT가 아래의 식에 의해 정의되는 이득-오프셋 모델과 동등하도록 정점들의 3개의 컬러 값이 선택될 수 있다.
K는 각각의 컬러 값을 나타내는 데 사용되는 비트들의 수에 의존하는 상수이다. 컬러 값들이 8개 비트로 표현되는 경우에 K=255이고, 컬러 값들이 10개 비트로 표현되는 경우에 K=1023이고, 기타 등등이다. 그러면, 삼선형 보간은 이득-오프셋 모델과 등가이다.
도 10은 본 발명의 일 실시예에 따른 디코딩 방법의 흐름도를 나타낸다.
단계 140에서, 적어도 하나의 오차가 비트스트림(F)으로부터 디코딩된다. 디코딩은 통상적으로 엔트로피 디코딩을 포함한다. 일 변형에 따르면, 디코딩은 양자화된 오차의 엔트로피 디코딩 및 양자화기(q)를 이용하는 양자화된 오차의 역 양자화를 포함한다. 엔트로피 디코딩은 지수-Golomb, Huffman, CABAC("Context Adaptive Binary Arithmetic Coding"의 영문 두문자어)와 같은 전통적인 이진 디코딩 기술들을 이용한다.
옵션으로서, 디코딩 방법은 비트스트림(F)으로부터 양자화기 값(q)을 디코딩하는 단계를 포함한다.
일 변형에 따르면, LUT의 모든 정점들이 비트스트림(F) 내에 인코딩되지는 않는다. 옵션으로서, 이진 플래그가 각각의 정점에 대해 비트스트림(F)으로부터 디코딩되며, 이 이진 플래그는 적어도 하나의 오차가 그 정점에 대해 인코딩되는지의 여부를 지시한다. 오차가 인코딩되지 않는 경우, 오차(들)는 이 정점에 대해 0인 것으로 추정된다.
단계 142에서, 현재 정점의 적어도 하나의 컬러 값이 이웃 정점들과 관련된 재구성 컬러 값들로부터 예측된다. 일례로서, 정점 V0(c1,c2)을 컬러 값들 (V0c1, V0c2)의 대응하는 쌍과 관련시키는 2D LUT가 도 5에 도시된다. 정점 V0와 관련된 컬러 값들은 공간적으로 이웃하는 정점들(V1, V2, V3, V4)로부터 예측된다. 일례로서, 예측자 P(Pc1, Pc2)가 아래와 같이 보간을 이용하여 계산된다.
Pc1= 0.25*(V1c1+ V2c1+ V3c1+V4c1)
Pc2=0.25*(V1c2+ V2c2+ V3c2+V4c2)
단계 144에서, 정점이 재구성된다. 더 정확하게는, 현재 정점의 적어도 하나의 컬러 값이 그의 예측 및 디코딩된 적어도 하나의 오차로부터 재구성된다.
일례로서, 2D LUT의 경우, 2개의 오차 RC1 및 Rc2가 현재 정점 V0에 대해 디코딩된다. 따라서, 현재 정점은 그의 2개의 컬러 값을 (RC1+Pc1) 및 (Rc2+ Pc2)로서 계산함으로써 재구성된다.
일 변형에 따르면, 디코딩 방법은 정점의 적어도 하나의 컬러 값을 예측하는 데 사용되는 보간 타입을 비트스트림(F)으로부터 디코딩하는 단계를 더 포함한다. 더 정확하게는, 보간 타입을 식별하는 인덱스가 비트스트림으로부터 디코딩된다. 일례로서, 인덱스 0은 이선형 보간을 식별하고, 인덱스 1은 최근접 정점 값 보간을 식별한다.
LUT의 크기도 옵션으로서 비트스트림으로부터 디코딩된다.
도 11은 본 발명의 다른 실시예에 따른 디코딩 방법의 흐름도를 나타낸다. 이 방법은 옥트리를 이용하여 정점들의 격자로서 정의된 3D LUT를 디코딩하기 위한 것이며, 여기서는 컬러 값들의 삼중쌍이 격자의 각각의 정점과 관련된다. 디코딩 방법은 현재 옥턴트에 속하는 격자의 현재 정점 V를 디코딩하기 위해 개시된다.
단계 150에서, 3개의 오차 resr, resg, resb가 비트스트림(F)으로부터 디코딩된다. 디코딩은 통상적으로 엔트로피 디코딩을 포함한다. 일 변형에 따르면, 디코딩은 양자화된 오차의 엔트로피 디코딩 및 양자화기(q)를 이용하는 양자화된 오차의 역 양자화를 포함한다. 엔트로피 디코딩은 지수-Golomb, Huffman, CABAC("Context Adaptive Binary Arithmetic Coding"의 영문 두문자어)와 같은 전통적인 이진 디코딩 기술들을 이용한다.
옵션으로서, 디코딩 방법은 비트스트림(F)으로부터 양자화기 값(q)을 디코딩하는 단계를 포함한다.
일 변형에 따르면, LUT의 모든 정점들이 비트스트림(F) 내에 인코딩되지는 않는다. 옵션으로서, 이진 플래그가 각각의 정점에 대해 비트스트림(F)으로부터 디코딩되며, 이 이진 플래그는 적어도 하나의 오차가 그 정점에 대해 인코딩되는지의 여부를 지시한다. 오차가 인코딩되지 않는 경우, 오차(들)는 이 정점에 대해 0인 것으로 추정된다.
단계 152에서, 좌표들 (r, g, b)의 현재 정점 V와 관련된 3개의 컬러 값 (Vr, Vg, Vb) 각각이 이웃 정점들, 즉 현재 옥턴트의 부모 옥턴트에 속하는 정점들과 관련된 재구성 컬러 값들로부터 예측된다. 표기법을 간소화하기 위해 (c1, c2, c3) 대신 (r, g, b)가 사용된다. 그러나, 본 발명은 (R, G, B) 컬러 공간으로 한정되지 않는다. 본 발명은 (Y,U,V), (Y,Cb,Cr) 등의 컬러 공간 표현들에 적용될 수 있다.
따라서, 각각의 컬러 값에 대해 예측이 결정된다.
따라서, 예를 들어 도 8에 도시된 바와 같은 삼선형 보간을 이용하여 각각의 컬러 값에 대해 예측이 결정된다.
여기서 i=0, 1, j=0, 1 및 k=0, 1을 갖는 (ri, gj, bk)는 3D 컬러 공간 내의 부모 옥턴트의 정점들의 좌표들이고,
(r, g, b)는 현재 정점의 좌표들이고,
s0(t) = t1-t 및 s1(t) = t-t0이고, t= r, g 또는 b이다.
동일한 식들이 g 및 b에 대해 사용된다. 프리즘, 피라미드 또는 사면체와 같은 다른 타입의 보간이 이용될 수 있다. 격자는 도 9에 도시된 바와 같이 반드시 균일하지는 않다.
따라서, 단계 154에서, 3개의 컬러 값이 현재 정점에 대해 그들의 예측 및 대응하는 디코딩된 오차들 (resr, resg, resb)로부터 재구성된다. 따라서, 현재 정점은 3개의 컬러 값을 (resr+ ), (resg+ )) 및 (resb+ )로서 계산함으로써 재구성된다.
레벨 0의 옥턴트는 부모 옥턴트를 갖지 않는다. 같은 방식으로, 코딩 옥턴트 리스트 내의 제1 옥턴트는 선행 옥턴트를 갖지 않는다. 결과적으로, 이러한 옥턴트의 현재 정점 V와 관련된 3개의 컬러 값 (Vr, Vg, Vb)는 알려진 컬러 값, 예로서 값 128로부터 예측된다. 일 변형에 따르면, 이러한 옥턴트의 현재 정점 V와 관련된 3개의 컬러 값 (Vr, Vg, Vb) 각각은 동일 옥턴트에 속하는 이웃 정점들과 관련된 이미 재구성된 컬러 값들로부터 예측된다.
방법은 전체 3D LUT를 디코딩하기 위해 재귀적으로 적용된다. 2개의 옥턴트에 속하는 정점들은 우선적으로 한 번만 디코딩된다.
현재 옥턴트(레벨 N)의 모든 정점들이 디코딩되면, 현재 옥턴트의 자식(레벨 N+1) 옥턴트들의 정점들이 디코딩된다.
일 변형에 따르면, 분할 플래그가 레벨 N의 현재 옥턴트에 대해 디코딩되며, 이 분할 플래그는 그의 직접 자식들(즉, 레벨 N+1의 자식들)이 재귀적으로 디코딩되는지 또는 아직 디코딩되지 않은 모든 자식들(즉, 레벨 N+k(k>0)의 자식들)의 정점들의 모든 오차들이 0인 것으로 추정되는지를 지시한다.
일 변형에 따르면, 디코딩 방법은 정점의 적어도 하나의 컬러 값을 예측하는 데 사용되는 보간 타입을 비트스트림(F)으로부터 디코딩하는 단계를 더 포함한다. 더 정확하게는, 보간 타입을 식별하는 인덱스가 비트스트림으로부터 디코딩된다. 일례로서, 인덱스 0은 삼선형 보간을 식별하고, 인덱스 1은 프리즘 보간을 식별하고, 인덱스 2는 피라미드 보간을 식별하고, 인덱스 3은 사면체 보간을 식별한다.
3D LUT는 예를 들어 VPS, SPS, PPS로부터 또는 AVC, HEVC, SVC 또는 SHVC 비디오 코딩 표준들에서 정의되는 바와 같은 하나의 SEI 메시지 내에서 디코딩된다. LUT의 크기도 옵션으로서 비트스트림으로부터 디코딩된다. 3D LUT는 예를 들어 아래에 정의되는 것과 같은 SEI 메시지 내에서 디코딩된다.
일 변형에 따르면, n개의 컬러 값을 갖는 정점들로 구성되는 하나의 3D LUT를 디코딩하는 대신에 1개의 컬러 값을 갖는 정점들로 구성되는 n개의 3D LUT가 디코딩되며, 예로서 n=3이다.
일 변형에 따르면, 3D LUT 크기가 S=2일 때, 디코딩된 3D LUT로부터 3x3 이득 행렬 플러스 오프셋을 계산하여 3D LUT 대신에 CMF로서 사용하도록 디코더에 지시하는 플래그가 디코딩된다.
도 4 및 6에 따른 인코딩 방법과 관련하여 개시되는 것과 동일한 변형들이 디코딩 측에 적용될 수 있다.
도 4, 6, 10 및 11에서, 표시된 박스들은 순전히 기능적인 엔티티들이며, 이들은 물리적인 개별 엔티티들에 반드시 대응하지는 않는다. 이 분야의 기술자에 의해 인식되듯이, 본 발명의 원리들의 양태들은 시스템, 방법 또는 컴퓨터 판독 가능 매체로서 구현될 수 있다. 따라서, 본 발명의 원리들의 양태들은 완전 하드웨어 실시예, (펌웨어, 상주 소프트웨어, 마이크로코드 등을 포함하는) 완전 소프트웨어 실시예, 또는 본 명세서에서 모두가 일반적으로 "회로", "모듈" 또는 "시스템"으로 지칭될 수 있는 소프트웨어 및 하드웨어 양태들을 결합하는 실시예의 형태를 취할 수 있다. 또한, 본 발명의 원리들의 양태들은 컴퓨터 판독 가능 저장 매체의 형태를 취할 수 있다. 하나 이상의 컴퓨터 판독 가능 매체(들)의 임의의 조합이 이용될 수 있다.
도면들 내의 흐름도 및/또는 블록도들은 본 발명의 다양한 실시예들에 따른 시스템들, 방법들 및 컴퓨터 프로그램 제품들의 가능한 구현들의 구성, 동작 및 기능을 예시한다. 이와 관련하여, 흐름도 또는 블록도들 내의 각각의 블록은 지정된 논리 기능(들)을 구현하기 위한 하나 이상의 실행 가능 명령어를 포함하는 모듈, 세그먼트, 또는 코드의 일부를 나타낼 수 있다. 일부 대안 구현들에서는 블록 내에 기재된 기능들이 도면들에 기재된 순서와 다르게 발생할 수 있다는 점에도 유의해야 한다. 예를 들어, 관련 기능에 따라, 연속적으로 도시된 2개의 블록은 실제로는 실질적으로 동시에 실행될 수 있거나, 블록들은 때때로 역순으로 실행될 수 있거나, 블록들은 대안 순서로 실행될 수 있다. 블록도들 및/또는 흐름도의 각각의 블록, 및 블록도들 및/또는 흐름도 내의 블록들의 조합들은 지정된 기능들 또는 동작들을 수행하는 특수 목적 하드웨어 기반 시스템들, 또는 특수 목적 하드웨어와 컴퓨터 명령어들의 조합들에 의해 구현될 수 있다는 점에도 유의할 것이다. 명확히 설명되지는 않지만, 본 발명의 실시예들은 임의의 조합 또는 하위 조합으로 이용될 수 있다.
3D LUT와 같은 LUT를 인코딩하는 비트스트림도 개시된다. 도면의 인코딩 방법에 의해 생성되는 비트스트림은 정점들의 격자로서 정의되는 적어도 LUT를 인코딩하며, 적어도 하나의 컬러 값이 격자의 각각의 정점과 관련되고, 상기 비트스트림은 현재 정점의 적어도 하나의 컬러 값과 그의 예측 사이에서 계산되는 적어도 하나의 오차를 그 안에 인코딩하는 것을 포함한다.
ITU-T SG16 WP3 및 ISO/IEC JTC1/SC29/WG11의 JCT-VC(Joint Collaborative Team on Video Coding)의 문서 JCTVC-L1003에서 정의되는 HEVC 코딩 표준 또는 ITU-T SG16 WP3 및 ISO/IEC JTC1/SC29/WG11의 JCT-VC(Joint Collaborative Team on Video Coding)의 문서 JCTVC-L1008에서 정의되는 HEVC 코딩 표준의 스케일링 가능 확장인 SHVC 코딩 표준의 프레임워크 내에서 일 실시예가 제안된다. 표준은 코딩된 데이터의 임의의 스트림이 이 표준에 맞도록 따라야 하는 신택스를 정의한다. 신택스는 특히 다양한 정보 아이템들(예로서, 시퀀스 내에 포함된 픽처들, 모션 벡터들 등에 관한 데이터)이 어떻게 코딩되는지를 정의한다. SHVC 코딩 표준과 관련하여, LUT는 PPS 또는 VPS 내에 인코딩될 수 있다. 신택스 요소 use_color_prediction은 표 1에 나타난 바와 같이 현재 픽처에서의 컬러 예측의 사용을 지시하는 데 사용된다.
표 1: 예측 파라미터들의 시그널링
use_color_prediction 플래그가 '1'인 경우, 3D_LUT_color_data 함수가 표 2에 나타난 바와 같이 3D LUT 데이터를 시그널링하도록 호출된다.
표 2: 3D LUT 컬러 데이터의 코딩
nbpCode는 nbpCode의 주어진 값에 대한 표 4에 목록화된 바와 같은 3D LUT 크기를 지시한다. 양자화기 값은 3D_LUT_color_data() 함수에 의해 인코딩될 수 있다.
일 변형에 따르면, 3D_LUT_color_data()는 표 3에서 아래와 같이 정의된다.
표 3: 3D LUT 컬러 데이터의 코딩
nbpCode는 nbpCode의 주어진 값에 대한 표 4에 목록화된 바와 같은 3D LUT 크기를 지시한다. 양자화기 값은 3D_LUT_color_data() 함수에 의해 인코딩될 수 있다.
NbitsPerSample은 컬러 값들을 나타내는 데 사용되는 비트들의 수를 지시한다.
표 4: nbpCode의 해석
옥턴트(계층, y,u,v)의 디코딩은 표 5에 나타난 바와 같이 재귀 함수이다. 각각의 옥턴트는 오차 컬러 값들이 인코딩될지 또는 모두 0인 것으로 추정될지를 지시하는 플래그 (encoded_flag[i])와 관련된 8개의 정점으로 구성된다. 컬러 값들은 컬러 값들의 예측에 오차들을 더함으로써 재구성된다. 컬러 값들의 예측은 예를 들어 layer_id-1의 8개의 이웃 정점의 삼선형 보간을 이용하여 계산된다.
표 5: coding_octant()에 대한 신택스 요소들
다른 유리한 실시예에 따르면, LUT는 SEI 메시지 내에 인코딩된다(SEI는 "보완 향상 정보"를 나타낸다). HEVC 표준은 그의 부록 D에서 SEI라고 하는 추가 정보를 코딩하는 방법을 정의한다. 이러한 추가 정보는 신택스에서 payloadType이라고 하는 필드에 의해 참조된다. SEI 메시지들은 예를 들어 표시와 관련된 프로세스들을 돕는다. 디코딩 장치가 그의 사용에 필요한 기능들을 갖지 않는 경우에는 이러한 정보가 무시된다는 점에 유의한다. 본 발명의 특정 실시예에 따르면, 3D LUT에 관한 추가 정보를 코딩하기 위해 새로운 타입의 SEI 메시지가 정의된다. 이러한 목적으로, 필드 payloadType에 대한 새로운 값이 아직 사용되지 않은 값들 중에서 정의된다(예를 들어, payloadType은 24이다).
SEI 데이터의 신택스(즉, sei_payload)는 아래의 방식으로 확장된다.
표 6: 컬러 맵핑 SEI 메시지
일 변형에 따르면, SEI 메시지는 예를 들어 color_description_present_flag 뒤에 지시자 color_interpolator_id를 더 포함하며, 그의 값은 표 7에 지정된 바와같은 보간의 타입을 지시한다.
표 7: 보간의 타입
이러한 SEI 메시지는 특정 표시 환경들에 대한 맞춤화를 위한 출력되는 디코딩된 픽처들의 컬러 샘플들의 리맵핑을 가능하게 하기 위한 정보를 제공한다. 리맵핑 프로세스는 RGB 컬러 공간 내의 코딩된 샘플 값들을 타겟 샘플 값들로 맵핑한다. 맵핑들은 루마 또는 RGB 컬러 공간 도메인에서 표현되며, 따라서 루마 컴포넌트에 또는 디코딩된 픽처의 컬러 공간 변환에 의해 생성되는 각각의 RGB 컴포넌트에 적용되어야 한다.
3D_LUT_color_data()가 표 2 또는 3에서 정의된다.
디코딩된 3D LUT는 예를 들어 SEI 메시지의 NAL 유닛 헤더의 인덱스 nuh_layer_id에 의해 식별된 계층에 속하는 디코딩된 픽처들에 적용된다(ITU-T SG16 WP3 및 ISO/IEC JTC1/SC29/WG11의 JCT-VC(Joint Collaborative Team on Video Coding)의 문서 JCTVC-L1003에서 정의되는 문서 HEVC 코딩 표준의 섹션 7.3.1.2 참조).
color_map_id는 컬러 맵핑 모델의 목적을 식별하는 데 사용될 수 있는 식별 번호를 포함한다. color_map_id의 값들은 응용에 의해 결정되는 대로 사용될 수 있다. color_map_id는 상이한 표시 시나리오들에 적합한 컬러 맵핑 동작들을 지원하는 데 사용될 수 있다. 예를 들어, color_map_id의 상이한 값들은 상이한 표시 비트 깊이들에 대응할 수 있다.
1과 동일한 color_map_cancel_flag는 컬러 맵핑 정보 SEI 메시지가 출력 순서에 있어서의 임의의 이전의 컬러 맵핑 정보 SEI 메시지의 지속성을 제거한다는 것을 지시한다. 0과 동일한 color_map_cancel_flag는 컬러 맵핑 정보가 이어진다는 것을 지시한다.
color_map_repetition_period는 컬러 맵핑 정보 SEI 메시지의 지속성을 지정하며, 동일 값의 color_map_id를 갖는 다른 컬러 맵핑 정보 SEI 메시지 또는 코딩된 비디오 시퀀스의 끝이 비트스트림 내에 존재해야 하는 픽처 순서 카운트 간격을 지정할 수 있다. 0과 동일한 color_map_repetition_period는 컬러 맵 정보가 현재의 디코딩된 픽처에만 적용된다는 것을 지정한다.
1과 동일한 color_map_repetition_period는 아래의 조건들 중 임의의 조건이 참일 때까지 컬러 맵 정보가 출력 순서에 있어서 지속된다는 것을 지정한다.
- 새로운 코딩된 비디오 시퀀스가 시작된다.
- 동일 값의 color_map_id를 갖는 컬러 맵핑 정보 SEI 메시지를 포함하는 액세스 유닛 내의 픽처가 PicOrderCnt(CurrPic)로 표시되는 현재의 디코딩된 픽처의 (POC로서 알려진) 픽처 순서 카운트보다 큰 POC를 갖고서 출력된다.
0과 동일한 또는 1과 동일한 color_map_repetition_period는 동일 값의 color_map_id를 갖는 다른 컬러 맵핑 정보 SEI 메시지가 존재하거나 존재하지 않을 수 있다는 것을 지시한다.
1보다 큰 color_map_repetition_period는 아래의 조건들 중 임의의 조건이 참일 때까지 컬러 맵 정보가 지속된다는 것을 지정한다.
- 새로운 코딩된 비디오 시퀀스가 시작된다.
- 동일 값의 color_map_id를 갖는 컬러 맵핑 정보 SEI 메시지를 포함하는 액세스 유닛 내의 픽처가 PicOrderCnt(CurrPic)보다 크거나 PicOrderCnt(CurrPic) + color_map_repetition_period 이하인 POC를 갖고서 출력된다.
1보다 color_map_repetition_period는 동일 값의 color_map_id를 갖는 다른 컬러 맵핑 정보 SEI 메시지가 PicOrderCnt(CurrPic)보다 크거나 PicOrderCnt(CurrPic) + color_map_repetition_period 이하인 POC를 갖고서 출력되는 액세스 유닛 내의 픽처에 대해 존재해야 하며, 그렇지 않을 경우에는 그러한 픽처의 출력 없이 비트스트림이 종료되거나, 새로운 코딩된 비디오 시퀀스가 시작된다는 것을 지시한다.
1과 동일한 color_description_present_flag는 colour_primaries_input_id 및 colour_primaries_output_id가 존재한다는 것을 지정한다. 0과 동일한 color_description_present_flag는 colour_primaries_input_id 및 colour_primaries_output_id가 존재하지 않는다는 것을 지정한다.
color_primaries_input_id는 ISO 11664-1에 의해 지정되는 바와 같은 x 및 y의 CIE 1931 정의와 관련하여 표 8에서 지정되는 바와 같은 소스 원색들의 색도 좌표들을 지시한다.
color_primaries_output_id는 3D 컬러 LUT가 적용되는 경우에 ISO 11664-1에 의해 지정되는 바와 같은 x 및 y의 CIE 1931 정의와 관련하여 표 8에서 지정되는 바와 같은 컬러 맵핑된 원색들의 색도 좌표들을 지시한다.
1과 동일한 color_output_rgb는 출력 컬러 샘플들이 루마 및 크로마 신호들이라는 것을 지정한다. 0과 동일한 color_output_rgb는 출력 컬러 샘플들이 녹색, 적색, 청색 값들이라는 것을 지정한다.
lut_bit_depth_minus8은 3D LUT 샘플들의 비트 깊이를 지정한다.
nbp_code는 nbp_code의 주어진 값에 대해 표 4에 목록화된 바와 같은 3D LUT 크기 nbp를 지시한다.
3D LUT 디코딩의 출력은 크기 nbp x nbp x nbp의 삼차원 어레이 LUT이다. 각각의 LUT 어레이 요소는 정점으로 지칭되며, (lut_bit_depth_minus8+8)과 동일한 비트 깊이의 3개의 재구성 샘플 값(recSamplesY, recSamplesU, recSamplesV)과 관련된다. 정점 lut[i][j][k]는 i%(nbp>>layer_id), j%(nbp>>layer_id), k%(nbp>>layer_id)의 값들이 0과 동일한 경우에 계층 layer_id에 속하는 것으로 지칭된다. 하나의 정점이 여러 계층에 속할 수 있다. 계층 layer_id의 옥턴트는 layer_id에 속하는 8개의 이웃 정점으로 구성된다(도 14).
옥턴트 (layer_id, y,u,v)의 디코딩은 재귀 함수이다. 각각의 옥턴트는 오차 컴포넌트 값들 (resY[i],resU[i], resV[i])가 인코딩되는지 또는 모두 0인 것으로 추정되는지를 지시하는 플래그 (encoded_ flag[i])와 관련된 8개의 정점 (i = 0,...7)로 구성된다. 컴포넌트 값들은 컴포넌트 값들의 예측에 오차들을 더함으로써 재구성된다. 컴포넌트 값들의 예측은 layer_id-1의 8개의 이웃 정점의 삼선형 보간을 이용하여 계산된다. 재구성된 정점은 재구성된 것으로서 마킹된다.
여기서, (y+dy[i]), (u+du[i]) 및 (v+dv[i])는 ((y,u,v)를 제1 정점(i=0) 좌표들로서 갖는) 현재 옥턴트의 8개의 자식 옥턴트 좌표(제1 3D 컬러 정점의 좌표들)이다. 주어진 계층에 대한 값들 dy[i],du[i] 및 dv[i]가 표 9에 표시된다.
표 8: 원색들(color_primaries_input_id 및 color_primaries_output_id)
표 9: layer = layer_id에 속하는 정점들에 대한 인덱스 i의 함수 내의 값들 dy[i],du[i] and dv[i]
layer = layer_id의 옥턴트에 속하는 정점 ((y+dy[i]), (u+du[i]), (v+dv[i]))에 대한 재구성 3D 컬러 LUT 샘플들 (recSamplesY[i], recSamplesU[i], recSamplesV[i])는 recSamplesY[i] = resY[i] + predSamplesY[i]에 의해 주어지며, 여기서 predSamplesY[i]의 값은 현재 옥턴트를 포함하는 layer = layer_id-1의 옥턴트의 정점들과 관련된 삼선형 보간을 이용하여 도출된다.
도 12는 인코더(1)의 예시적인 아키텍처를 나타낸다. 인코더는 인코딩 방법의 단계들을 실행하도록 구성된다. 인코더(1)는 데이터 및 주소 버스(64)에 의해 함께 링크되는 아래의 요소들을 포함한다:
- 예를 들어 DSP(즉, 디지털 신호 프로세서)인 마이크로프로세서(61)(또는 CPU);
- ROM(즉, 판독 전용 메모리)(62);
- RAM(즉, 랜덤 액세스 메모리)(63);
- 예를 들어 키보드, 마우스, 웹캠 등과 같은 하나 또는 여러 개의 I/O(입출력) 장치(65); 및
- 전원(66).
일 변형에 따르면, 전원(66)은 인코더 외부에 위치한다. 도 12의 이러한 요소들 각각은 이 분야의 기술자에게 잘 알려져 있으며, 더 설명되지 않을 것이다. 언급된 메모리 각각에서, 본 명세서에서 사용되는 단어 "레지스터"는 언급된 메모리들 각각에서 낮은 용량(몇몇 이진 데이터)의 메모리 존은 물론, (전체 프로그램이 저장되거나, 계산된 데이터를 나타내는 데이터의 전부 또는 일부가 표시되는 것을 가능하게 하는) 큰 용량의 메모리 존도 지시한다. ROM(62)은 프로그램 및 (임계치(TH)와 같은) 인코딩 파라미터들을 포함한다. 본 발명에 따른 인코딩 방법의 알고리즘은 ROM(62) 내에 저장된다. 스위치 온될 때, CPU(61)는 프로그램(620)을 RAM 내에 업로드하고, 대응하는 명령어들을 실행한다.
RAM(63)은 레지스터 내에, CPU(61)에 의해 실행되고 인코더(1)의 스위치 온 후에 업로드되는 프로그램, 레지스터 내의 입력 데이터, 레지스터 내의 인코딩 방법의 상이한 상태에서의 인코딩된 데이터 및 레지스터 내의 인코딩을 위해 사용되는 다른 변수들을 포함한다.
도 13은 디코더(2)의 예시적인 아키텍처를 나타낸다. 디코더는 디코딩 방법의 단계들을 실행하도록 구성된다. 디코더(2)는 데이터 및 주소 버스(74)에 의해 함께 링크되는 아래의 요소들을 포함한다:
- 예를 들어 DSP(즉, 디지털 신호 프로세서)인 마이크로프로세서(71)(또는 CPU);
- ROM(즉, 판독 전용 메모리)(72);
- RAM(즉, 랜덤 액세스 메모리)(73);
- 애플리케이션으로부터의 전송할 데이터의 수신을 위한 I/O 인터페이스(75); 및
- 배터리(76).
일 변형에 따르면, 배터리(76)는 인코더 외부에 위치한다. 도 13의 이러한 요소들 각각은 이 분야의 기술자에게 잘 알려져 있으며, 더 설명되지 않을 것이다. 언급된 메모리 각각에서, 본 명세서에서 사용되는 단어 "레지스터"는 적은 용량(몇몇 비트)의 영역 또는 매우 큰 영역(예로서, 전체 프로그램 또는 많은 양의 수신 또는 디코딩된 데이터)에 대응할 수 있다. ROM(72)은 적어도 프로그램 및 디코더 파라미터들을 포함한다. 본 발명에 따른 디코딩 방법의 알고리즘은 ROM(72) 내에 저장된다. 스위치 온될 때, CPU(71)는 프로그램(720)을 RAM 내에 업로드하고, 대응하는 명령어들을 실행한다.
RAM(73)은 레지스터 내에, CPU(71)에 의해 실행되고 디코더(2)의 스위치 온 후에 업로드되는 프로그램, 레지스터 내의 입력 데이터, 레지스터 내의 디코딩 방법의 상이한 상태에서의 디코딩된 데이터 및 레지스터 내의 디코딩을 위해 사용되는 다른 변수들을 포함한다.
본 명세서에서 설명되는 구현들은 예를 들어 방법 또는 프로세스, 장치, 소프트웨어 프로그램, 데이터 스트림 또는 신호 내에 구현될 수 있다. 단일 형태의 구현과 관련해서만 설명되는 경우에도(예를 들어, 방법 또는 장치로서만 설명되는 경우에도), 설명되는 특징들의 구현은 다른 형태들(예로서, 프로그램)로도 구현될 수 있다. 장치는 예를 들어 적절한 하드웨어, 소프트웨어 및 펌웨어로 구현될 수 있다. 방법들은 예를 들어 일반적으로 컴퓨터, 마이크로프로세서, 집적 회로 또는 프로그래밍 가능 논리 장치를 포함하는 처리 장치들을 지칭하는 프로세서와 같은 장치에서 구현될 수 있다. 프로세서들은 또한 예를 들어 컴퓨터, 셀 폰, 휴대용/개인용 디지털 단말기("PDA"), 및 최종 사용자들 사이의 정보의 통신을 용이하게 하는 다른 장치들과 같은 통신 장치들을 포함한다.
본 명세서에서 설명되는 다양한 프로세스들 및 특징들의 구현들은 다양한 상이한 장비 또는 애플리케이션, 특히 예를 들어 장비 또는 애플리케이션에서 구현될 수 있다. 그러한 장비의 예는 인코더, 디코더, 디코더로부터의 출력을 처리하는 포스트-프로세서, 인코더에 입력을 제공하는 프리-프로세서, 비디오 코더, 비디오 디코더, 비디오 코덱, 웹 서버, 셋톱 박스, 랩탑, 개인용 컴퓨터, 셀 폰, PDA 및 다른 통신 장치들을 포함한다. 명백해야 하듯이, 장비는 이동할 수 있고, 이동 차량 내에 설치될 수도 있다.
게다가, 방법들은 프로세서에 의해 실행되는 명령어들에 의해 구현될 수 있으며, 그러한 명령어들(및/또는 구현에 의해 생성되는 데이터 값들)은 예를 들어 집적 회로, 소프트웨어 캐리어 또는 다른 저장 장치, 예로서 하드 디스크, 컴팩트 디스켓("CD"), 광 디스크(예로서, 종종 디지털 다기능 디스크 또는 디지털 비디오 디스크로 지칭되는 DVD 등), 랜덤 액세스 메모리("RAM") 또는 판독 전용 메모리("ROM")와 같은 프로세서 판독 가능 매체 상에 저장될 수 있다. 명령어들은 프로세서 판독 가능 매체 상에 유형적으로 구현되는 애플리케이션 프로그램을 형성할 수 있다. 명령어들은 예를 들어 하드웨어, 펌웨어, 소프트웨어 또는 이들의 조합 내에 존재할 수 있다. 명령어들은 예를 들어 운영 체제, 개별 애플리케이션 또는 이들의 조합 내에서 발견될 수 있다. 따라서, 프로세서는 예를 들어 프로세스를 수행하도록 구성되는 장치 및 프로세스를 수행하기 위한 명령어들을 갖는 프로세서 판독 가능 매체(예로서, 저장 장치)를 포함하는 장치 양자로서 특화될 수 있다. 또한, 프로세서 판독 가능 매체는 명령어들에 더하여 또는 그 대신에 구현에 의해 생성된 데이터 값들을 저장할 수 있다.
이 분야의 기술자에게 명백하듯이, 구현들은 예를 들어 저장 또는 전송될 수 있는 정보를 운반하도록 포맷팅되는 다양한 신호들을 생성할 수 있다. 정보는 예를 들어 방법을 수행하기 위한 명령어들, 또는 설명되는 구현들 중 하나에 의해 생성되는 데이터를 포함할 수 있다. 예를 들어, 신호는 설명되는 실시예의 신택스를 기록 또는 판독하기 위한 규칙들을 데이터로서 운반하거나 설명되는 실시예에 의해 기록되는 실제 신택스 값들을 데이터로서 운반하도록 포맷팅될 수 있다. 그러한 신호는 예를 들어 (예를 들어, 스펙트럼의 무선 주파수 부분을 이용하여) 전자기파로서 또는 기저대역 신호로서 포맷팅될 수 있다. 포맷팅은 예를 들어 데이터 스트림을 인코딩하고, 인코딩된 데이터 스트림으로 캐리어를 변조하는 것을 포함할 수 있다. 신호가 운반하는 정보는 예를 들어 아날로그 또는 디지털 정보일 수 있다. 신호는 공지된 바와 같은 다양한 상이한 유선 또는 무선 링크를 통해 전송될 수 있다. 신호는 프로세서 판독 가능 매체 상에 저장될 수 있다.
다양한 구현들이 설명되었다. 그러나, 다양한 변경들이 이루어질 수 있다는 것을 이해할 것이다. 예를 들어, 상이한 구현들의 요소들은 다른 구현들을 생성하도록 결합, 보완, 변경 또는 제거될 수 있다. 게다가, 통상의 기술자는 다른 구조들 및 프로세스들이 개시된 것들을 대체할 수 있으며, 결과적인 구현들은 적어도 실질적으로 동일한 방식(들)으로 적어도 실질적으로 동일한 기능(들)을 수행하여 개시된 구현들과 적어도 실질적으로 동일한 결과(들)를 달성할 것이라는 것을 이해할 것이다. 따라서, 이들 및 다른 구현들은 본원에 의해 고려된다. 특히, 본 발명에 따른 LUT를 인코딩하기 위한 방법은 각각의 정점과 관련된 값들의 타입들에 관계없이 임의 종류의 LUT를 인코딩하는 데 사용될 수 있다.
Claims (14)
- 옥트리(octree)의 옥턴트들(octants)과 연관된 삼차원 컬러 탐색표(Look-Up Table)를 인코딩하기 위한 인코딩 방법으로서,
현재 옥턴트에 대해 그의 직접 자식 옥턴트들(immediate child octants) 중 적어도 하나가 재귀적으로 인코딩되는지를 지시하는 분할 플래그를 인코딩하는 단계;
상기 분할 플래그에 응답하여 상기 현재 옥턴트를 인코딩하는 단계 - 상기 현재 옥턴트를 인코딩하는 단계는 예측을 획득하기 위하여 이웃 정점의 적어도 하나의 재구성된 값으로부터 상기 현재 옥턴트 내의 정점의 적어도 하나의 값을 예측하는 단계를 포함함 -;
상기 정점의 상기 적어도 하나의 값과 상기 예측 사이에서 계산된 오차(residue)를 결정하는 단계; 및
상기 오차를 엔트로피 인코딩하는 단계
를 포함하고,
상기 인코딩 방법은,
상기 현재 옥턴트의 정점에 대해 적어도 하나의 오차가 상기 정점에 대해 인코딩되는지 여부를 지시하는 플래그를 인코딩하는 단계
를 더 포함하는 인코딩 방법. - 제1항에 있어서, 상기 정점의 적어도 하나의 값 및 상기 이웃 정점의 적어도 하나의 재구성된 값은 컬러 값들인 인코딩 방법.
- 제2항에 있어서, 상기 컬러 값들은 컬러 변환을 나타내는 인코딩 방법.
- 제1항 내지 제3항 중 어느 한 항에 있어서, 이웃 정점의 상기 적어도 하나의 재구성된 값은 상기 현재 옥턴트의 부모 옥턴트에 속하는 인코딩 방법.
- 옥트리의 옥턴트들의 삼차원 컬러 탐색표를 디코딩하기 위한 디코딩 방법으로서,
현재 옥턴트에 대해 그의 직접 자식 옥턴트들 중 적어도 하나가 재귀적으로 디코딩되는지를 지시하는 분할 플래그를 디코딩하는 단계; 및
상기 분할 플래그에 응답하여 상기 현재 옥턴트를 재구성하는 단계
를 포함하고, 상기 현재 옥턴트를 재구성하는 단계는,
(a) 예측을 획득하기 위하여 이웃 정점의 적어도 하나의 재구성된 값으로부터 상기 현재 옥턴트 내의 정점의 적어도 하나의 값을 예측하는 단계;
(b) 오차를 획득하기 위하여 수신된 데이터를 엔트로피 디코딩하는 단계; 및
(c) 상기 예측 및 상기 오차로부터 상기 정점의 상기 적어도 하나의 값을 재구성하는 단계
를 포함하고,
상기 디코딩 방법은,
상기 현재 옥턴트 내의 상기 정점에 대해 적어도 하나의 오차가 상기 정점에 대해 디코딩되는지 여부를 지시하는 플래그를 디코딩하는 단계
를 더 포함하는 디코딩 방법. - 제5항에 있어서, 상기 정점의 적어도 하나의 값 및 상기 이웃 정점의 상기 적어도 하나의 재구성된 값은 컬러 값들인 디코딩 방법.
- 제6항에 있어서, 상기 컬러 값들은 컬러 변환을 나타내는 디코딩 방법.
- 제5항 내지 제7항 중 어느 한 항에 있어서, 상기 이웃 정점의 상기 적어도 하나의 재구성된 값은 상기 현재 옥턴트의 부모 옥턴트에 속하는 디코딩 방법.
- 전송 장치로서,
현재 옥턴트의 적어도 하나의 직접 자식 옥턴트가 재귀적으로 인코딩되는지를 지시하는 분할 플래그를 전송하는 수단; 및
상기 현재 옥턴트에 대해, 상기 분할 플래그에 응답하여 인코딩된 데이터를 전송함으로써 옥턴트들의 삼차원 컬러 탐색표를 나타내는 비트스트림을 제공하기 위한 수단
을 포함하고,
상기 분할 플래그에 응답하여 인코딩된 상기 데이터는 상기 현재 옥턴트의 정점의 적어도 하나의 값과 이웃 정점의 적어도 하나의 재구성된 값으로부터 획득된 예측 사이에서 계산된 엔트로피 인코딩된 오차를 나타내고,
상기 전송 장치는,
상기 현재 옥턴트 내의 정점에 대해 적어도 하나의 오차가 상기 정점에 대해 인코딩되는지 여부를 지시하는 플래그를 전송하기 위한 수단
을 더 포함하는 전송 장치. - 옥트리의 옥턴트들과 연관된 삼차원 컬러 탐색표를 인코딩하기 위한 인코딩 장치로서,
현재 옥턴트에 대해 그의 직접 자식 옥턴트들 중 적어도 하나가 재귀적으로 인코딩되는지를 지시하는 분할 플래그를 인코딩하기 위한 수단;
상기 분할 플래그에 응답하여 상기 현재 옥턴트를 인코딩하기 위한 수단 - 상기 현재 옥턴트를 인코딩하기 위한 수단은 예측을 획득하기 위하여 이웃 정점의 적어도 하나의 재구성된 값으로부터 상기 현재 옥턴트 내의 정점의 적어도 하나의 값을 예측하도록 구성됨 - ;
상기 정점의 적어도 하나의 값과 상기 예측 사이에서 계산된 오차를 결정하기 위한 수단; 및
상기 오차를 엔트로피 인코딩하기 위한 수단
을 포함하고,
상기 인코딩 장치는,
상기 현재 옥턴트 내의 정점에 대해 적어도 하나의 오차가 상기 정점에 대해 인코딩되는지 여부를 지시하는 플래그를 인코딩하기 위한 수단
을 더 포함하는 인코딩 장치. - 옥트리의 옥턴트들의 삼차원 컬러 탐색표를 디코딩하기 위한 디코딩 장치로서,
현재 옥턴트에 대해 그의 직접 자식 옥턴트들 중 적어도 하나가 재귀적으로 디코딩되는지를 지시하는 분할 플래그를 디코딩하기 위한 수단; 및
상기 분할 플래그에 응답하여 상기 현재 옥턴트를 재구성하기 위한 수단 - 상기 현재 옥턴트를 재구성하기 위한 수단은,
(a) 예측을 획득하기 위하여 이웃 정점의 적어도 하나의 재구성된 값으로부터 상기 현재 옥턴트 내의 정점의 적어도 하나의 값을 예측하고;
(b) 오차를 획득하기 위하여 수신된 데이터를 엔트로피 디코딩하고;
(c) 상기 예측 및 상기 오차로부터 상기 정점의 상기 적어도 하나의 값을 재구성하도록 구성됨 -
을 포함하고,
상기 디코딩 장치는,
상기 현재 옥턴트 내의 정점에 대해 적어도 하나의 오차가 상기 정점에 대해 디코딩되는지 여부를 지시하는 플래그를 디코딩하기 위한 수단
을 더 포함하는 디코딩 장치. - 프로세서에 의해 실행될 때 상기 프로세서로 하여금 제1항 내지 제3항 중 어느 한 항의 인코딩 방법 또는 제5항 내지 제7항 중 어느 한 항의 디코딩 방법을 수행하게 하는 프로그램 명령어들이 저장되어 있는 컴퓨터 판독가능 저장 매체.
- 옥트리의 옥턴트들과 연관된 삼차원 컬러 탐색표를 인코딩하기 위한 인코딩 장치로서,
프로그램 명령어들을 저장하도록 구성된 메모리, 및
상기 메모리에 결합되고 상기 프로그램 명령어들을 실행하도록 구성된 프로세서
를 포함하고,
상기 프로그램 명령어들은, 상기 프로세서에 의해 실행될 때, 상기 프로세서로 하여금 제1항 내지 제3항 중 어느 한 항의 인코딩 방법을 수행하게 하는 인코딩 장치. - 옥트리의 옥턴트들의 삼차원 컬러 탐색표를 디코딩하기 위한 디코딩 장치로서,
프로그램 명령어들을 저장하도록 구성된 메모리, 및
상기 메모리에 결합되고 상기 프로그램 명령어들을 실행하도록 구성된 프로세서
를 포함하고,
상기 프로그램 명령어들은, 상기 프로세서에 의해 실행될 때, 상기 프로세서로 하여금 제5항 내지 제7항 중 어느 한 항의 디코딩 방법을 수행하게 하는 디코딩 장치.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020237040475A KR102729537B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
Applications Claiming Priority (8)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP13305453 | 2013-04-08 | ||
EP13305453.6 | 2013-04-08 | ||
EP13306010.3 | 2013-07-15 | ||
EP13306010 | 2013-07-15 | ||
EP14305109.2 | 2014-01-27 | ||
EP14305109 | 2014-01-27 | ||
PCT/EP2014/055333 WO2014166705A1 (en) | 2013-04-08 | 2014-03-17 | Method for encoding and method for decoding a lut and corresponding devices |
KR1020227005666A KR102481406B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020227005666A Division KR102481406B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020237040475A Division KR102729537B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20230006598A KR20230006598A (ko) | 2023-01-10 |
KR102607327B1 true KR102607327B1 (ko) | 2023-11-29 |
Family
ID=50349595
Family Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020227005666A KR102481406B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
KR1020157031727A KR102257783B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
KR1020217015575A KR102366842B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
KR1020227045016A KR102607327B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
Family Applications Before (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020227005666A KR102481406B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
KR1020157031727A KR102257783B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
KR1020217015575A KR102366842B1 (ko) | 2013-04-08 | 2014-03-17 | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 |
Country Status (25)
Country | Link |
---|---|
US (4) | US10097857B2 (ko) |
EP (2) | EP2984836B1 (ko) |
JP (4) | JP6353896B2 (ko) |
KR (4) | KR102481406B1 (ko) |
CN (4) | CN105230019B (ko) |
AU (4) | AU2014253414B2 (ko) |
BR (2) | BR112015025623B1 (ko) |
CA (1) | CA2909006C (ko) |
DK (1) | DK2984836T3 (ko) |
ES (1) | ES2983458T3 (ko) |
FI (1) | FI2984836T3 (ko) |
HK (2) | HK1219826A1 (ko) |
HR (1) | HRP20240953T1 (ko) |
HU (1) | HUE067556T2 (ko) |
IL (3) | IL272813B (ko) |
LT (1) | LT2984836T (ko) |
MX (2) | MX359650B (ko) |
PH (1) | PH12015502212A1 (ko) |
PL (1) | PL2984836T3 (ko) |
RS (1) | RS65827B1 (ko) |
RU (1) | RU2667723C2 (ko) |
SG (2) | SG11201507826TA (ko) |
SI (1) | SI2984836T1 (ko) |
WO (1) | WO2014166705A1 (ko) |
ZA (4) | ZA201507365B (ko) |
Families Citing this family (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
HRP20240953T1 (hr) | 2013-04-08 | 2024-10-25 | Dolby International Ab | Metoda kodiranja i metoda dekodiranja lut i odgovarajući uređaji |
TWI676389B (zh) | 2013-07-15 | 2019-11-01 | 美商內數位Vc專利控股股份有限公司 | 至少一種色彩轉換之編碼方法和編碼器、解碼器、顯示裝置、編碼視訊訊號、電腦程式製品及處理器可讀式媒體 |
JP6449892B2 (ja) | 2013-09-20 | 2019-01-09 | ヴィド スケール インコーポレイテッド | 3dルックアップテーブル符号化に色域スケーラビリティを提供するシステムおよび方法 |
WO2015089352A1 (en) | 2013-12-13 | 2015-06-18 | Vid Scale, Inc | Color gamut scalable video coding device and method for the phase alignment of luma and chroma using interpolation |
MX2016012130A (es) | 2014-03-19 | 2017-04-27 | Arris Entpr Inc | Codificacion escalable de secuencias de video utilizando mapeo de tonos y diferentes gamas de colores. |
US10104385B2 (en) * | 2014-04-17 | 2018-10-16 | Qualcomm Incorporated | Signaling reference layers for 3D color prediction for color gamut scalability |
CN106664410B (zh) * | 2014-06-19 | 2019-12-03 | Vid拓展公司 | 用于基于三维色彩映射模型参数优化的系统和方法 |
EP3010231A1 (en) | 2014-10-17 | 2016-04-20 | Thomson Licensing | Method for color mapping a video signal based on color mapping data and method of encoding a video signal and color mapping data and corresponding devices |
EP3131296A1 (en) * | 2015-08-13 | 2017-02-15 | Thomson Licensing | Color remapping information payload size compression |
US10462439B2 (en) | 2015-10-02 | 2019-10-29 | Vid Scale, Inc. | Color correction with a lookup table |
US10424269B2 (en) | 2016-12-22 | 2019-09-24 | Ati Technologies Ulc | Flexible addressing for a three dimensional (3-D) look up table (LUT) used for gamut mapping |
US10395423B2 (en) * | 2016-12-29 | 2019-08-27 | Intel Corporation | Apparatus and method for rendering adaptive mesh refinement (AMR) data |
US10242647B2 (en) * | 2017-02-24 | 2019-03-26 | Ati Technologies Ulc | Three dimensional (3-D) look up table (LUT) used for gamut mapping in floating point format |
US10453171B2 (en) | 2017-03-24 | 2019-10-22 | Ati Technologies Ulc | Multiple stage memory loading for a three-dimensional look up table used for gamut mapping |
US11252401B2 (en) | 2017-08-07 | 2022-02-15 | Dolby Laboratories Licensing Corporation | Optically communicating display metadata |
WO2020147021A1 (zh) * | 2019-01-15 | 2020-07-23 | 深圳市大疆创新科技有限公司 | 三维数据点的编解码方法和装置 |
WO2020248144A1 (zh) * | 2019-06-11 | 2020-12-17 | 深圳市大疆创新科技有限公司 | 三维数据点的编解码方法和装置 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5049986A (en) | 1988-10-27 | 1991-09-17 | International Business Machines Corporation | Method and apparatus for color image quantization |
US20060268297A1 (en) | 2005-05-25 | 2006-11-30 | Lexmark International, Inc. | Method for constructing a lookup table for converting data from a first color space to a second color space |
US20130034166A1 (en) * | 2010-04-08 | 2013-02-07 | Taichiro Shiodera | Image encoding method and image decoding method |
Family Cites Families (57)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS58160082A (ja) | 1982-03-17 | 1983-09-22 | アイダエンジニアリング株式会社 | プレス加工素材の搬送装置 |
US4694404A (en) | 1984-01-12 | 1987-09-15 | Key Bank N.A. | High-speed image generation of complex solid objects using octree encoding |
JPH0326069Y2 (ko) | 1986-09-29 | 1991-06-05 | ||
US5031050A (en) | 1990-02-26 | 1991-07-09 | Hewlett-Packard Company | Method and system for reproducing monochromatic and color images using ordered dither and error diffusion |
JP2582999B2 (ja) | 1992-07-22 | 1997-02-19 | インターナショナル・ビジネス・マシーンズ・コーポレイション | カラーパレット発生方法、装置及びデータ処理システム並びにルックアップテーブル入力発生方法 |
US6002795A (en) * | 1993-10-14 | 1999-12-14 | Electronics For Imaging, Inc. | Method and apparatus for transforming a source image to an output image |
US5748176A (en) * | 1995-07-20 | 1998-05-05 | Hewlett-Packard Company | Multi-variable colorimetric data access by iterative interpolation and subdivision |
US5717507A (en) | 1996-08-02 | 1998-02-10 | Hewlett-Packard Company | Apparatus for generating interpolator input data |
US5953506A (en) * | 1996-12-17 | 1999-09-14 | Adaptive Media Technologies | Method and apparatus that provides a scalable media delivery system |
US6281903B1 (en) * | 1998-12-04 | 2001-08-28 | International Business Machines Corporation | Methods and apparatus for embedding 2D image content into 3D models |
US6483518B1 (en) * | 1999-08-06 | 2002-11-19 | Mitsubishi Electric Research Laboratories, Inc. | Representing a color gamut with a hierarchical distance field |
US6567081B1 (en) | 2000-01-21 | 2003-05-20 | Microsoft Corporation | Methods and arrangements for compressing image-based rendering (IBR) data using alignment and 3D wavelet transform techniques |
JP2003018602A (ja) | 2001-04-24 | 2003-01-17 | Monolith Co Ltd | 画像データ符号化および復号のための方法および装置 |
US7265870B2 (en) * | 2001-11-26 | 2007-09-04 | Agfa Graphics Nv | Colour separation method |
KR100446635B1 (ko) * | 2001-11-27 | 2004-09-04 | 삼성전자주식회사 | 깊이 이미지 기반 3차원 객체 표현 장치 및 방법 |
JP3957620B2 (ja) * | 2001-11-27 | 2007-08-15 | 三星電子株式会社 | 深さイメージ基盤3次元客体を表現するための装置及び方法 |
JP2004005373A (ja) | 2001-11-27 | 2004-01-08 | Samsung Electronics Co Ltd | 深さイメージに基づく3次元物体を表現するためのノード構造 |
US7002571B2 (en) | 2002-06-04 | 2006-02-21 | Intel Corporation | Grid-based loose octree for spatial partitioning |
EP1431919B1 (en) | 2002-12-05 | 2010-03-03 | Samsung Electronics Co., Ltd. | Method and apparatus for encoding and decoding three-dimensional object data by using octrees |
JP2004208128A (ja) | 2002-12-26 | 2004-07-22 | Fuji Xerox Co Ltd | データ変換方法およびデータ変換装置 |
US7719563B2 (en) * | 2003-12-11 | 2010-05-18 | Angus Richards | VTV system |
KR100695142B1 (ko) | 2004-03-08 | 2007-03-14 | 삼성전자주식회사 | 적응적 2의 n 제곱 진트리 생성방법 및 이를 이용한 3차원 체적 데이터 부호화/복호화 방법 및 장치 |
EP1574996A3 (en) * | 2004-03-08 | 2007-03-21 | Samsung Electronics Co., Ltd. | Adaptive 2n-ary tree generating method, and method and apparatus for encoding and decoding 3D volume data using it |
EP1745439B1 (en) * | 2004-04-21 | 2009-11-04 | Slipstream Data, Inc. | Method, system and software product for color image encoding |
US20060017720A1 (en) * | 2004-07-15 | 2006-01-26 | Li You F | System and method for 3D measurement and surface reconstruction |
DE102004049156B4 (de) | 2004-10-08 | 2006-07-13 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Codierschema für einen ein zeitlich veränderliches Graphikmodell darstellenden Datenstrom |
US7599439B2 (en) * | 2005-06-24 | 2009-10-06 | Silicon Image, Inc. | Method and system for transmitting N-bit video data over a serial link |
KR100763196B1 (ko) | 2005-10-19 | 2007-10-04 | 삼성전자주식회사 | 어떤 계층의 플래그를 계층간의 연관성을 이용하여부호화하는 방법, 상기 부호화된 플래그를 복호화하는방법, 및 장치 |
EP1989926B1 (en) * | 2006-03-01 | 2020-07-08 | Lancaster University Business Enterprises Limited | Method and apparatus for signal presentation |
WO2007116551A1 (ja) | 2006-03-30 | 2007-10-18 | Kabushiki Kaisha Toshiba | 画像符号化装置及び画像符号化方法並びに画像復号化装置及び画像復号化方法 |
US20070247647A1 (en) * | 2006-04-21 | 2007-10-25 | Daniel Pettigrew | 3D lut techniques for color correcting images |
DE102006061325B4 (de) | 2006-12-22 | 2008-11-13 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Verfahren zur computergestützten Identifikation der von einem Richtstrahl durchschnittenen Kinderoktanten eines Elternoktants in einer Octree-Datenstruktur mittels Look-up-Tabellen |
JP4996501B2 (ja) | 2007-04-06 | 2012-08-08 | キヤノン株式会社 | 多次元データの符号化装置及び復号装置並びにその制御方法 |
KR100927601B1 (ko) * | 2007-04-19 | 2009-11-23 | 한국전자통신연구원 | 3차원 메쉬 정보의 부호화/복호화 방법 및 장치 |
EP2051527A1 (en) * | 2007-10-15 | 2009-04-22 | Thomson Licensing | Enhancement layer residual prediction for bit depth scalability using hierarchical LUTs |
KR100940283B1 (ko) | 2008-01-31 | 2010-02-05 | 성균관대학교산학협력단 | 동일해상도의 옥트리 구조에서의 인접한 이웃셀의 주소검색방법 |
US8169434B2 (en) * | 2008-09-29 | 2012-05-01 | Microsoft Corporation | Octree construction on graphics processing units |
MX2010002097A (es) * | 2008-09-30 | 2010-08-02 | Panasonic Corp | Medio de grabacion, dispositivo de reproduccion, integracion a gran escala de sistema, metodo de reproduccion, lentes y dispositivo visual para imagenes 3d. |
US8233705B2 (en) * | 2008-10-03 | 2012-07-31 | Eastman Kodak Company | Potential field-based gamut mapping |
GB0823701D0 (en) * | 2008-12-31 | 2009-02-04 | Symbian Software Ltd | Fast data entry |
JP2010251940A (ja) | 2009-04-14 | 2010-11-04 | Seiko Epson Corp | 画像処理装置、画像処理方法、およびプログラム |
RU2447607C1 (ru) | 2009-10-19 | 2012-04-10 | Кэнон Кабусики Кайся | Устройство обработки изображения, способ регулировки и машиночитаемый носитель |
JP5505154B2 (ja) * | 2010-07-16 | 2014-05-28 | ソニー株式会社 | 画像処理装置と画像処理方法 |
US9131033B2 (en) * | 2010-07-20 | 2015-09-08 | Qualcomm Incoporated | Providing sequence data sets for streaming video data |
ES2761891T3 (es) * | 2010-07-21 | 2020-05-21 | Ericsson Telefon Ab L M | Codificación y decodificación de imagen |
US8467629B2 (en) * | 2010-08-12 | 2013-06-18 | High Technology Video, Inc. | Methods and systems for automatic coloring of digital images |
JP6081360B2 (ja) | 2010-09-16 | 2017-02-15 | コーニンクレッカ フィリップス エヌ ヴェKoninklijke Philips N.V. | 改善された画像の符号化及び/又は復号のための装置、方法並びに画像データ記憶媒体 |
US9008175B2 (en) | 2010-10-01 | 2015-04-14 | Qualcomm Incorporated | Intra smoothing filter for video coding |
CN102592293A (zh) | 2011-01-07 | 2012-07-18 | 北京四维图新科技股份有限公司 | 一种真彩色图像的降色方法及装置 |
US9154799B2 (en) * | 2011-04-07 | 2015-10-06 | Google Inc. | Encoding and decoding motion via image segmentation |
KR20140018919A (ko) * | 2011-04-12 | 2014-02-13 | 톰슨 라이센싱 | 메시 모델을 인코딩하는 방법, 인코딩된 메시 모델 및 메시 모델을 디코딩하는 방법 |
US8804816B2 (en) * | 2011-08-30 | 2014-08-12 | Microsoft Corporation | Video encoding enhancements |
MY176011A (en) * | 2011-12-15 | 2020-07-21 | Tagivan Ii Llc | Image coding method, image decoding method, image coding apparatus, image decoding apparatus, and image coding and decoding apparatus |
HRP20240953T1 (hr) * | 2013-04-08 | 2024-10-25 | Dolby International Ab | Metoda kodiranja i metoda dekodiranja lut i odgovarajući uređaji |
US9367807B2 (en) * | 2013-04-29 | 2016-06-14 | Vulcan, Inc. | Method and system that provides efficient index-based retrieval of rules |
US10003805B2 (en) * | 2013-07-01 | 2018-06-19 | Samsung Electronics Co., Ltd. | Video encoding and decoding method accompanied with filtering, and device thereof |
JP6449892B2 (ja) * | 2013-09-20 | 2019-01-09 | ヴィド スケール インコーポレイテッド | 3dルックアップテーブル符号化に色域スケーラビリティを提供するシステムおよび方法 |
-
2014
- 2014-03-17 HR HRP20240953TT patent/HRP20240953T1/hr unknown
- 2014-03-17 US US14/783,062 patent/US10097857B2/en active Active
- 2014-03-17 JP JP2016506828A patent/JP6353896B2/ja active Active
- 2014-03-17 EP EP14712249.3A patent/EP2984836B1/en active Active
- 2014-03-17 KR KR1020227005666A patent/KR102481406B1/ko active IP Right Grant
- 2014-03-17 DK DK14712249.3T patent/DK2984836T3/da active
- 2014-03-17 BR BR112015025623-6A patent/BR112015025623B1/pt active IP Right Grant
- 2014-03-17 BR BR122020017670-9A patent/BR122020017670B1/pt active IP Right Grant
- 2014-03-17 LT LTEPPCT/EP2014/055333T patent/LT2984836T/lt unknown
- 2014-03-17 CN CN201480026132.XA patent/CN105230019B/zh active Active
- 2014-03-17 WO PCT/EP2014/055333 patent/WO2014166705A1/en active Application Filing
- 2014-03-17 KR KR1020157031727A patent/KR102257783B1/ko active IP Right Grant
- 2014-03-17 KR KR1020217015575A patent/KR102366842B1/ko active IP Right Grant
- 2014-03-17 HU HUE14712249A patent/HUE067556T2/hu unknown
- 2014-03-17 FI FIEP14712249.3T patent/FI2984836T3/fi active
- 2014-03-17 SI SI201432091T patent/SI2984836T1/sl unknown
- 2014-03-17 MX MX2015014074A patent/MX359650B/es active IP Right Grant
- 2014-03-17 SG SG11201507826TA patent/SG11201507826TA/en unknown
- 2014-03-17 RU RU2015147556A patent/RU2667723C2/ru active
- 2014-03-17 CN CN201910205554.8A patent/CN109922345B/zh active Active
- 2014-03-17 PL PL14712249.3T patent/PL2984836T3/pl unknown
- 2014-03-17 RS RS20240783A patent/RS65827B1/sr unknown
- 2014-03-17 ES ES14712249T patent/ES2983458T3/es active Active
- 2014-03-17 AU AU2014253414A patent/AU2014253414B2/en active Active
- 2014-03-17 SG SG10201803221XA patent/SG10201803221XA/en unknown
- 2014-03-17 CN CN201910205555.2A patent/CN109951714B/zh active Active
- 2014-03-17 KR KR1020227045016A patent/KR102607327B1/ko active IP Right Grant
- 2014-03-17 CA CA2909006A patent/CA2909006C/en active Active
- 2014-03-17 CN CN201910205556.7A patent/CN109951712B/zh active Active
- 2014-03-17 EP EP23192629.6A patent/EP4254954A3/en active Pending
- 2014-03-17 IL IL272813A patent/IL272813B/en unknown
-
2015
- 2015-09-21 IL IL241789A patent/IL241789B/en active IP Right Grant
- 2015-09-22 PH PH12015502212A patent/PH12015502212A1/en unknown
- 2015-10-05 ZA ZA2015/07365A patent/ZA201507365B/en unknown
- 2015-10-06 MX MX2018012138A patent/MX2018012138A/es unknown
-
2016
- 2016-06-30 HK HK16107652.6A patent/HK1219826A1/zh unknown
- 2016-07-21 HK HK16108746.2A patent/HK1220840A1/zh unknown
-
2018
- 2018-06-11 JP JP2018111122A patent/JP2018157595A/ja active Pending
- 2018-09-10 US US16/126,764 patent/US10694209B2/en active Active
- 2018-09-28 ZA ZA2018/06464A patent/ZA201806464B/en unknown
- 2018-10-11 AU AU2018247264A patent/AU2018247264B2/en active Active
-
2019
- 2019-07-10 IL IL267963A patent/IL267963B/en active IP Right Grant
-
2020
- 2020-02-10 US US16/786,111 patent/US11153605B2/en active Active
- 2020-02-27 JP JP2020031455A patent/JP6957664B2/ja active Active
-
2021
- 2021-01-15 AU AU2021200241A patent/AU2021200241B2/en active Active
- 2021-09-20 ZA ZA2021/06976A patent/ZA202106976B/en unknown
- 2021-09-20 US US17/448,089 patent/US12034971B2/en active Active
- 2021-10-06 JP JP2021164377A patent/JP7233501B2/ja active Active
- 2021-11-30 ZA ZA2021/09771A patent/ZA202109771B/en unknown
-
2023
- 2023-02-23 AU AU2023201060A patent/AU2023201060A1/en active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5049986A (en) | 1988-10-27 | 1991-09-17 | International Business Machines Corporation | Method and apparatus for color image quantization |
US20060268297A1 (en) | 2005-05-25 | 2006-11-30 | Lexmark International, Inc. | Method for constructing a lookup table for converting data from a first color space to a second color space |
US20130034166A1 (en) * | 2010-04-08 | 2013-02-07 | Taichiro Shiodera | Image encoding method and image decoding method |
Non-Patent Citations (1)
Title |
---|
Philippe Bordes et al., "AHG14: Color Gamut Scalable Video Coding using 3D LUT", (JCTVC-M0197), JCT-VC of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11 13th Meeting: Incheon, KR, (2013.04.08) |
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP7233501B2 (ja) | ルックアップ・テーブルを符号化する方法および復号する方法、並びに対応する装置 | |
KR102590322B1 (ko) | 컬러 변환을 인코딩하는 방법 및 디코딩하는 방법 및 대응하는 디바이스들 | |
KR102729537B1 (ko) | Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들 | |
RU2772897C2 (ru) | Способ кодирования и способ декодирования lut и соответствующие устройства |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A107 | Divisional application of patent | ||
E701 | Decision to grant or registration of patent right |