영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체

07-03-2025 дата публикации
Номер:
KR20250033040A
Контакты:
Номер заявки: 01-24-102015799
Дата заявки: 28-08-2024

[0001]

본 발명은 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체에 관한 것이다. 구체적으로, 본 발명은 다양한 인트라 예측 모드 후보들을 기초로 한 템플릿 기반 인트라 예측 모드 유도(template-based intra mode derivation, TIMD) 방법을 이용하는 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체에 관한 것이다.

[0002]

최근 UHD(Ultra High Definition) 영상과 같은 고해상도, 고품질의 영상에 대한 수요가 다양한 응용 분야에서 증가하고 있다. 영상 데이터가 고해상도, 고품질이 될수록 기존의 영상 데이터에 비해 상대적으로 데이터량이 증가하기 때문에 기존의 유무선 광대역 회선과 같은 매체를 이용하여 영상 데이터를 전송하거나 기존의 저장 매체를 이용해 저장하는 경우, 전송 비용과 저장 비용이 증가하게 된다. 영상 데이터가 고해상도, 고품질화 됨에 따라 발생하는 이러한 문제들을 해결하기 위해서는 더 높은 해상도 및 화질을 갖는 영상에 대한 고효율 영상 부호화(encoding)/복호화(decoding) 기술이 요구된다.

[0003]

영상 부호화/복호화 기술에 사용되는 템플릿 기반 인트라 예측 모드 유도(template-based intra mode derivation, TIMD)는 예측 신호를 생성하기 위해 임의의 방향성(angular)/비방향성(non-angular) 인트라 예측 후보 모드들에 대해 템플릿(template)을 분석하는 인트라 예측 방법이다.

[0004]

TIMD 방법에 따르면, 예측 품질을 향상시킬 수 있는 다른 인트라 예측 모드들을 고려하지 아니하고, 정규(regular) 인트라 예측 모드에 대한 템플릿만이 분석될 수 있다. 따라서, 정규 인트라 예측 모드 이외의 인트라 예측 모드들을 고려하도록 TIMD의 인트라 예측 후보 모드를 확장하여, 예측 품질을 향상시키고, 코딩 성능을 향상시키는 방법이 필요하다.

[0005]

본 발명은 부호화/복호화 효율이 향상된 영상 부호화/복호화 방법 및 장치를 제공하는 것을 목적으로 한다.

[0006]

또한, 본 발명에 따른 영상 복호화 방법 또는 장치에 의해 생성된 비트스트림을 저장한 기록 매체를 제공하는 것을 목적으로 한다.

[0007]

또한, 본 발명은 위와 같은 문제점을 해결하기 위해 템플릿 기반 인트라 예측 모드 유도(template-based intra mode derivation, TIMD)의 인트라 예측 후보 모드를 확장하여 예측 블록을 생성하는 방법을 제공하는 것을 목적으로 한다.

[0008]

본 발명의 일 실시예에 따른 영상 복호화 방법은, 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계, 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계, 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계, 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계, 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계, 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 할 수 있다.

[0009]

상기 영상 복호화 방법에 있어서, 상기 소정의 인트라 예측 모드는, 하나의 비방향성 인트라 예측 모드일 수 있다.

[0010]

상기 영상 복호화 방법에 있어서, 상기 제1 인트라 예측 모드는 인트라 템플릿 매칭 예측 모드(intra template matching prediction mode, IntraTMP)인 것을 특징으로 할 수 있다.

[0011]

상기 영상 복호화 방법에 있어서, 상기 제1 예측 블록에 적용되는 가중치는, 상기 인트라 템플릿 매칭 예측 모드를 기초로 예측된 상기 현재 템플릿의 비용 값을 기초로 결정될 수 있다.

[0012]

상기 영상 복호화 방법에 있어서, 상기 현재 블록의 최종 예측 블록을 유도하는 단계는 상기 인트라 템플릿 매칭 예측 모드를 기초로 예측된 상기 현재 템플릿의 비용 값과 상기 제2 인트라 예측 모드를 기초로 유도된 예측된 상기 현재 템플릿의 비용 값의 비교 결과를 기초로, 상기 제1 예측 블록과 상기 제2 예측 블록을 가중 합할 수 있다.

[0013]

상기 영상 복호화 방법에 있어서, 상기 현재 블록의 블록 벡터의 정밀도는 인트라 템플릿 매칭 예측 모드의 블록 벡터의 정밀도를 지시하는 정보를 기초로 결정될 수 있다.

[0014]

상기 영상 복호화 방법에 있어서, 상기 인트라 템플릿 매칭 예측 모드의 블록 벡터의 정밀도를 지시하는 정보는 TIMD에 관한 정보에 종속적으로 시그널링될 수 있다.

[0015]

상기 영상 복호화 방법에 있어서, 상기 제1 인트라 예측 모드는 인트라 블록 복사(intra block copy, IBC)인 것을 특징으로 할 수 있다.

[0016]

상기 영상 복호화 방법에 있어서, 상기 제1 예측 블록에 적용되는 가중치는, 상기 인트라 블록 복사를 기반으로 예측된 상기 현재 템플릿의 비용 값을 기초로 결정될 수 있다.

[0017]

상기 영상 복호화 방법에 있어서, 상기 현재 블록의 최종 예측 블록을 유도하는 단계는 상기 인트라 블록 복사를 기반으로 예측된 상기 현재 템플릿의 비용 값과 상기 제2 인트라 예측 모드를 기초로 유도된 예측된 상기 현재 템플릿의 비용 값의 비교 결과를 기초로, 상기 제1 예측 블록과 상기 제2 예측 블록을 가중 합할 수 있다.

[0018]

상기 영상 복호화 방법에 있어서, 상기 현재 블록의 블록 벡터의 정밀도는 인트라 블록 복사에 사용되는 블록 벡터의 정밀도를 지시하는 정보를 기초로 결정될 수 있다.

[0019]

상기 영상 복호화 방법에 있어서, 상기 인트라 블록 복사에 사용되는 블록 벡터의 정밀도를 지시하는 정보는 TIMD에 관한 정보에 종속적으로 시그널링될 수 있다.

[0020]

상기 영상 복호화 방법에 있어서, 상기 복수의 후보 인트라 예측 모드는, 서로 다른 인트라 예측 모드를 이용하는 공간적 결합된 인트라-인트라 예측(spatial combined intra-intra prediction, SCIIP) 모드를 포함하고 상기 제1 인트라 예측 모드는 상기 SCIIP 모드인 것을 특징으로 할 수 있다.

[0021]

상기 영상 복호화 방법에 있어서, 상기 제1 예측 블록에 적용되는 가중치는 상기 SCIIP 모드를 기초로 예측된 상기 현재 템플릿의 비용 값을 기초로 결정될 수 있다.

[0022]

상기 영상 복호화 방법에 있어서, 상기 현재 블록의 최종 예측 블록을 유도하는 단계는 상기 SCIIP 모드를 기초로 예측된 상기 현재 템플릿의 비용 값과 상기 제2 인트라 예측 모드를 기초로 유도된 예측된 상기 현재 템플릿의 비용 값의 비교 결과를 기초로, 상기 제1 예측 블록과 상기 제2 예측 블록을 가중 합할 수 있다.

[0023]

상기 영상 복호화 방법에 있어서, 상기 제1 인트라 예측 모드는 상기 SCIIP 모드를 지시하는 정보에 기초하여, 상기 SCIIP 모드로 결정되고 상기 SCIIP 모드를 지시하는 정보는 인트라 템플릿 매칭 예측에 관한 정보에 종속적으로 시그널링될 수 있다.

[0024]

본 발명의 일 실시예에 따른 영상 부호화 방법은, 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계, 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계, 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계, 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계, 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계, 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 할 수 있다.

[0025]

본 발명의 일 실시예에 따른 비 일시적 컴퓨터 판독가능한 기록 매체는, 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계, 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계, 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계, 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계, 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계, 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 하는, 영상 부호화 방법에 의해 생성된 비트스트림을 저장할 수 있다.

[0026]

본 발명의 일 실시예에 따른 전송 방법은, 비트스트림을 전송하는 단계를 포함하고, 상기 부호화 방법은, 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계, 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계, 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계, 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계, 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계, 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 할 수 있다.

[0027]

본 개시에 대하여 위에서 간략하게 요약된 특징들은 후술하는 본 개시의 상세한 설명의 예시적인 양상일 뿐이며, 본 개시의 범위를 제한하는 것은 아니다.

[0028]

본 발명에 따르면, 부호화/복호화 효율이 향상된 영상 부호화/복호화 방법 및 장치가 제공될 수 있다.

[0029]

또한, 본 발명에 따르면, 다양한 인트라 예측 후보 모드들을 이용한 템플릿 기반 인트라 예측 모드 유도(template-based intra mode derivation, TIMD) 방법을 기초로 예측 블록을 생성하는 방법이 제공될 수 있다.

[0030]

본 개시에서 얻을 수 있는 효과는 이상에서 언급한 효과들로 제한되지 않으며, 언급하지 않은 또 다른 효과들은 아래의 기재로부터 본 개시가 속하는 기술분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다.

[0031]

도 1은 본 발명이 적용되는 부호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다. 도 2는 본 발명이 적용되는 복호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다. 도 3은 본 발명이 적용될 수 있는 비디오 코딩 시스템을 개략적으로 나타내는 도면이다. 도 4는 본 발명의 일 실시 예에 따른 템플릿 기반 인트라 예측 모드 유도 방법을 설명하기 위한 도면이다. 도 5는 본 발명의 일 실시 예에 따른 인트라 템플릿 매칭 예측을 설명하기 위한 도면이다. 도 6은 본 발명의 일 실시 예에 따른 인트라 블록 복사 기반 예측 방법을 설명하기 위한 도면이다. 도 7은 본 발명의 일 실시 예에 따른 공간적 결합된 인트라-인트라 예측 방법을 설명하기 위한 도면이다. 도 8은 본 발명의 일 실시 예에 따른 영상 복호화 방법을 나타내는 흐름도이다. 도 9는 본 발명에 따른 실시예가 적용될 수 있는 컨텐츠 스트리밍 시스템을 예시적으로 나타내는 도면이다.

[0032]

본 발명은 다양한 변경을 가할 수 있고 여러 가지 실시예를 가질 수 있는 바, 특정 실시예들을 도면에 예시하고 상세한 설명에 상세하게 설명하고자 한다. 그러나, 이는 본 발명을 특정한 실시 형태에 대해 한정하려는 것이 아니며, 본 발명의 사상 및 기술 범위에 포함되는 모든 변경, 균등물 내지 대체물을 포함하는 것으로 이해되어야 한다. 도면에서 유사한 참조부호는 여러 측면에 걸쳐서 동일하거나 유사한 기능을 지칭한다. 도면에서의 요소들의 형상 및 크기 등은 보다 명확한 설명을 위해 예시적으로 제공될 수 있다. 후술하는 예시적 실시예들에 대한 상세한 설명은, 특정 실시예를 예시로서 도시하는 첨부 도면을 참조한다. 이들 실시예는 당업자가 실시예를 실시할 수 있기에 충분하도록 상세히 설명된다. 다양한 실시예들은 서로 다르지만 상호 배타적일 필요는 없음이 이해되어야 한다. 예를 들어, 여기에 기재되어 있는 특정 형상, 구조 및 특성은 일 실시예에 관련하여 본 발명의 정신 및 범위를 벗어나지 않으면서 다른 실시예로 구현될 수 있다. 또한, 각각의 개시된 실시예 내의 개별 구성요소의 위치 또는 배치는 실시예의 정신 및 범위를 벗어나지 않으면서 변경될 수 있음이 이해되어야 한다. 따라서, 후술하는 상세한 설명은 한정적인 의미로서 취하려는 것이 아니며, 예시적 실시예들의 범위는, 적절하게 설명된다면, 그 청구항들이 주장하는 것과 균등한 모든 범위와 더불어 첨부된 청구항에 의해서만 한정된다.

[0033]

본 발명에서 제1, 제2 등의 용어는 다양한 구성요소들을 설명하는데 사용될 수 있지만, 상기 구성요소들은 상기 용어들에 의해 한정되어서는 안 된다. 상기 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용된다. 예를 들어, 본 발명의 권리 범위를 벗어나지 않으면서 제1 구성요소는 제2 구성요소로 명명될 수 있고, 유사하게 제2 구성요소도 제1 구성요소로 명명될 수 있다. 및/또는 이라는 용어는 복수의 관련된 기재된 항목들의 조합 또는 복수의 관련된 기재된 항목들 중의 어느 항목을 포함한다.

[0034]

본 발명의 실시예에 나타나는 구성부들은 서로 다른 특징적인 기능들을 나타내기 위해 독립적으로 도시되는 것으로, 각 구성부들이 분리된 하드웨어나 하나의 소프트웨어 구성단위로 이루어짐을 의미하지 않는다. 즉, 각 구성부는 설명의 편의상 각각의 구성부로 나열하여 포함한 것으로 각 구성부 중 적어도 두 개의 구성부가 합쳐져 하나의 구성부로 이루어지거나, 하나의 구성부가 복수 개의 구성부로 나뉘어져 기능을 수행할 수 있고 이러한 각 구성부의 통합된 실시예 및 분리된 실시예도 본 발명의 본질에서 벗어나지 않는 한 본 발명의 권리범위에 포함된다.

[0035]

본 발명에서 사용한 용어는 단지 특정한 실시예를 설명하기 위해 사용된 것으로, 본 발명을 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 또한, 본 발명의 일부의 구성 요소는 본 발명에서 본질적인 기능을 수행하는 필수적인 구성 요소는 아니고 단지 성능을 향상시키기 위한 선택적 구성 요소일 수 있다. 본 발명은 단지 성능 향상을 위해 사용되는 구성 요소를 제외한 본 발명의 본질을 구현하는데 필수적인 구성부만을 포함하여 구현될 수 있고, 단지 성능 향상을 위해 사용되는 선택적 구성 요소를 제외한 필수 구성 요소만을 포함한 구조도 본 발명의 권리범위에 포함된다.

[0036]

실시예에서 용어 "적어도 하나(at least one)"는 1, 2, 3 및 4와 같은 1 이상의 개수들 중 하나를 의미할 수 있다. 실시예에서 용어 "복수(a plurality of)"는 2, 3 및 4와 같은 2 이상의 개수들 중 하나를 의미할 수 있다.

[0037]

이하, 도면을 참조하여 본 발명의 실시 형태에 대하여 구체적으로 설명한다. 본 명세서의 실시예를 설명함에 있어, 관련된 공지 구성 또는 기능에 대한 구체적인 설명이 본 명세서의 요지를 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명은 생략하고, 도면상의 동일한 구성요소에 대해서는 동일한 참조부호를 사용하고 동일한 구성요소에 대해서 중복된 설명은 생략한다.

[0038]

용어 설명

[0039]

이하에서, “영상”은 동영상(video)을 구성하는 하나의 픽처(picture)를 의미할 수 있으며, 동영상 자체를 나타낼 수도 있다. 예를 들면, "영상의 부호화 및/또는 복호화"는 "동영상의 부호화 및/또는 복호화"를 의미할 수 있으며, "동영상을 구성하는 영상들 중 하나의 영상의 부호화 및/또는 복호화"를 의미할 수도 있다.

[0040]

이하에서, "동영상" 및 "비디오"는 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다. 또한, 대상 영상은 부호화의 대상인 부호화 대상 영상 및/또는 복호화의 대상인 복호화 대상 영상일 수 있다. 또한, 대상 영상은 부호화 장치로 입력된 입력 영상일 수 있고, 복호화 장치로 입력된 입력 영상일 수 있다. 여기서, 대상 영상은 현재 영상과 동일한 의미를 가질 수 있다.

[0041]

이하에서, 부호화기 및 영상 부호화 장치는 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.

[0042]

이하에서, 복호화기 및 영상 복호화 장치는 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.

[0043]

이하에서, "영상(image)", "픽처(picture)", "프레임(frame)" 및 "스크린(screen)"은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.

[0044]

이하에서, “대상 블록”은 부호화의 대상인 부호화 대상 블록 및/또는 복호화의 대상인 복호화 대상 블록일 수 있다. 또한, 대상 블록은 현재 부호화 및/또는 복호화의 대상인 현재 블록일 수 있다. 예를 들면, "대상 블록" 및 "현재 블록"은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.

[0045]

이하에서, "블록" 및 "유닛"은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다. 또한, “유닛”은 블록과 구분하여 지칭하기 위해 휘도(Luma) 성분 블록과 그에 대응하는 색차(Chroma) 성분 블록을 포함한 것을 의미할 수 있다. 일 예로, 부호화 트리 유닛(Coding Tree Unit, CTU)은 하나의 휘도 성분(Y) 부호화 트리 블록(Coding Tree Block, CTB)과 관련된 두 색차 성분(Cb, Cr) 부호화 트리 블록들로 구성될 수 있다.

[0046]

이하에서, “샘플”, “화소” 및 “픽셀”은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다. 여기서, 샘플은 블록을 구성하는 기본 단위를 나타낼 수 있다.

[0047]

이하에서, “인터” 및 “화면 간”은 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.

[0048]

이하에서, “인트라” 및 “화면 내”는 동일한 의미로 사용될 수 있으며, 서로 교체되어 사용될 수 있다.

[0050]

도 1은 본 발명이 적용되는 부호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다.

[0051]

부호화 장치(100)는 인코더, 비디오 부호화 장치 또는 영상 부호화 장치일 수 있다. 비디오는 하나 이상의 영상들을 포함할 수 있다. 부호화 장치(100)는 하나 이상의 영상들을 순차적으로 부호화할 수 있다.

[0052]

도 1을 참조하면, 부호화 장치(100)는 영상 분할부(110), 인트라 예측부(120), 움직임 예측부(121), 움직임 보상부(122), 스위치(115), 감산기(113), 변환부(130), 양자화부(140), 엔트로피 부호화부(150), 역양자화부(160), 역변환부(170), 가산기(117), 필터부(180) 및 참조 픽처 버퍼(190)를 포함할 수 있다.

[0053]

또한, 부호화 장치(100)는 입력 영상에 대한 부호화를 통해 부호화된 정보를 포함하는 비트스트림을 생성할 수 있고, 생성된 비트스트림을 출력할 수 있다. 생성된 비트스트림은 컴퓨터 판독가능한 기록 매체에 저장될 수 있거나, 유/무선 전송 매체를 통해 스트리밍될 수 있다.

[0054]

영상 분할부(110)는 동영상 부호화/복호화의 효율을 높이기 위해, 입력 영상을 다양한 형태로 분할할 수 있다. 즉, 입력 동영상은 다수의 픽처로 구성되어 있고 하나의 픽처는 압축 효율, 병렬처리 등을 위하여 계층적으로 분할되어 처리될 수 있다. 예를 들어, 하나의 픽처를 하나 또는 다수개의 타일(tile) 또는 슬라이스(slice)로 분할하고 다시 다수개의 CTU (Coding Tree Unit)로 분할할 수 있다. 또 다른 방식으로, 먼저 하나의 픽처를 직사각형 모양의 슬라이스의 그룹으로 정의되는 다수개의 서브픽처(sub-picture)로 분할하고, 각 서브픽처를 상기 타일/슬라이스로 분할할 수도 있다. 여기서, 서브픽처는 픽처를 부분적으로 독립 부호화/복호화 및 전송하는 기능을 지원하기 위하여 활용될 수 있다. 여러 개의 서브픽처는 각각 개별적으로 복원 가능하기에 멀티 채널 입력을 하나의 픽처로 구성하는 응용에 있어서 편집이 용이하다는 장점을 가지게 된다. 또한, 타일을 횡방향으로 분할하여 브릭(brick)을 생성할 수도 있다. 여기서, 브릭(brick)은 픽처내 병렬처리의 기본 단위로 활용할 수 있다. 또한, 하나의 CTU는 쿼드 트리(QT: Quadtree)로 재귀적으로 분할될 수 있고, 분할의 말단 노드를 CU (Coding Unit)라고 정의할 수 있다. CU는 예측 단위인 PU(Prediction Unit)와 변환 단위인 TU (Transform Unit)로 분할되어 예측과 분할이 수행될 수 있다. 한편, CU는 예측 단위 및/또는 변환 단위 그 자체로 활용할 수 있다. 여기서, 유연한 분할을 위하여 각 CTU는 쿼드 트리(QT) 뿐만 아니라 멀티타입 트리(MTT: Multi-Type Tree)로 재귀적으로 분할될 수도 있다. CTU는 QT의 말단 노드에서 멀티타입 트리로 분할이 시작될 수 있으며 MTT는 BT(Binary Tree)와 TT(Triple Tree)로 구성될 수 있다. 예를 들어, MTT구조에는 수직 이진 분할모드(SPLIT_BT_VER), 수평 이진 분할모드(SPLIT_BT_HOR), 수직 삼항 분할모드(SPLIT_TT_VER), 수평 삼항 분할모드(SPLIT_TT_HOR)로 구분될 수 있다. 또한, 분할 시 휘도 블록의 쿼드 트리의 최소 블록 크기(MinQTSize)는 16x16이고 바이너리 트리의 최대블록 크기(MaxBtSize)는 128x128, 트리플 트리의 최대 블록 크기(MaxTtSize)는 64x64로 설정할 수 있다. 또한, 바이너리 트리의 최소 블록 크기(MinBtSize)와 트리플 트리의 최소 블록 크기(MinTtSize)는 4x4, 멀티 타입 트리의 최대 깊이(MaxMttDepth)는 4로 지정할 수 있다. 또한 I 슬라이스의 부호화 효율을 높이기 위하여 휘도와 색차성분의 CTU 분할 구조를 서로 다르게 사용하는 듀얼 트리(dual tree)를 적용할 수도 있다. 반면 P와 B슬라이스에서는 CTU 내의 휘도와 색차 CTB (Coding Tree Block)들이 코딩 트리 구조를 공유하는 싱글 트리(single tree)로 분할할 수 있다.

[0055]

부호화 장치(100)는 입력 영상에 대해 인트라 모드 및/또는 인터 모드로 부호화를 수행할 수 있다. 또는, 부호화 장치(100)는 입력 영상에 대해 상기 인트라 모드 및 인터 모드가 아닌 제3의 모드 (예, IBC 모드, Palette 모드 등)로 부호화를 수행할 수도 있다. 단, 상기 제3의 모드가 인트라 모드 또는 인터 모드와 유사한 기능적 특징을 가지는 경우, 설명의 편의를 위해 인트라 모드 또는 인터 모드로 분류하기도 한다. 본 발명에서는 상기 제3의 모드에 대한 구체적인 설명이 필요한 경우에만 이를 별도로 분류하여 기술할 것이다.

[0056]

예측 모드로 인트라 모드가 사용되는 경우 스위치(115)는 인트라로 전환될 수 있고, 예측 모드로 인터 모드가 사용되는 경우 스위치(115)는 인터로 전환될 수 있다. 여기서 인트라 모드는 화면 내 예측 모드를 의미할 수 있으며, 인터 모드는 화면 간 예측 모드를 의미할 수 있다. 부호화 장치(100)는 입력 영상의 입력 블록에 대한 예측 블록을 생성할 수 있다. 또한, 부호화 장치(100)는 예측 블록이 생성된 후, 입력 블록 및 예측 블록의 차분(residual)을 사용하여 잔여 블록을 부호화할 수 있다. 입력 영상은 현재 부호화의 대상인 현재 영상으로 칭해질 수 있다. 입력 블록은 현재 부호화의 대상인 현재 블록 혹은 부호화 대상 블록으로 칭해질 수 있다.

[0057]

예측 모드가 인트라 모드인 경우, 인트라 예측부(120)는 현재 블록의 주변에 이미 부호화/복호화된 블록의 샘플을 참조 샘플로서 이용할 수 있다. 인트라 예측부(120)는 참조 샘플을 이용하여 현재 블록에 대한 공간적 예측을 수행할 수 있고, 공간적 예측을 통해 입력 블록에 대한 예측 샘플들을 생성할 수 있다. 여기서 인트라 예측은 화면 내 예측을 의미할 수 있다.

[0058]

인트라 예측 방식으로, DC 모드, Planar 모드와 같은 무방향성 예측 모드와 방향성 예측 모드 (예, 65개 방향)가 적용될 수 있다. 여기서, 인트라 예측 방식은 인트라 예측 모드 또는 화면 내 예측 모드로 표현될 수 있다.

[0059]

예측 모드가 인터 모드인 경우, 움직임 예측부(121)는, 움직임 예측 과정에서 참조 영상으로부터 입력 블록과 가장 매치가 잘 되는 영역을 검색할 수 있고, 검색된 영역을 이용하여 움직임 벡터를 도출할 수 있다. 이때, 상기 영역으로 탐색 영역을 사용할 수 있다. 참조 영상은 참조 픽처 버퍼(190)에 저장될 수 있다. 여기서, 참조 영상에 대한 부호화/복호화가 처리되었을 때 참조 픽처 버퍼(190)에 저장될 수 있다.

[0060]

움직임 보상부(122)는 움직임 벡터를 이용하는 움직임 보상을 수행함으로써 현재 블록에 대한 예측 블록을 생성할 수 있다. 여기서 인터 예측은 화면 간 예측 혹은 움직임 보상을 의미할 수 있다.

[0061]

상기 움직임 예측부(121)과 움직임 보상부(122)는 움직임 벡터의 값이 정수 값을 가지지 않을 경우에 참조 영상 내의 일부 영역에 대해 보간 필터(Interpolation Filter)를 적용하여 예측 블록을 생성할 수 있다. 화면 간 예측 혹은 움직임 보상을 수행하기 위해 부호화 유닛을 기준으로 해당 부호화 유닛에 포함된 예측 유닛의 움직임 예측 및 움직임 보상 방법이 스킵 모드(Skip Mode), 머지 모드(Merge Mode), 향상된 움직임 벡터 예측(Advanced Motion Vector Prediction; AMVP) 모드, 인트라 블록 카피(Intra Block Copy; IBC) 모드 중 어떠한 방법인지 여부를 판단할 수 있고, 각 모드에 따라 화면 간 예측 혹은 움직임 보상을 수행할 수 있다.

[0062]

또한, 상기 화면 간 예측 방법을 기초로, sub-PU 기반 예측의 AFFINE 모드, SbTMVP (Subblock-based Temporal Motion Vector Prediction) 모드, 및 PU 기반 예측의 MMVD(Merge with MVD) 모드, GPM(Geometric Partitioning Mode) 모드를 적용할 수도 있다. 또한, 각 모드의 성능 향상을 위하여 HMVP(History based MVP), PAMVP(Pairwise Average MVP), CIIP(Combined Intra/Inter Prediction), AMVR(Adaptive Motion Vector Resolution), BDOF(Bi-Directional Optical-Flow), BCW(Bi-predictive with CU Weights), LIC (Local Illumination Compensation), TM(Template Matching), OBMC(Overlapped Block Motion Compensation) 등을 적용할 수도 있다.

[0063]

이 중, AFFINE 모드는 AMVP와 MERGE 모드에서 모두 사용되고 부호화 효율 또한 높은 기술이다. 종래 동영상 코딩 표준에서는 블록의 평행이동만을 고려하여 MC(Motion Compensation)를 수행하기 때문에 줌 인/아웃(zoom in/out), 회전(rotation)과 같이 현실에서 발생하는 움직임을 제대로 보상하지 못하는 단점이 있었다. 이를 보완하여, 두 개의 컨트롤 포인트 움직임 벡터(control point motion vector, CPMV)를 사용하는 4 파라미터 어파인 움직임 모델과 세 개의 컨트롤 포인트 움직임 벡터를 사용하는 6 파라미터 어파인 움직임 모델을 사용하여 인터 예측에 적용할 수 있다. 여기서, CPMV는 현재 블록의 왼쪽 상단, 오른쪽 상단, 왼쪽 하단 중 어느 하나의 어파인 움직임 모델을 표현하는 벡터이다.

[0064]

감산기(113)는 입력 블록 및 예측 블록의 차분을 사용하여 잔여 블록을 생성할 수 있다. 잔여 블록은 잔여 신호로 칭해질 수도 있다. 잔여 신호는 원 신호 및 예측 신호 간의 차이(difference)를 의미할 수 있다. 또는, 잔여 신호는 원신호 및 예측 신호 간의 차이를 변환(transform)하거나, 양자화하거나, 또는 변환 및 양자화함으로써 생성된 신호일 수 있다. 잔여 블록은 블록 단위의 잔여 신호일 수 있다.

[0065]

변환부(130)는 잔여 블록에 대해 변환(transform)을 수행하여 변환 계수(transform coefficient)를 생성할 수 있고, 생성된 변환 계수를 출력할 수 있다. 여기서, 변환 계수는 잔여 블록에 대한 변환을 수행함으로써 생성된 계수 값일 수 있다. 변환 생략(transform skip) 모드가 적용되는 경우, 변환부(130)는 잔여 블록에 대한 변환을 생략할 수도 있다.

[0066]

변환 계수 또는 잔여 신호에 양자화를 적용함으로써 양자화된 레벨(quantized level)이 생성될 수 있다. 이하, 실시예들에서는 양자화된 레벨도 변환 계수로 칭해질 수 있다.

[0067]

일 예로, 화면내 예측을 통해 생성된 4x4 휘도 잔차 블록은 DST(Discrete Sine Transform) 기반 기저 벡터를 통해 변환하며, 나머지 잔차 블록에 대해서는 DCT(Discrete Cosine Transform) 기반의 기저 벡터를 사용하여 변환을 수행할 수 있다. 또한 RQT(Residual Quad Tree) 기술을 통하여 하나의 블록에 대하여 변환 블록을 쿼드 트리 형태로 분할하며 RQT를 통해 분할된 각 변환 블록에 대하여 변환과 양자화를 수행하고 난 후 모든 계수가 0이 되는 경우의 부호화 효율을 높이기 위해 cbf(coded block flag)를 전송할 수 있다.

[0068]

또 다른 대안으로는, 여러 변환 기저를 선택적으로 사용하여 변환을 수행하는 MTS(Multiple Transform Selection) 기술을 적용할 수도 있다. 즉, CU를 RQT를 통해 TU로 분할하지 않고, SBT(Sub-block Transform) 기술을 통해 TU분할과 유사한 기능을 수행할 수 있다. 구체적으로, SBT는 화면 간 예측 블록에만 적용되며 RQT와 달리 현재 블록을 수직 혹은 수평 방향으로 ½ 혹은 ¼ 크기로 분할한 뒤 그 중 하나의 블록에 대해서만 변환을 수행할 수 있다. 예를 들어, 수직으로 분할된 경우 맨 왼쪽 혹은 맨 오른쪽 블록에 대해 변환을 수행하고, 수평으로 분할된 경우 맨 위쪽 혹은 맨 아래쪽 블록에 대하여 변환을 수행할 수 있다.

[0069]

또한 DCT 또는 DST를 통해 주파수 영역으로 변환된 잔차 신호를 추가 변환하는 2차 변환 (secondary transform) 기술인 LFNST(Low Frequency Non-Separable Transform)를 적용할 수도 있다. LFNST는 좌측 상단의 4x4 또는 8x8의 저주파수 영역에 대해서 변환을 추가적으로 수행하여 잔차 계수를 좌측 상단으로 집중시킬 수 있게 된다.

[0070]

양자화부(140)는 변환 계수 또는 잔여 신호를 양자화 매개변수 (QP, Quantization parameter)에 따라 양자화함으로써 양자화된 레벨을 생성할 수 있고, 생성된 양자화된 레벨을 출력할 수 있다. 이때, 양자화부(140)에서는 양자화 행렬을 사용하여 변환 계수를 양자화할 수 있다.

[0071]

일 예로, 0~51 QP 값을 사용하는 양자화기를 사용할 수 있다. 또는, 영상의 크기가 보다 크고 높은 부호화 효율이 요구되는 경우에는, 0~63 QP를 사용할 수도 있다. 또한 하나의 양자화기를 사용하는 것이 아닌 두 개의 양자화기를 사용하는 DQ(Dependent Quantization) 방법을 적용할 수도 있다. DQ는 두개의 양자화기(예, Q0, Q1)를 사용하여 양자화를 수행하되, 특정 양자화기 사용에 대한 정보를 시그널링 하지 않더라도, 상태 전이 모델을 통해 현재 상태에 기반하여 다음 변환 계수에 사용할 양자화기가 선택되도록 적용할 수 있다.

[0072]

엔트로피 부호화부(150)는, 양자화부(140)에서 산출된 값들 또는 부호화 과정에서 산출된 부호화 파라미터(Coding Parameter) 값들 등에 대하여 확률 분포에 따른 엔트로피 부호화를 수행함으로써 비트스트림(bitstream)을 생성할 수 있고, 비트스트림을 출력할 수 있다. 엔트로피 부호화부(150)는 영상의 샘플에 관한 정보 및 영상의 복호화를 위한 정보에 대한 엔트로피 부호화를 수행할 수 있다. 예를 들면, 영상의 복호화를 위한 정보는 구문 요소(syntax element) 등을 포함할 수 있다.

[0073]

엔트로피 부호화가 적용되는 경우, 높은 발생 확률을 갖는 심볼(symbol)에 적은 수의 비트가 할당되고 낮은 발생 확률을 갖는 심볼에 많은 수의 비트가 할당되어 심볼이 표현됨으로써, 부호화 대상 심볼들에 대한 비트열의 크기가 감소될 수 있다. 엔트로피 부호화부(150)는 엔트로피 부호화를 위해 지수 골롬(exponential Golomb), CAVLC(Context-Adaptive Variable Length Coding), CABAC(Context-Adaptive Binary Arithmetic Coding)과 같은 부호화 방법을 사용할 수 있다. 예를 들면, 엔트로피 부호화부(150)는 가변 길이 부호화(Variable Length Coding/Code; VLC) 테이블을 이용하여 엔트로피 부호화를 수행할 수 있다. 또한 엔트로피 부호화부(150)는 대상 심볼의 이진화(binarization) 방법 및 대상 심볼/빈(bin)의 확률 모델(probability model)을 도출한 후, 도출된 이진화 방법, 확률 모델, 문맥 모델(Context Model)을 사용하여 산술 부호화를 수행할 수도 있다.

[0074]

관련하여, CABAC을 적용함에 있어서, 복호화 장치에서 저장되는 확률 테이블의 크기를 줄이고자, 테이블 확률 업데이트 방식을 간단한 수식을 통한 테이블 업데이트 방식으로 변경하여 적용할 수도 있다. 또한 더 정확한 심볼의 확률 값을 얻기 위하여 2개의 서로 다른 확률 모델을 사용할 수도 있다.

[0075]

엔트로피 부호화부(150)는 변환 계수 레벨(양자화된 레벨)을 부호화하기 위해 변환 계수 스캐닝(Transform Coefficient Scanning) 방법을 통해 2차원의 블록 형태(form) 계수를 1차원의 벡터 형태로 변경할 수 있다.

[0076]

부호화 파라미터(Coding Parameter)는 구문 요소 (syntax element)와 같이 부호화 장치(100)에서 부호화되어 복호화 장치(200)로 시그널링되는 정보(플래그, 색인 등)뿐만 아니라, 부호화 과정 혹은 복호화 과정에서 유도되는 정보를 포함할 수 있으며, 영상을 부호화하거나 복호화할 때 필요한 정보를 의미할 수 있다.

[0077]

여기서, 플래그 혹은 색인을 시그널링(signaling)한다는 것은 인코더에서는 해당 플래그 혹은 색인을 엔트로피 부호화(Entropy Encoding)하여 비트스트림(Bitstream)에 포함하는 것을 의미할 수 있고, 디코더에서는 비트스트림으로부터 해당 플래그 혹은 색인을 엔트로피 복호화(Entropy Decoding)하는 것을 의미할 수 있다.

[0078]

부호화된 현재 영상은 이후에 처리되는 다른 영상에 대한 참조 영상으로서 사용될 수 있다. 따라서, 부호화 장치(100)는 부호화된 현재 영상을 다시 복원 또는 복호화할 수 있고, 복원 또는 복호화된 영상을 참조 영상으로 참조 픽처 버퍼(190)에 저장할 수 있다.

[0079]

양자화된 레벨은 역양자화부(160)에서 역양자화(dequantization)될 수 있고. 역변환부(170)에서 역변환(inverse transform)될 수 있다. 역양자화 및/또는 역변환된 계수는 가산기(117)를 통해 예측 블록과 합해질 수 있다, 역양자화 및/또는 역변환된 계수와 예측 블록을 합함으로써 복원 블록(reconstructed block)이 생성될 수 있다. 여기서, 역양자화 및/또는 역변환된 계수는 역양자화 및 역변환 중 적어도 하나 이상이 수행된 계수를 의미하며, 복원된 잔여 블록을 의미할 수 있다. 상기 역양자화부(160) 및 역변환부(170)는 양자화부(140) 및 변환부(130)의 역과정으로 수행될 수 있다.

[0080]

복원 블록은 필터부(180)를 거칠 수 있다. 필터부(180)는 디블록킹 필터(deblocking filter), 샘플 적응적 오프셋(Sample Adaptive Offset; SAO), 적응적 루프 필터(Adaptive Loop Filter; ALF), 양방향 필터 (Bilateral filter; BIF), LMCS (Luma Mapping with Chroma Scaling) 등을 복원 샘플, 복원 블록 또는 복원 영상에, 전부 또는 일부 필터링 기술로 적용할 수 있다. 필터부(180)는 인-루프 필터(in-loop filter)로 칭해질 수도 있다. 이때, 인-루프 필터(in-loop filter)는 LMCS를 제외하는 명칭으로 사용하기도 한다.

[0081]

디블록킹 필터는 블록들 간의 경계에서 발생한 블록 왜곡을 제거할 수 있다. 디블록킹 필터를 수행할지 여부를 판단하기 위해 블록에 포함된 몇 개의 열 또는 행에 포함된 샘플을 기초로 현재 블록에 디블록킹 필터 적용할지 여부를 판단할 수 있다. 블록에 디블록킹 필터를 적용하는 경우 필요한 디블록킹 필터링 강도에 따라 서로 다른 필터를 적용할 수 있다.

[0082]

샘플 적응적 오프셋을 이용하여 부호화 에러를 보상하기 위해 샘플 값에 적정 오프셋(offset) 값을 더할 수 있다. 샘플 적응적 오프셋은 디블록킹을 수행한 영상에 대해 샘플 단위로 원본 영상과의 오프셋을 보정할 수 있다. 영상에 포함된 샘플을 일정한 수의 영역으로 구분한 후 오프셋을 수행할 영역을 결정하고 해당 영역에 오프셋을 적용하는 방법 또는 각 샘플의 에지 정보를 고려하여 오프셋을 적용하는 방법을 사용할 수 있다.

[0083]

양방향 필터 (Bilateral filter; BIF) 또한 디블록킹을 수행한 영상에 대해 샘플 단위로 원본 영상과의 오프셋을 보정할 수 있다.

[0084]

적응적 루프 필터는 복원 영상 및 원래의 영상을 비교한 값에 기반하여 필터링을 수행할 수 있다. 영상에 포함된 샘플을 소정의 그룹으로 나눈 후 해당 그룹에 적용될 필터를 결정하여 그룹마다 차별적으로 필터링을 수행할 수 있다. 적응적 루프 필터를 적용할지 여부에 관련된 정보는 부호화 유닛(Coding Unit, CU) 별로 시그널링될 수 있고, 각각의 블록에 따라 적용될 적응적 루프 필터의 모양 및 필터 계수는 달라질 수 있다.

[0085]

LMCS(Luma Mapping with Chroma Scaling)에서, 루마 매핑(LM, Luma-mapping)은 piece-wise 선형 모델을 통해 휘도 값을 재맵핑 하는 것을 의미하고, 크로마 스케일링(CS, Chroma scaling)은 예측 신호의 평균 휘도 값에 따라 색차 성분의 잔차 값을 스케일링해주는 기술을 의미한다. 특히, LMCS는 HDR(High Dynamic Range) 영상의 특성을 반영한 HDR 보정 기술로 활용될 수 있다.

[0086]

필터부(180)를 거친 복원 블록 또는 복원 영상은 참조 픽처 버퍼(190)에 저장될 수 있다. 필터부(180)를 거친 복원 블록은 참조 영상의 일부일 수 있다. 말하자면, 참조 영상은 필터부(180)를 거친 복원 블록들로 구성된 복원 영상일 수 있다. 저장된 참조 영상은 이후 화면 간 예측 혹은 움직임 보상에 사용될 수 있다.

[0087]

도 2는 본 발명이 적용되는 복호화 장치의 일 실시예에 따른 구성을 나타내는 블록도이다.

[0088]

복호화 장치(200)는 디코더, 비디오 복호화 장치 또는 영상 복호화 장치일 수 있다.

[0089]

도 2를 참조하면, 복호화 장치(200)는 엔트로피 복호화부(210), 역양자화부(220), 역변환부(230), 인트라 예측부(240), 움직임 보상부(250), 가산기(201), 스위치 (203), 필터부(260) 및 참조 픽처 버퍼(270)를 포함할 수 있다.

[0090]

복호화 장치(200)는 부호화 장치(100)에서 출력된 비트스트림을 수신할 수 있다. 복호화 장치(200)는 컴퓨터 판독가능한 기록 매체에 저장된 비트스트림을 수신하거나, 유/무선 전송 매체를 통해 스트리밍되는 비트스트림을 수신할 수 있다. 복호화 장치(200)는 비트스트림에 대하여 인트라 모드 또는 인터 모드로 복호화를 수행할 수 있다. 또한, 복호화 장치(200)는 복호화를 통해 복원된 영상 또는 복호화된 영상을 생성할 수 있고, 복원된 영상 또는 복호화된 영상을 출력할 수 있다.

[0091]

복호화에 사용되는 예측 모드가 인트라 모드인 경우 스위치(203)가 인트라로 전환될 수 있다. 복호화에 사용되는 예측 모드가 인터 모드인 경우 스위치(203)가 인터로 전환될 수 있다.

[0092]

복호화 장치(200)는 입력된 비트스트림을 복호화하여 복원된 잔여 블록(reconstructed residual block)을 획득할 수 있고, 예측 블록을 생성할 수 있다. 복원된 잔여 블록 및 예측 블록이 획득되면, 복호화 장치(200)는 복원된 잔여 블록과 및 예측 블록을 더함으로써 복호화 대상이 되는 복원 블록을 생성할 수 있다. 복호화 대상 블록은 현재 블록으로 칭해질 수 있다.

[0093]

엔트로피 복호화부(210)는 비트스트림에 대한 확률 분포에 따른 엔트로피 복호화를 수행함으로써 심볼들을 생성할 수 있다. 생성된 심볼들은 양자화된 레벨 형태의 심볼을 포함할 수 있다. 여기에서, 엔트로피 복호화 방법은 상술된 엔트로피 부호화 방법의 역과정일 수 있다.

[0094]

엔트로피 복호화부(210)는 변환 계수 레벨(양자화된 레벨)을 복호화하기 위해 변환 계수 스캐닝 방법을 통해 1차원의 벡터 형태 계수를 2차원의 블록 형태로 변경할 수 있다.

[0095]

양자화된 레벨은 역양자화부(220)에서 역양자화될 수 있고, 역변환부(230)에서 역변환될 수 있다. 양자화된 레벨은 역양자화 및/또는 역변환이 수행된 결과로서, 복원된 잔여 블록으로 생성될 수 있다. 이때, 역양자화부(220)는 양자화된 레벨에 양자화 행렬을 적용할 수 있다. 복호화 장치에 적용되는 역양자화부(220) 및 역변환부(230)는 전술한 부호화 장치에 적용되는 역양자화부(160) 및 역변환부(170)와 동일한 기술을 적용할 수 있다.

[0096]

인트라 모드가 사용되는 경우, 인트라 예측부(240)는 복호화 대상 블록 주변의 이미 복호화된 블록의 샘플 값을 이용하는 공간적 예측을 현재 블록에 대해 수행함으로써 예측 블록을 생성할 수 있다. 복호화 장치에 적용되는 인트라 예측부(240)는 전술한 부호화 장치에 적용되는 인트라 예측부(120)와 동일한 기술을 적용할 수 있다.

[0097]

인터 모드가 사용되는 경우, 움직임 보상부(250)는 움직임 벡터 및 참조 픽처 버퍼(270)에 저장되어 있는 참조 영상을 이용하는 움직임 보상을 현재 블록에 대해 수행함으로써 예측 블록을 생성할 수 있다. 상기 움직임 보상부(250)는 움직임 벡터의 값이 정수 값을 가지지 않을 경우에 참조 영상 내의 일부 영역에 대해 보간 필터를 적용하여 예측 블록을 생성할 수 있다. 움직임 보상을 수행하기 위해 부호화 유닛을 기준으로 해당 부호화 유닛에 포함된 예측 유닛의 움직임 보상 방법이 스킵 모드, 머지 모드, AMVP 모드, 현재 픽처 참조 모드 중 어떠한 방법인지 여부를 판단할 수 있고, 각 모드에 따라 움직임 보상을 수행할 수 있다. 복호화 장치에 적용되는 움직임 보상부(250)는 전술한 부호화 장치에 적용되는 움직임 보상부(122)와 동일한 기술을 적용할 수 있다.

[0098]

가산기(201)는 복원된 잔여 블록 및 예측 블록을 가산하여 복원 블록을 생성할 수 있다. 필터부(260)는 Inverse-LMCS, 디블록킹 필터, 샘플 적응적 오프셋 및 적응적 루프 필터 등 적어도 하나를 복원 블록 또는 복원 영상에 적용할 수 있다. 복호화 장치에 적용되는 필터부(260)는 전술한 부호화 장치에 적용되는 필터부(180)에 적용된 필터링 기술과 동일한 기술을 적용할 수 있다.

[0099]

필터부(260)는 복원 영상을 출력할 수 있다. 복원 블록 또는 복원 영상은 참조 픽처 버퍼(270)에 저장되어 인터 예측에 사용될 수 있다. 필터부(260)를 거친 복원 블록은 참조 영상의 일부일 수 있다. 말하자면, 참조 영상은 필터부(260)를 거친 복원 블록들로 구성된 복원 영상일 수 있다. 저장된 참조 영상은 이후 화면 간 예측 혹은 움직임 보상에 사용될 수 있다.

[0100]

도 3은 본 발명이 적용될 수 있는 비디오 코딩 시스템을 개략적으로 나타내는 도면이다.

[0101]

일 실시예에 따른 비디오 코딩 시스템은 부호화 장치(10) 및 복호화 장치(20)를 포함할 수 있다. 부호화 장치(10)는 부호화된 비디오(video) 및/또는 영상(image) 정보 또는 데이터를 파일 또는 스트리밍 형태로 디지털 저장매체 또는 네트워크를 통하여 복호화 장치(20)로 전달할 수 있다.

[0102]

일 실시예에 따른 부호화 장치(10)는 비디오 소스 생성부(11), 부호화부(12), 전송부(13)를 포함할 수 있다. 일 실시예에 따른 복호화 장치(20)는 수신부(21), 복호화부(22) 및 렌더링부(23)를 포함할 수 있다. 상기 부호화부(12)는 비디오/영상 부호화부라고 불릴 수 있고, 상기 복호화부(22)는 비디오/영상 복호화부라고 불릴 수 있다. 전송부(13)는 부호화부(12)에 포함될 수 있다. 수신부(21)는 복호화부(22)에 포함될 수 있다. 렌더링부(23)는 디스플레이부를 포함할 수도 있고, 디스플레이부는 별개의 디바이스 또는 외부 컴포넌트로 구성될 수도 있다.

[0103]

비디오 소스 생성부(11)는 비디오/영상의 캡쳐, 합성 또는 생성 과정 등을 통하여 비디오/영상을 획득할 수 있다. 비디오 소스 생성부(11)는 비디오/영상 캡쳐 디바이스 및/또는 비디오/영상 생성 디바이스를 포함할 수 있다. 비디오/영상 캡쳐 디바이스는 예를 들어, 하나 이상의 카메라, 이전에 캡쳐된 비디오/영상을 포함하는 비디오/영상 아카이브 등을 포함할 수 있다. 비디오/영상 생성 디바이스는 예를 들어 컴퓨터, 타블렛 및 스마트폰 등을 포함할 수 있으며 (전자적으로) 비디오/영상을 생성할 수 있다. 예를 들어, 컴퓨터 등을 통하여 가상의 비디오/영상이 생성될 수 있으며, 이 경우 관련 데이터가 생성되는 과정으로 비디오/영상 캡쳐 과정이 갈음될 수 있다.

[0104]

부호화부(12)는 입력 비디오/영상을 부호화할 수 있다. 부호화부(12)는 압축 및 부호화 효율을 위하여 예측, 변환, 양자화 등 일련의 절차를 수행할 수 있다. 부호화부(12)는 부호화된 데이터(부호화된 비디오/영상 정보)를 비트스트림(bitstream) 형태로 출력할 수 있다. 상기 부호화부(12)의 상세 구성은 전술한 도 1의 부호화 장치(100)와 동일하게 구성하는 것도 가능하다.

[0105]

전송부(13)는 비트스트림 형태로 출력된 부호화된 비디오/영상 정보 또는 데이터를 파일 또는 스트리밍 형태로 디지털 저장매체 또는 네트워크를 통하여 복호화 장치(20)의 수신부(21)로 전달할 수 있다. 디지털 저장 매체는 USB, SD, CD, DVD, 블루레이, HDD, SSD 등 다양한 저장 매체를 포함할 수 있다. 전송부(13)는 미리 정해진 파일 포맷을 통하여 미디어 파일을 생성하기 위한 엘리먼트를 포함할 수 있고, 방송/통신 네트워크를 통한 전송을 위한 엘리먼트를 포함할 수 있다. 수신부(21)는 상기 저장매체 또는 네트워크로부터 상기 비트스트림을 추출/수신하여 복호화부(22)로 전달할 수 있다.

[0106]

복호화부(22)는 부호화부(12)의 동작에 대응하는 역양자화, 역변환, 예측 등 일련의 절차를 수행하여 비디오/영상을 복호화할 수 있다. 상기 복호화부(22)의 상세 구성은 전술한 도 2의 복호화 장치(200)와 동일하게 구성하는 것도 가능하다.

[0107]

렌더링부(23)는 복호화된 비디오/영상을 렌더링할 수 있다. 렌더링된 비디오/영상은 디스플레이부를 통하여 디스플레이될 수 있다.

[0109]

템플릿 기반 인트라 예측 모드 유도(template-based intra mode derivation, TIMD) 방법은 예측 신호를 생성하기 위해 현재 블록의 템플릿(template)을 분석하는 인트라 예측 방법이다.

[0110]

이하, 도 4 내지 도 8을 참고하여, 본 발명의 일 실시 예에 따른 후보 인트라 예측 모드를 확장한 템플릿 기반 인트라 예측 모드 유도 방법을 기반으로 인트라 예측을 수행하는 방법을 설명하도록 한다.

[0112]

도 4는 본 발명의 일 실시 예에 따른 템플릿 기반 인트라 예측 모드 유도 방법을 설명하기 위한 도면이다.

[0113]

도 4를 참조하면, 현재 블록(Current block, 410)의 템플릿인 현재 템플릿(Current template, 420)에 인접한 화소들인 템플릿의 참조 화소(Reference of the template, 430)에 임의의 후보 인트라 예측 모드들을 적용하여, 현재 템플릿(420)의 예측 샘플이 생성될 수 있다. 여기서, 임의의 후보 인트라 예측 모드는 방향성(angular) 모드 및/또는 비방향성(non-angular) 모드일 수 있다. 현재 템플릿(420)의 크기는, L1xN 및/또는 L2xM 일 수 있으며, L1, L2, N, M은 모두 양의 정수일 수 있다.

[0114]

그리고, 현재 템플릿(420)의 예측 샘플들과 현재 템플릿(420)에 복원된 (reconstructed) 샘플들 간의 유사도가 도출될 수 있다. 유사도는 임의의 비용 함수(cost function)를 이용하여 산출된 현재 템플릿(420)의 예측 샘플의 비용 값(cost)을 기초로 도출될 수 있다. 여기서, 임의의 후보 인트라 예측 모드들 중에서, 가장 낮은 비용 값을 갖는 두 개의 인트라 예측 모드들이 TIMD 모드들로 선택될 수 있다. 선택된 두 개의 TIMD 모드들을 이용하여 현재 블록(410)의 예측 샘플들이 생성될 수 있다. 그리고, 두 개의 TIMD 모드들을 이용하여 생성된 현재 블록(410)의 예측 샘플들은 특정한 가중 값을 이용해 가중 합(weighted sum)될 수 있다. 일 실시예에 따르면, TIMD에서 사용되는 임의의 후보 인트라 예측 모드들은 MPM (most probable mode) 및/또는 WAIP (wide angle intra prediction) 모드들을 포함할 수 있다.

[0115]

본 발명의 일 실시예에 따르면, TIMD에서, MPM 및/또는 WAIP 모드 뿐만 아니라 추가의 인트라 예측 후보 모드들이 사용될 수 있다. 즉, 템플릿 기반 인트라 예측 모드 유도 방법에 사용되는 후보 인트라 예측 모드들은 확장될 수 있다.

[0116]

본 발명의 일 실시예에 따르면, 인트라 템플릿 매칭 예측 모드가 템플릿 기반 인트라 예측 모드 유도 방법을 위한 후보 인트라 예측 모드로 사용될 수 있다. 본 발명의 일 실시 예에 따른 인트라 템플릿 매칭 예측 및 인트라 템플릿 매칭을 이용하여 템플릿 기반 인트라 예측 모드 유도 방법을 기반으로 인트라 예측을 수행하는 방법을 설명하도록 한다.

[0117]

도 5는 본 발명의 일 실시 예에 따른 인트라 템플릿 매칭 예측을 설명하기 위한 도면이다.

[0118]

도 5를 참고하면, 인트라 템플릿 매칭 예측은 현재 블록(Current block, 510)을 기준으로 현재 픽처(Current picture, 500)내의 기 복원된 영역(Reconstructed area, 530)에서 현재 블록(510)에 대한 최적의 예측 블록을 결정할 수 있다. 구체적으로, 인트라 템플릿 매칭 예측에서, 현재 블록(510)의 주변 인접한 참조 화소들의 집합을 현재 템플릿(Current template, 520)이라 정의할 수 있다. 그리고, 현재 템플릿(520)을 기초로 기 복원된 영역(530) 내에서 템플릿 매칭 기반 탐색을 수행하여 현재 템플릿(520)과 가장 유사도가 높은 템플릿(similar template, 540)을 찾아 매칭 블록(matching block, 550)이 결정될 수 있다. 여기서, 매칭 블록(550)은 현재 블록(510)에 대한 예측 블록으로 이용될 수 있다.

[0119]

한편, 템플릿 매칭은 기 복원된 영역(530) 중 기 정의된 된 영역(R1, R2, R3, R4)에서 수행될 수 있고, 탐색 순서는 R1, R2, R3, R4 순일 수 있다.

[0120]

본 발명의 일 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에서 사용되는 후보 인트라 예측 모드는 인트라 템플릿 매칭 예측 모드를 더 포함할 수 있다. 그리고, 후보 인트라 예측 모드들 중에서, 가장 낮은 비용 값을 가지는 2 개의 현재 템플릿의 예측 샘플을 유도하는 2 개의 인트라 예측 모드들이 선택될 수 있다. 여기서, 선택된 2 개의 인트라 예측 모드들 중 하나의 모드가 인트라 템플릿 매칭 예측 모드인 경우, 아래의 수학식 1과 같이 인트라 템플릿 매칭 예측 모드를 이용하여 유도된 예측 샘플과 다른 인트라 예측 모드를 이용하여 유도된 예측 샘플들을 가중합하여 현재 블록에 대한 예측 샘플이 유도될 수 있다.

[0121]

[0122]

여기서, Pred는 최종 예측 값을 의미할 수 있다. PredM1은 M1 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredM2는 M2 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. ωM1은 M1 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 그리고, ωM2는 M2 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 여기서, 0 ≤ ωM1≤ 1이고, 0 ≤ ωM2≤ 1이다.

[0123]

CostM1은 M1 모드를 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값을 의미할 수 있다. 그리고, CostM2는 M2 모드를 이용하여 유도된 현재 템플릿의 예측 샘플에 적용되는 비용 값을 의미할 수 있다. 여기서, 비용 값은 SAD (sum of absolute differences), MSE (mean squared error), SSD (sum of squared differences), SATD (sum of absolute transformed differences) 등의 비용 함수를 사용하여 도출될 수 있다.

[0124]

본 발명의 다른 실시예에 따르면, 선택된 인트라 예측 모드들 중 하나가 인트라 템플릿 매칭 예측 모드이고, 선택된 인트라 예측 모드들에 관한 조건이 충족된 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다. 예를 들어, 선택된 제1 인트라 예측 모드를 이용하여 생성된 예측 샘플의 비용 값이 선택된 제2 인트라 예측 모드를 이용하여 생성된 예측 샘플의 비용 값의 실수 배 이하인 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다.

[0125]

반면, 선택된 인트라 예측 모드들에 관한 조건이 충족되지 않은 경우, 현재 블록의 예측 샘플은, 가장 낮은 비용 값을 가지는 현재 템플릿의 예측 샘플을 유도하기 위해 사용된 하나의 인트라 예측 모드를 이용하여 유도될 수 있다. 예를 들어, 인트라 템플릿 매칭을 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값이 가장 작은 경우, 인트라 템플릿 매칭을 이용하여 현재 블록의 예측 블록이 생성될 수 있다.

[0126]

후보 인트라 예측 모드들 중에서, X개의 인트라 예측 모드들이 최종적으로 선택될 수 있다. 즉, 인트라 템플릿 매칭 예측 모드를 포함하는 후보 인트라 예측 모드들 중에서, 비용 값이 작은 순으로 X개의 인트라 예측 모드들 M1, M2, …, MX가 선택될 수 있다. 선택된 인트라 예측 모드들 중 하나의 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드인 경우, 현재 블록에 대해 인트라 템플릿 매칭 예측을 수행하여 유도된 예측 샘플과 다른 후보 인트라 예측 모드들을 이용하여 유도된 예측 샘플들이 가중합될 수 있다.

[0127]

다른 실시예에 따르면, 선택된 인트라 예측 모드들 중 하나의 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드이고, 선택된 인트라 예측 모드들에 관한 조건이 충족된 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다. 반면, 선택된 인트라 예측 모드들에 관한 조건이 충족되지 않은 경우, 현재 블록의 예측 샘플은, 가장 낮은 비용 값을 가지는 현재 템플릿의 예측 샘플을 유도하기 위해 사용된 하나의 인트라 예측 모드를 이용하여 유도될 수 있다. 예를 들어, 인트라 템플릿 매칭을 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값이 가장 작은 경우, 인트라 템플릿 매칭을 이용하여 현재 블록의 예측 블록이 생성될 수 있다.

[0128]

또 다른 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에 따른 후보 인트라 예측 모드들 중에서 선택된 X개의 인트라 예측 모드들을 이용하여 유도된 예측 샘플들을 가중합하는 경우, 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 템플릿 기반 인트라 예측 모드 유도 방법에서 항상 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 또는 선택된 X개의 인트라 예측 모드들이 미리 정의된 소정의 인트라 예측 모드를 포함하지 않는 경우에 한하여, 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 또는 선택된 X개의 인트라 예측 모드들 중에서, 가장 높은 비용 값을 가지는 인트라 예측 모드가 미리 정의된 소정의 인트라 예측 모드로 대체될 수 있다. 여기서, 소정의 인트라 예측 모드는 플래너 모드, DC 모드와 같이 미리 정의된 인트라 예측 모드일 수 있다.

[0129]

예를 들어, 수학식 2와 같이 선택된 X개의 인트라 예측 모드들과 미리 정의된 소정의 인트라 예측 모드인 플래너 모드를 사용하여 유도된 예측 샘플을 가중합하여 예측 샘플이 생성될 수 있다.

[0130]

[0131]

여기서, Pred는 최종 예측 값을 의미할 수 있다. PredM1은 M1 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredM2는 M2 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredMX은 MX 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredPlanar는 플래너 모드를 이용한 예측 샘플 값을 의미할 수 있다.

[0132]

ωM1은 M1 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. ωM2는 M2 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. ωMX는 MX 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 그리고, ωPlanar는 플래너 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 각각의 가중치 값은 0이하 1 이하의 실수이고, 각각의 가중치 값들의 합은 1이다.

[0133]

또한, 본 발명의 일 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에 따른 후보 인트라 예측 모드로 사용되는 인트라 템플릿 매칭 예측 모드에서 사용되는 블록 벡터(block vector, BV)는 정수 화소 (integer-pel) 또는/및 부화소(fractional-pel) 단위의 정밀도를 가질 수 있다. 인트라 템플릿 매칭 예측 모드의 블록 벡터는 임의의 버퍼(ex. BV 버퍼, history-based motion vector prediction (HMVP) 버퍼 등)에 정수 화소 또는/및 부화소 단위의 정밀도로 저장될 수 있다. 정수 화소 또는/및 부화소 정밀도를 가지도록 저장된 블록 벡터는 현재 블록 이후에 블록들의 부호화/복호화 과정에서 사용될 수 있다.

[0134]

블록 벡터의 정수 화소 단위의 정밀도는 1 화소 이외에도 2, 4, 8, 16 등의 2의 자승 단위의 정수 값을 가질 수 있다. 그리고, 블록 벡터의 부화소 단위의 정밀도는 1/2, 1/4, 1/8, 1/16 등의 값을 가질 수 있다. 부화소 단위의 정밀도를 가지는 샘플을 생성하기 위하여, 미리 설계된 임의의 탭 수를 갖는 보간 필터, 임의의 탭 수를 갖는 큐빅(cubic) 보간 필터, 임의의 탭 수를 갖는 가우시안(Gaussian) 보간 필터, 이중 선형 보간 필터 (bilinear interpolation filter) 등이 사용될 수 있다. 1차원 보간 필터가 사용되는 경우 수평, 수직 또는 수직, 수평 순서로 보간 필터가 순차적으로 적용될 수 있다. 부화소 정밀도의 샘플을 생성하기 위한 보간 필터를 적용하는 과정에서, 참조 영역(reference area)의 경계에 위치한 일부 입력 샘플을 사용할 수 없는 경우(not available), 일부 입력 샘플은 패딩(padding)을 통해 생성되거나, 임의의 값으로 대체될 수 있다.

[0135]

블록 벡터의 정밀도의 단위를 지시하는 정보는 상위 레벨(high level)(예를 들어, VPS(video parameter set), SPS(sequence parameter set), PPS(picture parameter set), 픽처 헤더(picture header), 슬라이스 헤더(slice header) 등)에서 시그널링되는 TIMD 사용 여부(ex. timd_enabled_flag) 또는 TIMD 확장 여부(ex. timd_extension_flag)에 종속되어 하위 계층(low level)(예를 들어, CU(coding unit), PU(prediction unit), TU(transform unit) 등)에서 시그널링 될 수도 있다. 이 경우, 복호화기는 로우 레벨에서 시그널링 되는 구문요소(또는 구문요소들)의 값에 따라 TIMD의 후보 인트라 예측 모드인 인트라 템플릿 매칭 예측에 사용되는 블록 벡터의 정밀도의 단위 정보(1, 2, 4, 8, 16 등의 정화소 정밀도 또는 1/2, 1/4, 1/8, 1/16 등의 부화소 정밀도)를 확인할 수 있다.

[0137]

본 발명의 다른 실시예에 따르면, 인트라 블록 복사 모드가 템플릿 기반 인트라 예측 모드 유도 방법을 위한 후보 인트라 예측 모드로 사용될 수 있다. 본 발명의 일 실시 예에 따른 인트라 블록 복사 및 인트라 블록 복사를 이용하여 템플릿 기반 인트라 예측 모드 유도 방법을 기반으로 인트라 예측을 수행하는 방법을 설명하도록 한다.

[0138]

도 6은 본 발명의 일 실시 예에 따른 인트라 블록 복사 기반 예측 방법을 설명하기 위한 도면이다.

[0139]

도 6을 참고하면, 현재 블록(current block, 610)의 블록 벡터(block vector, 620)에 기초하여 현재 픽처(600)의 복원된 영역(Reconstructed area, 630)의 기 정의된 탐색 범위 (R1, R2, R3, R4) 내에서 매칭 블록(640)이 탐색될 수 있다. 그리고, 현재 블록(610)의 예측 블록은 매칭 블록(640)을 기초로 유도될 수 있다. 따라서, 현재 블록(610)에 인트라 블록 복사 기반 예측 방법이 적용되면, 부호화기는 인트라 블록 복사 기반 예측 방법에 관한 정보와 블록 벡터(620)에 관련된 정보를 복호화기로 전송할 수 있다.

[0140]

도 6에서 기 정의된 탐색 범위인 R1, R2, R3, R4는 현재 블록(610)을 포함하는 현재 CTU(Coding Tree Unit), 현재 CTU로부터 기 설정된 범위 이내의 영역 중에서 현재 CTU의 좌측 상단에 위치하는 좌상단 CTU, 현재 CTU로부터 기 설정된 범위 이내의 영역 중에서 현재 CTU의 상단에 위치하는 상단 CTU, 현재 CTU로부터 기 설정된 범위 이내의 영역 중에서 현재 CTU의 좌측에 위치하는 좌측 CTU 로 각각 정의될 수 있다. 여기서, 기 설정된 범위 이내의 영역은 현재 타일, 슬라이스, 픽처 중 하나로 설정된 영역일 수 있다.

[0141]

본 발명의 일 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에서 사용되는 후보 인트라 예측 모드는 인트라 블록 복사 기반 예측 모드를 더 포함할 수 있다. 그리고, 후보 인트라 예측 모드들 중에서, 가장 낮은 비용 값을 가지는 2 개의 현재 템플릿의 예측 샘플을 유도하는 2 개의 인트라 예측 모드들이 선택될 수 있다. 여기서, 선택된 2 개의 인트라 예측 모드들 중 하나의 모드가 인트라 블록 복사 기반 예측 모드인 경우, 아래의 수학식 3과 같이 인트라 블록 복사 기반 예측 모드를 이용하여 유도된 예측 샘플과 다른 인트라 예측 모드를 이용하여 유도된 예측 샘플들을 가중합하여 현재 블록에 대한 예측 샘플이 유도될 수 있다.

[0142]

[0143]

여기서, Pred는 최종 예측 값을 의미할 수 있다. PredM1은 M1 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredM2는 M2 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. ωM1은 M1 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 그리고, ωM2는 M2 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 여기서, 0 ≤ ωM1≤ 1이고, 0 ≤ ωM2≤ 1이다.

[0144]

CostM1은 M1 모드를 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값을 의미할 수 있다. 그리고, CostM2는 M2 모드를 이용하여 유도된 현재 템플릿의 예측 샘플에 적용되는 비용 값을 의미할 수 있다. 여기서, 비용 값은 SAD (sum of absolute differences), MSE (mean squared error), SSD (sum of squared differences), SATD (sum of absolute transformed differences) 등의 비용 함수를 사용하여 도출될 수 있다.

[0145]

본 발명의 다른 실시예에 따르면, 선택된 인트라 예측 모드들 중 하나가 인트라 블록 복사 기반 예측 모드이고, 선택된 인트라 예측 모드들에 관한 조건이 충족된 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다. 예를 들어, 선택된 제1 인트라 예측 모드를 이용하여 생성된 예측 샘플의 비용 값이 선택된 제2 인트라 예측 모드를 이용하여 생성된 예측 샘플의 비용 값의 실수 배 이하인 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다.

[0146]

반면, 선택된 인트라 예측 모드들에 관한 조건이 충족되지 않은 경우, 현재 블록의 예측 샘플은, 가장 낮은 비용 값을 가지는 현재 템플릿의 예측 샘플을 유도하기 위해 사용된 하나의 인트라 예측 모드를 이용하여 유도될 수 있다. 예를 들어, 인트라 블록 복사 기반 예측을 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값이 가장 작은 경우, 인트라 블록 복사 기반 예측을 이용하여 현재 블록의 예측 블록이 생성될 수 있다.

[0147]

후보 인트라 예측 모드들 중에서, Y개의 인트라 예측 모드들이 최종적으로 선택될 수 있다. 즉, 인트라 블록 복사 기반 예측 모드를 포함하는 후보 인트라 예측 모드들 중에서, 비용 값이 작은 순으로 Y개의 인트라 예측 모드들 M1, M2, …, MY가 선택될 수 있다. 선택된 인트라 예측 모드들 중 하나의 인트라 예측 모드가 인트라 블록 복사 기반 예측 모드인 경우, 현재 블록에 대해 인트라 블록 복사 기반 예측을 수행하여 유도된 예측 샘플과 다른 후보 인트라 예측 모드들을 이용하여 유도된 예측 샘플들이 가중합될 수 있다.

[0148]

다른 실시예에 따르면, 선택된 Y개의 인트라 예측 모드들 중 하나의 인트라 예측 모드가 인트라 블록 복사 기반 예측 모드이고, 선택된 인트라 예측 모드들에 관한 조건이 충족된 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다. 반면, 선택된 인트라 예측 모드들에 관한 조건이 충족되지 않은 경우, 현재 블록의 예측 샘플은, 가장 낮은 비용 값을 가지는 현재 템플릿의 예측 샘플을 유도하기 위해 사용된 하나의 인트라 예측 모드를 이용하여 유도될 수 있다. 예를 들어, 인트라 블록 복사를 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값이 가장 작은 경우, 인트라 블록 복사를 이용하여 현재 블록의 예측 블록이 생성될 수 있다.

[0149]

또 다른 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에 따른 후보 인트라 예측 모드들 중에서 선택된 K개의 인트라 예측 모드들을 이용하여 유도된 예측 샘플들을 가중합하는 경우, 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 템플릿 기반 인트라 예측 모드 유도 방법에서 항상 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 또는 선택된 K개의 인트라 예측 모드들이 미리 정의된 소정의 인트라 예측 모드를 포함하지 않는 경우에 한하여, 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 또는 선택된 K개의 인트라 예측 모드들 중에서, 가장 높은 비용 값을 가지는 인트라 예측 모드가 미리 정의된 소정의 인트라 예측 모드로 대체될 수 있다. 여기서, 소정의 인트라 예측 모드는 플래너 모드, DC 모드와 같이 미리 정의된 인트라 예측 모드일 수 있다.

[0150]

예를 들어, 수학식 4와 같이 선택된 K개의 인트라 예측 모드들과 미리 정의된 소정의 인트라 예측 모드인 플래너 모드를 사용하여 유도된 예측 샘플을 가중합하여 예측 샘플이 생성될 수 있다.

[0151]

[0152]

여기서, Pred는 최종 예측 값을 의미할 수 있다. PredM1은 M1 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredM2는 M2 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredMK은 MK 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredPlanar는 플래너 모드를 이용한 예측 샘플 값을 의미할 수 있다.

[0153]

ωM1은 M1 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. ωM2는 M2 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. ωMK는 MK 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 그리고, ωPlanar는 플래너 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 각각의 가중치 값은 0이하 1 이하의 실수이고, 각각의 가중치 값들의 합은 1이다.

[0154]

또한, 본 발명의 일 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에 따른 후보 인트라 예측 모드로 사용되는 인트라 블록 복사 기반 예측 모드에서 사용되는 블록 벡터(block vector, BV)는 정수 화소 (integer-pel) 또는/및 부화소(fractional-pel) 단위의 정밀도를 가질 수 있다. 인트라 블록 복사 기반 예측 모드의 블록 벡터는 임의의 버퍼(ex. BV 버퍼, history-based motion vector prediction (HMVP) 버퍼 등)에 정수 화소 또는/및 부화소 단위의 정밀도로 저장될 수 있다. 정수 화소 또는/및 부화소 정밀도를 가지도록 저장된 블록 벡터는 현재 블록 이후에 블록들의 부호화/복호화 과정에서 사용될 수 있다.

[0155]

블록 벡터의 정수 화소 단위의 정밀도는 1 화소 이외에도 2, 4, 8, 16 등의 2의 자승 단위의 정수 값을 가질 수 있다. 그리고, 블록 벡터의 부화소 단위의 정밀도는 1/2, 1/4, 1/8, 1/16 등의 값을 가질 수 있다. 부화소 단위의 정밀도를 가지는 샘플을 생성하기 위하여, 미리 설계된 임의의 탭 수를 갖는 보간 필터, 임의의 탭 수를 갖는 큐빅(cubic) 보간 필터, 임의의 탭 수를 갖는 가우시안(Gaussian) 보간 필터, 이중 선형 보간 필터 (bilinear interpolation filter) 등이 사용될 수 있다. 1차원 보간 필터가 사용되는 경우 수평, 수직 또는 수직, 수평 순서로 보간 필터가 순차적으로 적용될 수 있다. 부화소 정밀도의 샘플을 생성하기 위한 보간 필터를 적용하는 과정에서, 참조 영역(reference area)의 경계에 위치한 일부 입력 샘플을 사용할 수 없는 경우(not available), 일부 입력 샘플은 패딩(padding)을 통해 생성되거나, 임의의 값으로 대체될 수 있다.

[0156]

블록 벡터의 정밀도의 단위를 지시하는 정보는 상위 레벨(high level)(예를 들어, VPS(video parameter set), SPS(sequence parameter set), PPS(picture parameter set), 픽처 헤더(picture header), 슬라이스 헤더(slice header) 등)에서 시그널링되는 TIMD 사용 여부(ex. timd_enabled_flag) 또는 TIMD 확장 여부(ex. timd_extension_flag)에 종속되어 하위 계층(low level)(예를 들어, CU(coding unit), PU(prediction unit), TU(transform unit) 등)에서 시그널링 될 수도 있다. 이 경우, 복호화기는 로우 레벨에서 시그널링 되는 구문요소(또는 구문요소들)의 값에 따라 TIMD의 후보 인트라 예측 모드인 인트라 블록 복사 기반 예측 모드에 사용되는 블록 벡터의 정밀도의 단위 정보(1, 2, 4, 8, 16 등의 정화소 정밀도 또는 1/2, 1/4, 1/8, 1/16 등의 부화소 정밀도)를 확인할 수 있다.

[0158]

본 발명의 다른 실시예에 따르면, 공간적 결합된 인트라-인트라 예측(spatial combined intra-intra prediction, SCIIP) 모드가 템플릿 기반 인트라 예측 모드 유도 방법을 위한 후보 인트라 예측 모드로 사용될 수 있다. 본 발명의 일 실시 예에 따른 SCIIP 및 SCIIP를 이용하여 템플릿 기반 인트라 예측 모드 유도 방법을 기반으로 인트라 예측을 수행하는 방법을 설명하도록 한다.

[0159]

도 7은 본 발명의 일 실시 예에 따른 공간적 결합된 인트라-인트라 예측 방법을 설명하기 위한 도면이다.

[0160]

도 7을 참고하면, 현재 블록(current block, 710)의 예측 블록은 서로 다른 인트라 예측 모드에 따라 생성되는 서로 다른 예측 블록들의 가중합을 통해 생성될 수 있다. 여기서, 서로 다른 인트라 예측 모드들은 일반적인 인트라 예측 모드들, WAIP 모드들, 인트라 템플릿 매칭 예측 모드, 인트라 블록 복사 모드를 포함할 수 있다. 그리고, 공간적 결합된 인트라-인트라 예측에 사용되는 인트라 예측 모드들의 개수는 2개일 수 있다.

[0161]

여기서, 공간적 결합된 인트라-인트라 예측에 사용되는 인트라 예측 모드들 중 적어도 하나의 인트라 예측 모드가 일반적인 인트라 예측 모드 및/또는 WAIP 모드인 경우, 현재 블록(710)의 예측 블록은 인트라 예측 모드 및 현재 블록의 이웃한 샘플(720)을 이용하여 생성된 예측 블록과 다른 인트라 예측 모드를 기초로 생성된 예측 블록을 가중합하여 통해 생성될 수 있다.

[0162]

여기서, 공간적 결합된 인트라-인트라 예측에 사용되는 인트라 예측 모드들 중 적어도 하나의 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드 및/또는 인트라 블록 복사 모드인 경우, 현재 블록(710)의 예측 블록은 매칭 블록(730)을 기초로 생성된 예측 블록과 다른 인트라 예측 모드를 기초로 생성된 예측 블록을 가중합하여 통해 생성될 수 있다.

[0163]

공간적 결합된 인트라-인트라 예측에 사용되는 인트라 예측 모드들 중 하나의 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드인 경우, 현재 블록에 이웃한 샘플(720) 및/또는 블록 벡터(740)을 기초로, 매칭 블록에 이웃한 샘플(750)이 탐색될 수 있다. 그리고, 매칭 블록에 이웃한 샘플(750) 탐색 결과를 기초로 매칭 블록(730)이 유도될 수 있다. 현재 블록(710)의 예측 블록은 매칭 블록(730)을 기초로 생성된 예측 블록과 다른 인트라 예측 모드를 기초로 생성된 예측 블록을 가중합하여 통해 생성될 수 있다.

[0164]

공간적 결합된 인트라-인트라 예측에 사용되는 인트라 예측 모드들 중 적어도 하나의 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드 및/또는 인트라 블록 복사 모드인 경우, 매칭 블록(730)은 현재 블록의 블록 벡터를 기초로 유도될 수 있다. 현재 블록(710)의 예측 블록은 매칭 블록(730)을 기초로 생성된 예측 블록과 다른 인트라 예측 모드를 기초로 생성된 예측 블록을 가중합하여 통해 생성될 수 있다.

[0165]

본 발명의 일 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에서 사용되는 후보 인트라 예측 모드는 공간적 결합된 인트라-인트라 예측 모드를 더 포함할 수 있다. 그리고, 후보 인트라 예측 모드들 중에서, 가장 낮은 비용 값을 가지는 2 개의 현재 템플릿의 예측 샘플을 유도하는 2 개의 인트라 예측 모드들이 선택될 수 있다. 여기서, 선택된 2 개의 인트라 예측 모드들 중 하나의 모드가 공간적 결합된 인트라-인트라 예측 모드인 경우, 아래의 수학식 5와 같이 공간적 결합된 인트라-인트라 예측 모드를 이용하여 유도된 예측 샘플과 다른 인트라 예측 모드를 이용하여 유도된 예측 샘플들을 가중합하여 현재 블록에 대한 예측 샘플이 유도될 수 있다.

[0166]

[0167]

여기서, Pred는 최종 예측 값을 의미할 수 있다. PredM1은 M1 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredM2는 M2 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. ωM1은 M1 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 그리고, ωM2는 M2 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 여기서, 0 ≤ ωM1≤ 1이고, 0 ≤ ωM2≤ 1이다.

[0168]

CostM1은 M1 모드를 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값을 의미할 수 있다. 그리고, CostM2는 M2 모드를 이용하여 유도된 현재 템플릿의 예측 샘플에 적용되는 비용 값을 의미할 수 있다. 여기서, 비용 값은 SAD (sum of absolute differences), MSE (mean squared error), SSD (sum of squared differences), SATD (sum of absolute transformed differences) 등의 비용 함수를 사용하여 도출될 수 있다.

[0169]

본 발명의 다른 실시예에 따르면, 선택된 인트라 예측 모드들 중 하나가 공간적 결합된 인트라-인트라 예측 모드이고, 선택된 인트라 예측 모드들에 관한 조건이 충족된 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다. 예를 들어, 선택된 제1 인트라 예측 모드를 이용하여 생성된 예측 샘플의 비용 값이 선택된 제2 인트라 예측 모드를 이용하여 생성된 예측 샘플의 비용 값의 실수 배 이하인 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다.

[0170]

반면, 선택된 인트라 예측 모드들에 관한 조건이 충족되지 않은 경우, 현재 블록의 예측 샘플은, 가장 낮은 비용 값을 가지는 현재 템플릿의 예측 샘플을 유도하기 위해 사용된 하나의 인트라 예측 모드를 이용하여 유도될 수 있다. 예를 들어, 공간적 결합된 인트라-인트라 예측을 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값이 가장 작은 경우, 공간적 결합된 인트라-인트라 예측을 이용하여 현재 블록의 예측 블록이 생성될 수 있다.

[0171]

후보 인트라 예측 모드들 중에서, Z개의 인트라 예측 모드들이 최종적으로 선택될 수 있다. 즉, 공간적 결합된 인트라-인트라 예측 모드를 포함하는 후보 인트라 예측 모드들 중에서, 비용 값이 작은 순으로 Z개의 인트라 예측 모드들 M1, M2, …, MZ가 선택될 수 있다. 선택된 인트라 예측 모드들 중 하나의 인트라 예측 모드가 공간적 결합된 인트라-인트라 예측 모드인 경우, 현재 블록에 대해 공간적 결합된 인트라-인트라 예측을 수행하여 유도된 예측 샘플과 다른 후보 인트라 예측 모드들을 이용하여 유도된 예측 샘플들이 가중합될 수 있다.

[0172]

다른 실시예에 따르면, 선택된 Y개의 인트라 예측 모드들 중 하나의 인트라 예측 모드가 공간적 결합된 인트라-인트라 예측 모드이고, 선택된 인트라 예측 모드들에 관한 조건이 충족된 경우, 선택된 인트라 예측 모드들을 이용하여 생성된 예측 샘플들을 가중합하여 현재 블록에 대한 최종 예측 샘플을 유도할 수 있다. 반면, 선택된 인트라 예측 모드들에 관한 조건이 충족되지 않은 경우, 현재 블록의 예측 샘플은, 가장 낮은 비용 값을 가지는 현재 템플릿의 예측 샘플을 유도하기 위해 사용된 하나의 인트라 예측 모드를 이용하여 유도될 수 있다. 예를 들어, 공간적 결합된 인트라-인트라 예측 모드를 이용하여 유도된 현재 템플릿의 예측 샘플의 비용 값이 가장 작은 경우, 공간적 결합된 인트라-인트라 예측 모드를 이용하여 현재 블록의 예측 블록이 생성될 수 있다.

[0173]

또 다른 실시예에 따르면, 템플릿 기반 인트라 예측 모드 유도 방법에 따른 후보 인트라 예측 모드들 중에서 선택된 L개의 인트라 예측 모드들을 이용하여 유도된 예측 샘플들을 가중합하는 경우, 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 템플릿 기반 인트라 예측 모드 유도 방법에서 항상 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 또는 선택된 L개의 인트라 예측 모드들이 미리 정의된 소정의 인트라 예측 모드를 포함하지 않는 경우에 한하여, 미리 정의된 소정의 인트라 예측 모드를 사용하여 유도된 예측 샘플을 가중합할 수 있다. 또는 선택된 L개의 인트라 예측 모드들 중에서, 가장 높은 비용 값을 가지는 인트라 예측 모드가 미리 정의된 소정의 인트라 예측 모드로 대체될 수 있다. 여기서, 소정의 인트라 예측 모드는 플래너 모드, DC 모드와 같이 미리 정의된 인트라 예측 모드일 수 있다.

[0174]

예를 들어, 수학식 6과 같이 선택된 L개의 인트라 예측 모드들과 미리 정의된 소정의 인트라 예측 모드인 플래너 모드를 사용하여 유도된 예측 샘플을 가중합하여 예측 샘플이 생성될 수 있다.

[0175]

[0176]

여기서, Pred는 최종 예측 값을 의미할 수 있다. PredM1은 M1 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredM2는 M2 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredML은 ML 후보 인트라 예측 모드를 이용한 예측 샘플 값을 의미할 수 있다. PredPlanar는 플래너 모드를 이용한 예측 샘플 값을 의미할 수 있다.

[0177]

ωM1은 M1 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. ωM2는 M2 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. ωML는 ML 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 그리고, ωPlanar는 플래너 모드를 이용하여 유도된 예측 샘플에 적용되는 가중치 값을 의미할 수 있다. 각각의 가중치 값은 0이하 1 이하의 실수이고, 각각의 가중치 값들의 합은 1이다.

[0178]

일 실시예에 따르면, 공간적 결합된 인트라-인트라 예측 모드에 사용되는 두 개의 인트라 예측 모드들 중 하나는, 인트라 템플릿 매칭 예측 모드일 수 있다. 이 경우, 공간적 결합된 인트라-인트라 예측 모드는 인트라 템플릿 매칭 예측 모드의 하위 모드로 정의될 수 있다.

[0179]

공간적 결합된 인트라-인트라 예측 모드가 인트라 템플릿 매칭 예측 모드의 하위 모드인 경우, 공간적 결합된 인트라-인트라 예측 모드는 인트라 템플릿 매칭 예측 모드와 별개의 후보 인트라 예측 모드로 고려되지 않을 수 있다. 즉, 공간적 결합된 인트라-인트라 예측 모드와 인트라 템플릿 매칭 예측 모드는, 하나의 후보 인트라 예측 모드로 고려될 수 있다.

[0180]

템플릿 기반 인트라 예측 모드 유도 과정에서 사용되는 후보 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드 및/또는 공간적 결합된 인트라-인트라 예측 모드인지 여부는 명시적으로 (explicitly) 시그널링 될 수 있다. 인트라 템플릿 매칭 예측 모드 및/또는 공간적 결합된 인트라-인트라 예측 모드의 사용 여부를 지시하는 정보를 시그널링하는 방법은 아래에 설명하는 바와 같을 수 있다.

[0181]

TIFFpat00007.tif15123

[0182]

여기서, intra_tmp_flag는 인트라 템플릿 매칭 예측 모드의 사용 여부를 지시하는 구문 요소(syntax element)이고, spatial_ciip_flag는 공간적 결합된 인트라-인트라 예측 모드의 사용 여부를 지시하는 구문 요소(syntax element)일 수 있다.

[0183]

구체적으로, 공간적 결합된 인트라-인트라 예측 모드가 인트라 템플릿 매칭 예측 모드의 하위 모드인 경우, spatial_ciip_flag는 intra_tmp_flag에 종속적으로 시그널링 될 수 있다. 즉, 먼저 시그널링되는 intra_tmp_flag의 값이 1인 경우에만, spatial_ciip_flag가 시그널링 될 수 있다.

[0184]

템플릿 기반 인트라 예측 모드 유도 과정에서 사용되는 후보 인트라 예측 모드가 인트라 템플릿 매칭 예측 모드인 경우, intra_tmp_flag은 1로 시그널링되고, spatial_ciip_flag는 0으로 시그널링될 수 있다. 반면, 템플릿 기반 인트라 예측 모드 유도 과정에서 사용되는 후보 인트라 예측 모드가 공간적 결합된 인트라-인트라 예측 모드인 경우, intra_tmp_flag와 spatial_ciip_flag는 1로 시그널링될 수 있다.

[0186]

도 8은 본 발명의 일 실시 예에 따른 영상 복호화 방법을 나타내는 흐름도이다.

[0187]

영상 복호화 장치는 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정할 수 있다(S810).

[0188]

영상 복호화 장치는 복수의 후보 인트라 예측 모드들 중에서, 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정할 수 있다(S820). 여기서, 복수의 후보 인트라 예측 모드는, 현재 블록의 블록 벡터를 기초로 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함할 수 있다.

[0189]

영상 복호화 장치는 제1 인트라 예측 모드에 기초하여 현재 블록의 제1 예측 블록을 유도할 수 있다(S830);

[0190]

영상 복호화 장치는 제2 인트라 예측 모드에 기초하여 현재 블록의 제2 예측 블록을 유도할 수 있다(S840).

[0191]

영상 복호화 장치는 소정의 인트라 예측 모드에 기초하여 현재 블록의 제3 예측 블록을 유도할 수 있다(S850).

[0192]

영상 복호화 장치는 제1 예측 블록, 제2 예측 블록 및 제3 예측 블록의 가중 합에 기초하여, 현재 블록의 최종 예측 블록을 유도할 수 있다(S840).

[0193]

그리고, 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가질 수 있다.

[0194]

여기서, 소정의 인트라 예측 모드는, 하나의 비방향성 인트라 예측 모드일 수 있다.

[0195]

여기서, 제1 인트라 예측 모드는, 인트라 템플릿 매칭 예측 모드(intra template matching prediction mode, IntraTMP)일 수 있다.

[0196]

여기서, 제1 예측 블록에 적용되는 가중치는, 인트라 템플릿 매칭 예측 모드를 기초로 예측된 현재 템플릿의 비용 값을 기초로 결정될 수 있다.

[0197]

여기서, 현재 블록의 최종 예측 블록을 유도하는 단계는, 인트라 템플릿 매칭 예측 모드를 기초로 예측된 현재 템플릿의 비용 값과 제2 인트라 예측 모드를 기초로 유도된 예측된 현재 템플릿의 비용 값의 비교 결과를 기초로, 제1 예측 블록과 제2 예측 블록을 가중 합할 수 있다.

[0198]

여기서, 현재 블록의 블록 벡터의 정밀도는, 인트라 템플릿 매칭 예측 모드의 블록 벡터의 정밀도를 지시하는 정보를 기초로 결정될 수 있다.

[0199]

여기서, 인트라 템플릿 매칭 예측 모드의 블록 벡터의 정밀도를 지시하는 정보는, TIMD에 관한 정보에 종속적으로 시그널링될 수 있다.

[0200]

여기서, 제1 인트라 예측 모드는, 인트라 블록 복사(intra block copy, IBC)인 것을 특징으로 할 수 있다.

[0201]

여기서, 제1 예측 블록에 적용되는 가중치는, 인트라 블록 복사를 기반으로 예측된 현재 템플릿의 비용 값을 기초로 결정될 수 있다.

[0202]

여기서, 현재 블록의 최종 예측 블록을 유도하는 단계는, 인트라 블록 복사를 기반으로 예측된 현재 템플릿의 비용 값과 제2 인트라 예측 모드를 기초로 유도된 예측된 현재 템플릿의 비용 값의 비교 결과를 기초로, 제1 예측 블록과 제2 예측 블록을 가중 합할 수 있다.

[0203]

여기서, 현재 블록의 블록 벡터의 정밀도는, 인트라 블록 복사에 사용되는 블록 벡터의 정밀도를 지시하는 정보를 기초로 결정될 수 있다.

[0204]

여기서, 인트라 블록 복사에 사용되는 블록 벡터의 정밀도를 지시하는 정보는, TIMD에 관한 정보에 종속적으로 시그널링될 수 있다.

[0205]

여기서, 복수의 후보 인트라 예측 모드는, 서로 다른 인트라 예측 모드를 이용하는 공간적 결합된 인트라-인트라 예측(spatial combined intra-intra prediction, SCIIP) 모드를 포함하고, 제1 인트라 예측 모드는, SCIIP 모드인 것을 특징으로 할 수 있다.

[0206]

여기서, 제1 예측 블록에 적용되는 가중치는, SCIIP 모드를 기초로 예측된 현재 템플릿의 비용 값을 기초로 결정될 수 있다.

[0207]

여기서, 현재 블록의 최종 예측 블록을 유도하는 단계는, SCIIP 모드를 기초로 예측된 현재 템플릿의 비용 값과 제2 인트라 예측 모드를 기초로 유도된 예측된 현재 템플릿의 비용 값의 비교 결과를 기초로, 제1 예측 블록과 제2 예측 블록을 가중 합할 수 있다.

[0208]

여기서, 제1 인트라 예측 모드는, SCIIP 모드를 지시하는 정보에 기초하여, SCIIP 모드로 결정될 수 있다. 그리고, SCIIP 모드를 지시하는 정보는, 인트라 템플릿 매칭 예측에 관한 정보에 종속적으로 시그널링될 수 있다.

[0209]

한편, 도 8에서 설명한 단계들은 영상 부호화 방법에서도 수행될 수 있다. 또한, 도 8에서 설명한 단계를 포함하는 영상 부호화 방법에 의해 비트스트림이 생성될 수 있다. 상기 비트스트림은 비 일시적 컴퓨터 판독가능한 기록매체에 저장될 수 있으며, 또한, 전송(또는 스트리밍)될 수 있다.

[0211]

도 9는 본 발명에 따른 실시예가 적용될 수 있는 컨텐츠 스트리밍 시스템을 예시적으로 나타내는 도면이다.

[0212]

도 9에 도시된 바와 같이, 본 발명의 실시예가 적용된 컨텐츠 스트리밍 시스템은 크게 인코딩 서버, 스트리밍 서버, 웹 서버, 미디어 저장소, 사용자 장치 및 멀티미디어 입력 장치를 포함할 수 있다.

[0213]

상기 인코딩 서버는 스마트폰, 카메라, CCTV 등과 같은 멀티미디어 입력 장치들로부터 입력된 컨텐츠를 디지털 데이터로 압축하여 비트스트림을 생성하고 이를 상기 스트리밍 서버로 전송하는 역할을 한다. 다른 예로, 스마트폰, 카메라, CCTV 등과 같은 멀티미디어 입력 장치들이 비트스트림을 직접 생성하는 경우, 상기 인코딩 서버는 생략될 수도 있다.

[0214]

상기 비트스트림은 본 발명의 실시예가 적용된 영상 부호화 방법 및/또는 영상 부호화 장치에 의해 생성될 수 있고, 상기 스트리밍 서버는 상기 비트스트림을 전송 또는 수신하는 과정에서 일시적으로 상기 비트스트림을 저장할 수 있다.

[0215]

상기 스트리밍 서버는 웹 서버를 통한 사용자 요청에 기반하여 멀티미디어 데이터를 사용자 장치에 전송하고, 상기 웹 서버는 사용자에게 어떠한 서비스가 있는지를 알려주는 매개체 역할을 할 수 있다. 사용자가 상기 웹 서버에 원하는 서비스를 요청하면, 상기 웹 서버는 이를 스트리밍 서버에 전달하고, 상기 스트리밍 서버는 사용자에게 멀티미디어 데이터를 전송할 수 있다. 이때, 상기 컨텐츠 스트리밍 시스템은 별도의 제어 서버를 포함할 수 있고, 이 경우 상기 제어 서버는 상기 컨텐츠 스트리밍 시스템 내 각 장치 간 명령/응답을 제어하는 역할을 수행할 수 있다.

[0216]

상기 스트리밍 서버는 미디어 저장소 및/또는 인코딩 서버로부터 컨텐츠를 수신할 수 있다. 예를 들어, 상기 인코딩 서버로부터 컨텐츠를 수신하는 경우, 상기 컨텐츠를 실시간으로 수신할 수 있다. 이 경우, 원활한 스트리밍 서비스를 제공하기 위하여 상기 스트리밍 서버는 상기 비트스트림을 일정 시간동안 저장할 수 있다.

[0217]

상기 사용자 장치의 예로는, 휴대폰, 스마트 폰(smart phone), 노트북 컴퓨터(laptop computer), 디지털방송용 단말기, PDA(personal digital assistants), PMP(portable multimedia player), 네비게이션, 슬레이트 PC(slate PC), 태블릿 PC(tablet PC), 울트라북(ultrabook), 웨어러블 디바이스(wearable device, 예를 들어, 워치형 단말기 (smartwatch), 글래스형 단말기 (smart glass), HMD(head mounted display)), 디지털 TV, 데스크탑 컴퓨터, 디지털 사이니지 등이 있을 수 있다.

[0218]

상기 컨텐츠 스트리밍 시스템 내 각 서버들은 분산 서버로 운영될 수 있으며, 이 경우 각 서버에서 수신하는 데이터는 분산 처리될 수 있다.

[0220]

상기의 실시예들은 부호화 장치 및 복호화 장치에서 동일한 방법 또는 상응하는 방법으로 수행될 수 있다. 또한, 상기 실시예들 중 적어도 하나 혹은 적어도 하나의 조합을 이용해서 영상을 부호화/복호화할 수 있다.

[0221]

상기 실시예들이 적용되는 순서는 부호화 장치와 복호화 장치에서 상이할 수 있다. 또는, 상기 실시예들이 적용되는 순서는 부호화 장치와 복호화 장치에서 동일할 수 있다.

[0222]

상기 실시예들은 휘도 및 색차 신호 각각에 대하여 수행될 수 있다. 또는, 휘도 및 색차 신호에 대한 상기 실시예들이 동일하게 수행될 수 있다.

[0223]

상기 실시예들에서, 방법들은 일련의 단계 또는 유닛으로서 순서도를 기초로 설명되고 있으나, 본 발명은 단계들의 순서에 한정되는 것은 아니며, 어떤 단계는 상술한 바와 다른 단계와 다른 순서로 또는 동시에 발생할 수 있다. 또한, 당해 기술 분야에서 통상의 지식을 가진 자라면 순서도에 나타난 단계들이 배타적이지 않고, 다른 단계가 포함되거나, 순서도의 하나 또는 그 이상의 단계가 본 발명의 범위에 영향을 미치지 않고 삭제될 수 있음을 이해할 수 있을 것이다.

[0224]

상기 실시예들은 다양한 컴퓨터 구성요소를 통하여 수행될 수 있는 프로그램 명령어의 형태로 구현되어 컴퓨터 판독 가능한 기록 매체에 기록될 수 있다. 상기 컴퓨터 판독 가능한 기록 매체는 프로그램 명령어, 데이터 파일, 데이터 구조 등을 단독으로 또는 조합하여 포함할 수 있다. 상기 컴퓨터 판독 가능한 기록 매체에 기록되는 프로그램 명령어는 본 발명을 위하여 특별히 설계되고 구성된 것들이거나 컴퓨터 소프트웨어 분야의 당업자에게 공지되어 사용 가능한 것일 수도 있다.

[0225]

상기 실시예에 따른 부호화 방법에 의해 생성된 비트스트림은 비 일시적인 컴퓨터 판독 가능한 기록 매체에 저장될 수 있다. 또한, 상기 비 일시적인 컴퓨터 판독 가능한 기록 매체에 저장되는 비트스트림은 상기 실시예에 따른 복호화 방법에 의해 복호화될 수 있다.

[0226]

여기서, 컴퓨터 판독 가능한 기록 매체의 예에는, 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체, CD-ROM, DVD와 같은 광기록 매체, 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical media), 및 ROM, RAM, 플래시 메모리 등과 같은 프로그램 명령어를 저장하고 수행하도록 특별히 구성된 하드웨어 장치가 포함된다. 프로그램 명령어의 예에는, 컴파일러에 의해 만들어지는 것과 같은 기계어 코드뿐만 아니라 인터프리터 등을 사용해서 컴퓨터에 의해서 실행될 수 있는 고급 언어 코드도 포함된다. 상기 하드웨어 장치는 본 발명에 따른 처리를 수행하기 위해 하나 이상의 소프트웨어 모듈로서 작동하도록 구성될 수 있으며, 그 역도 마찬가지이다.

[0227]

이상에서 본 발명이 구체적인 구성요소 등과 같은 특정 사항들과 한정된 실시예 및 도면에 의해 설명되었으나, 이는 본 발명의 보다 전반적인 이해를 돕기 위해서 제공된 것일 뿐, 본 발명이 상기 실시예들에 한정되는 것은 아니며, 본 발명이 속하는 기술분야에서 통상적인 지식을 가진 자라면 이러한 기재로부터 다양한 수정 및 변형을 꾀할 수 있다.

[0228]

따라서, 본 발명의 사상은 상기 설명된 실시예에 국한되어 정해져서는 아니 되며, 후술하는 특허청구범위뿐만 아니라 이 특허청구범위와 균등하게 또는 등가적으로 변형된 모든 것들은 본 발명의 사상의 범주에 속한다고 할 것이다.



[0001a]

영상 부호화/복호화 방법, 장치, 비트스트림을 저장한 기록 매체 및 전송 방법이 제공된다. 영상 복호화 방법은 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계, 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계, 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계, 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계, 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계, 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고, 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 할 수 있다.



1.

영상 복호화 방법에 있어서, 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계; 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계; 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계; 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계; 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계; 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고, 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 하는, 영상 복호화 방법.

2.

제1항에 있어서, 상기 소정의 인트라 예측 모드는, 하나의 비방향성 인트라 예측 모드인 것을 특징으로 하는, 영상 복호화 방법.

3.

제1항에 있어서, 상기 제1 인트라 예측 모드는, 인트라 템플릿 매칭 예측 모드(intra template matching prediction mode, IntraTMP)인 것을 특징으로 하는, 영상 복호화 방법.

4.

제3항에 있어서, 상기 제1 예측 블록에 적용되는 가중치는, 상기 인트라 템플릿 매칭 예측 모드를 기초로 예측된 상기 현재 템플릿의 비용 값을 기초로 결정되는, 영상 복호화 방법.

5.

제3항에 있어서, 상기 현재 블록의 최종 예측 블록을 유도하는 단계는, 상기 인트라 템플릿 매칭 예측 모드를 기초로 예측된 상기 현재 템플릿의 비용 값과 상기 제2 인트라 예측 모드를 기초로 유도된 예측된 상기 현재 템플릿의 비용 값의 비교 결과를 기초로, 상기 제1 예측 블록과 상기 제2 예측 블록을 가중 합하는, 영상 복호화 방법.

6.

제5항에 있어서, 상기 현재 블록의 블록 벡터의 정밀도는, 인트라 템플릿 매칭 예측 모드의 블록 벡터의 정밀도를 지시하는 정보를 기초로 결정되는, 영상 복호화 방법.

7.

제6항에 있어서,상기 인트라 템플릿 매칭 예측 모드의 블록 벡터의 정밀도를 지시하는 정보는, TIMD에 관한 정보에 종속적으로 시그널링되는, 영상 복호화 방법.

8.

제1항에 있어서, 상기 제1 인트라 예측 모드는, 인트라 블록 복사(intra block copy, IBC)인 것을 특징으로 하는, 영상 복호화 방법.

9.

제8항에 있어서, 상기 제1 예측 블록에 적용되는 가중치는, 상기 인트라 블록 복사를 기반으로 예측된 상기 현재 템플릿의 비용 값을 기초로 결정되는, 영상 복호화 방법.

10.

제8항에 있어서, 상기 현재 블록의 최종 예측 블록을 유도하는 단계는, 상기 인트라 블록 복사를 기반으로 예측된 상기 현재 템플릿의 비용 값과 상기 제2 인트라 예측 모드를 기초로 유도된 예측된 상기 현재 템플릿의 비용 값의 비교 결과를 기초로, 상기 제1 예측 블록과 상기 제2 예측 블록을 가중 합하는, 영상 복호화 방법.

11.

제8항에 있어서, 상기 현재 블록의 블록 벡터의 정밀도는, 인트라 블록 복사에 사용되는 블록 벡터의 정밀도를 지시하는 정보를 기초로 결정되는, 영상 복호화 방법.

12.

제11항에 있어서,상기 인트라 블록 복사에 사용되는 블록 벡터의 정밀도를 지시하는 정보는, TIMD에 관한 정보에 종속적으로 시그널링되는, 영상 복호화 방법.

13.

제1항에 있어서, 상기 복수의 후보 인트라 예측 모드는,서로 다른 인트라 예측 모드를 이용하는 공간적 결합된 인트라-인트라 예측(spatial combined intra-intra prediction, SCIIP) 모드를 포함하고, 상기 제1 인트라 예측 모드는, 상기 SCIIP 모드인 것을 특징으로 하는, 영상 복호화 방법.

14.

제13항에 있어서, 상기 제1 예측 블록에 적용되는 가중치는, 상기 SCIIP 모드를 기초로 예측된 상기 현재 템플릿의 비용 값을 기초로 결정되는, 영상 복호화 방법.

15.

제13항에 있어서, 상기 현재 블록의 최종 예측 블록을 유도하는 단계는, 상기 SCIIP 모드를 기초로 예측된 상기 현재 템플릿의 비용 값과 상기 제2 인트라 예측 모드를 기초로 유도된 예측된 상기 현재 템플릿의 비용 값의 비교 결과를 기초로, 상기 제1 예측 블록과 상기 제2 예측 블록을 가중 합하는, 영상 복호화 방법.

16.

제13항에 있어서, 상기 제1 인트라 예측 모드는, 상기 SCIIP 모드를 지시하는 정보에 기초하여, 상기 SCIIP 모드로 결정되고, 상기 SCIIP 모드를 지시하는 정보는, 인트라 템플릿 매칭 예측에 관한 정보에 종속적으로 시그널링되는, 영상 복호화 방법.

17.

영상 부호화 방법에 있어서,현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계; 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계; 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계; 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계; 및 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계; 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고, 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 하는, 영상 부호화 방법.

18.

영상 부호화 방법에 의해 생성된 비트스트림을 저장하는 비 일시적 컴퓨터 판독가능한 기록 매체에 있어서,상기 영상 부호화 방법은, 현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계; 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계; 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계; 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계; 및 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계; 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고, 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 하는, 비 일시적 컴퓨터 판독가능한 기록 매체.

19.

영상 부호화 방법에 의해 생성된 비트스트림의 전송 방법에 있어서,상기 전송 방법은 상기 비트스트림을 전송하는 단계를 포함하고,상기 부호화 방법은,현재 블록의 인트라 예측 모드를 템플릿 기반 인트라 예측 모드 유도(template based intra prediction mode derivation, TIMD) 모드로 결정하는 단계; 복수의 후보 인트라 예측 모드들 중에서, 상기 현재 블록에 인접한 참조 샘플을 포함하는 현재 템플릿을 기초로, 상기 현재 블록의 제1 인트라 예측 모드 및 제2 인트라 예측 모드를 결정하는 단계; 상기 제1 인트라 예측 모드에 기초하여 상기 현재 블록의 제1 예측 블록을 유도하는 단계; 상기 제2 인트라 예측 모드에 기초하여 상기 현재 블록의 제2 예측 블록을 유도하는 단계; 및 소정의 인트라 예측 모드에 기초하여 상기 현재 블록의 제3 예측 블록을 유도하는 단계; 및 상기 제1 예측 블록, 상기 제2 예측 블록 및 상기 제3 예측 블록의 가중 합에 기초하여, 상기 현재 블록의 최종 예측 블록을 유도하는 단계를 포함하고, 상기 복수의 후보 인트라 예측 모드는, 상기 현재 블록의 블록 벡터를 기초로 상기 현재 블록의 예측 블록을 생성하는 인트라 예측 모드를 포함하고, 상기 현재 블록의 블록 벡터는, 정수 화소 또는 부화소 단위의 정밀도를 가지는 것을 특징으로 하는, 전송 방법.