RU2800133C2 - Method and device for coding/decoding image signals - Google Patents
Method and device for coding/decoding image signals Download PDFInfo
- Publication number
- RU2800133C2 RU2800133C2 RU2021111110A RU2021111110A RU2800133C2 RU 2800133 C2 RU2800133 C2 RU 2800133C2 RU 2021111110 A RU2021111110 A RU 2021111110A RU 2021111110 A RU2021111110 A RU 2021111110A RU 2800133 C2 RU2800133 C2 RU 2800133C2
- Authority
- RU
- Russia
- Prior art keywords
- block
- intra prediction
- current block
- prediction mode
- coding
- Prior art date
Links
Abstract
Description
ПРЕДПОСЫЛКИ ИЗОБРЕТЕНИЯBACKGROUND OF THE INVENTION
Область техники, к которой относится изобретениеThe field of technology to which the invention belongs
[01] Настоящее изобретение относится к способу и устройству для кодирования и декодирования видеосигнала.[01] The present invention relates to a method and apparatus for encoding and decoding a video signal.
Предшествующий уровень техникиPrior Art
[02] По мере увеличения дисплейных панелей, требуется все больше видеоуслуг более высокого качества. Самой большой проблемой видеоуслуг высокой четкости является значительное увеличение объема данных, и для решения этой проблемы активно проводятся исследования по улучшению степени сжатия видео. В качестве иллюстративного примера группа экспертов по кинематографии (MPEG) и группа экспертов по видеокодированию (VCEG) в рамках сектора по стандартизации телекоммуникаций в составе Международного союза электросвязи (ITU-T) сформировали объединенную команду по видеокодированию (JCT-VC) в 2009 году. JCT-VC предложила высокоэффективное видеокодирование (HEVC), которое представляет собой стандарт сжатия видео, имеющий эффективность сжатия примерно вдвое выше, чем эффективность сжатия H.264/AVC, и он одобрен в качестве стандарта 25 января 2013 г.С быстрым развитием видеоуслуг высокой четкости эффективность HEVC постепенно обнаруживает свои ограничения.[02] As display panels get bigger, more and more higher quality video services are needed. The biggest problem of high-definition video services is a significant increase in data volume, and to solve this problem, research is being actively conducted to improve the degree of video compression. As an illustrative example, the Motion Picture Experts Group (MPEG) and the Video Coding Experts Group (VCEG) within the Telecommunication Standardization Sector of the International Telecommunication Union (ITU-T) formed the Joint Video Coding Team (JCT-VC) in 2009. JCT-VC proposed High Efficiency Video Coding (HEVC), which is a video compression standard that has a compression efficiency about twice that of H.264/AVC, and it was approved as a standard on January 25, 2013. With the rapid development of high-definition video services, the efficiency of HEVC is gradually discovering its limitations.
СУЩНОСТЬ ИЗОБРЕТЕНИЯSUMMARY OF THE INVENTION
[03] Целью настоящего изобретения является предоставление способа получения кандидатного режима внутреннего предсказания на основании режима внутреннего предсказания соседнего блока, смежного с текущим блоком, при кодировании/декодировании видеосигнала и устройства для выполнения способа.[03] An object of the present invention is to provide a method for obtaining a candidate intra prediction mode based on the intra prediction mode of an adjacent block adjacent to the current block when encoding/decoding a video signal, and an apparatus for performing the method.
[04] Еще одной целью настоящего изобретения является предоставление способа разбиения блока кодирования или блока преобразования на множество подблоков и выполнения внутреннего предсказания в отношении каждого из подблоков при кодировании/декодировании видеосигнала и устройства для выполнения способа.[04] Yet another object of the present invention is to provide a method for partitioning an encoding block or a transformation block into a plurality of subblocks and performing intra prediction on each of the subblocks when encoding/decoding a video signal, and an apparatus for performing the method.
[05] Еще одной целью настоящего изобретения является предоставление способа разбиения блока кодирования или блока преобразования на множество подблоков и выполнения преобразования только в отношении некоторых из подблоков при кодировании/декодировании видеосигнала и устройства для выполнения способа.[05] Yet another object of the present invention is to provide a method for splitting an encoding block or a transformation block into a plurality of subblocks and performing transformation on only some of the subblocks when encoding/decoding a video signal, and a device for performing the method.
[06] Технические задачи, которые должны быть решены в настоящем изобретении, не ограничиваются техническими задачами, упомянутыми выше, и не упомянутые другие задачи могут быть ясно поняты специалистами в данной области техники из следующего описания.[06] The technical problems to be solved in the present invention are not limited to the technical problems mentioned above, and other problems not mentioned can be clearly understood by those skilled in the art from the following description.
[07] Способ декодирования/кодирования видеосигнала согласно настоящему изобретению включает следующие этапы: определение линии опорных отсчетов текущего блока; определение того, существует ли кандидатный режим внутреннего предсказания, который является таким же, как режим внутреннего предсказания текущего блока; получение режима внутреннего предсказания текущего блока на основании определения; и выполнение внутреннего предсказания в отношении текущего блока на основании линии опорных отсчетов и режима внутреннего предсказания. В этом случае по меньшей мере один из кандидатных режимов внутреннего предсказания может быть получен путем добавления смещения к максимальному значению из режима внутреннего предсказания верхнего соседнего блока текущего блока и режима внутреннего предсказания левого соседнего блока текущего блока или вычитания из него.[07] The method for decoding/encoding a video signal according to the present invention includes the following steps: determining a reference sample line of the current block; determining whether there is a candidate intra prediction mode that is the same as the intra prediction mode of the current block; obtaining an intra prediction mode of the current block based on the determination; and performing intra prediction on the current block based on the reference sample line and the intra prediction mode. In this case, at least one of the candidate intra prediction modes can be obtained by adding or subtracting an offset to the maximum value from the top neighbor block intra prediction mode of the current block and the left neighbor intra prediction mode of the current block.
[08] В способе декодирования/кодирования видеосигнала согласно настоящему изобретению по меньшей мере один из кандидатных режимов внутреннего предсказания может быть получен путем добавления 2 к максимальному значению или вычитания из него, когда разница между режимом внутреннего предсказания верхнего соседнего блока и режимом внутреннего предсказания левого соседнего блока составляет 64.[08] In the video decoding/coding method according to the present invention, at least one of the candidate intra prediction modes can be obtained by adding 2 to or subtracting from the maximum value when the difference between the intra prediction mode of the upper neighbor block and the intra prediction mode of the left neighbor block is 64.
[09] В способе декодирования/кодирования видеосигнала согласно настоящему изобретению количество кандидатных режимов внутреннего предсказания может меняться согласно индексу линии опорных отсчетов.[09] In the video decoding/coding method according to the present invention, the number of candidate intra prediction modes may vary according to the reference sample line index.
[10] Способ декодирования/кодирования видеосигнала согласно настоящему изобретению может дополнительно включать этап определения того, следует ли разбивать текущий блок на множество подблоков, и, когда текущий блок разбивают на множество подблоков, множество подблоков могут совместно использовать один режим внутреннего предсказания.[10] The video decoding/coding method according to the present invention may further include the step of determining whether the current block should be divided into a plurality of subblocks, and when the current block is divided into a plurality of subblocks, the plurality of subblocks may share one intra prediction mode.
[11] В способе декодирования/кодирования видеосигнала согласно настоящему изобретению обратное преобразование может быть пропущено для некоторых из множества подблоков.[11] In the video decoding/coding method according to the present invention, the inverse transform may be skipped for some of the plurality of sub-blocks.
[12] В способе декодирования/кодирования видеосигнала согласно настоящему изобретению тип преобразования в горизонтальном направлении подблока могут определять на основании ширины подблока, и тип преобразования в вертикальном направлении подблока могут определять на основании высоты подблока.[12] In the video decoding/coding method according to the present invention, a transformation type in the horizontal direction of a subblock may be determined based on the width of the subblock, and a transformation type in the vertical direction of the subblock may be determined based on the height of the subblock.
[13] В способе декодирования/кодирования видеосигнала согласно настоящему изобретению тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении подблока могут определять на основании формы подблока.[13] In the video decoding/coding method according to the present invention, a transformation type in the horizontal direction and a transformation type in the vertical direction of a sub-block may be determined based on the shape of the sub-block.
[14] Признаки, кратко изложенные выше в отношении настоящего изобретения, являются просто иллюстративными аспектами подробного описания настоящего изобретения, которые будут описаны ниже, и не ограничивают объем настоящего изобретения.[14] The features summarized above in relation to the present invention are merely illustrative aspects of the detailed description of the present invention, which will be described below, and do not limit the scope of the present invention.
[15] Согласно настоящему изобретению эффективность внутреннего предсказания может быть улучшена путем получения кандидатного режима внутреннего предсказания, подобного режиму внутреннего предсказания соседнего блока, смежного с текущим блоком.[15] According to the present invention, the performance of intra prediction can be improved by obtaining a candidate intra prediction mode similar to the intra prediction mode of an adjacent block adjacent to the current block.
[16] Согласно настоящему изобретению эффективность внутреннего предсказания может быть улучшена путем разбиения блока кодирования или блока преобразования на множество подблоков и выполнения внутреннего предсказания в отношении каждого из подблоков.[16] According to the present invention, the performance of intra prediction can be improved by dividing a coding block or a transform block into a plurality of sub-blocks and performing intra prediction on each of the sub-blocks.
[17] Согласно настоящему изобретению эффективность кодирования и декодирования может быть улучшена путем разбиения блока кодирования или блока преобразования на множество подблоков и выполнения преобразования в отношении только некоторых из подблоков.[17] According to the present invention, encoding and decoding efficiency can be improved by dividing an encoding block or a transformation block into a plurality of subblocks and performing transformation on only some of the subblocks.
[18] Эффекты, которые могут быть получены из настоящего изобретения, не ограничены упомянутыми выше эффектами, и не упомянутые другие эффекты могут быть ясно поняты специалистами в данной области техники из следующего описания.[18] The effects that can be obtained from the present invention are not limited to the effects mentioned above, and other effects not mentioned can be clearly understood by those skilled in the art from the following description.
КРАТКОЕ ОПИСАНИЕ ГРАФИЧЕСКИХ МАТЕРИАЛОВBRIEF DESCRIPTION OF GRAPHICS
[19] На фиг.1 представлена структурная схема, показывающая видеокодер согласно одному варианту осуществления настоящего изобретения.[19] FIG. 1 is a block diagram showing a video encoder according to one embodiment of the present invention.
[20] На фиг.2 представлена структурная схема, показывающая видеодекодер согласно одному варианту осуществления настоящего изобретения.[20] FIG. 2 is a block diagram showing a video decoder according to one embodiment of the present invention.
[21] На фиг.3 представлен вид, показывающий базовый элемент кодового дерева согласно одному варианту осуществления настоящего изобретения.[21] FIG. 3 is a view showing a base element of a code tree according to one embodiment of the present invention.
[22] На фиг.4 представлен вид, показывающий различные типы разбиения блока кодирования.[22] Fig. 4 is a view showing various types of partitioning of a coding block.
[23] На фиг.5 представлен вид, показывающий схему разбиения элемента кодового дерева.[23] Fig. 5 is a view showing a partitioning scheme of a code tree element.
[24] На фиг.6 представлена блок-схема, изображающая способ предсказания, осуществляемого между изображениями, согласно одному варианту осуществления настоящего изобретения.[24] FIG. 6 is a flowchart showing a prediction method performed between images according to one embodiment of the present invention.
[25] На фиг.7 представлен вид, показывающий совмещаемый блок.[25] FIG. 7 is a view showing a matching block.
[26] На фиг.8 представлена блок-схема, изображающая способ внутреннего предсказания согласно одному варианту осуществления настоящего изобретения.[26] FIG. 8 is a flowchart showing an intra prediction method according to one embodiment of the present invention.
[27] На фиг.9 представлен вид, показывающий опорные отсчеты, включенные в каждую линию опорных отсчетов.[27] Fig. 9 is a view showing reference samples included in each reference sample line.
[28] На фиг.10 представлен вид, показывающий режимы внутреннего предсказания.[28] Fig. 10 is a view showing intra prediction modes.
[29] На фиг.11 и 12 представлены виды, показывающие пример одномерного массива, размещающего опорные отсчеты в линию.[29] Figures 11 and 12 are views showing an example of a one-dimensional array placing reference samples in a line.
[30] На фиг.13 представлен вид, показывающий пример углов, образованных между режимами внутреннего предсказания, основанными на информации об углах, и прямой линией, параллельной оси x.[30] FIG. 13 is a view showing an example of angles formed between angle information-based intra prediction modes and a straight line parallel to the x-axis.
[31] На фиг.14 представлен вид, показывающий вариант осуществления получения отсчетов предсказания, когда текущий блок имеет неквадратную форму.[31] Fig. 14 is a view showing an embodiment of obtaining prediction samples when the current block is non-square.
[32] На фиг.15 представлен вид, показывающий широкоугольные режимы внутреннего предсказания.[32] Fig. 15 is a view showing wide-angle intra prediction modes.
[33] На фиг.16 представлен вид, показывающий пример разбиения в вертикальном направлении и разбиения в горизонтальном направлении.[33] Fig. 16 is a view showing an example of splitting in the vertical direction and splitting in the horizontal direction.
[34] На фиг.17 представлен вид, показывающий пример определения типа разбиения блока кодирования.[34] FIG. 17 is a view showing an example of determining a split type of a coding block.
[35] На фиг.18 представлен вид, показывающий пример определения типа разбиения блока кодирования.[35] FIG. 18 is a view showing an example of determining a splitting type of a coding block.
[36] На фиг.19 представлен вид, показывающий пример, в котором тип разбиения блока кодирования определяют на основании режима внутреннего предсказания блока кодирования.[36] FIG. 19 is a view showing an example in which a split type of a coding block is determined based on the intra prediction mode of the coding block.
[37] На фиг.20 представлен вид для описания схемы разбиения блока кодирования.[37] FIG. 20 is a view for describing a coding block split scheme.
[38] На фиг.21 представлен вид, показывающий пример, в котором режим кодирования с предсказанием устанавливают по-разному для каждого подблока.[38] FIG. 21 is a view showing an example in which the predictive coding mode is set differently for each sub-block.
[39] На фиг.22 представлен вид, показывающий вариант осуществления применения PDPC.[39] FIG. 22 is a view showing an embodiment of applying PDPC.
[40] На фиг.23 и 24 представлены виды, показывающие подблок, в отношении которого будут выполнять второе преобразование.[40] FIGS. 23 and 24 are views showing a sub-block on which the second transformation will be performed.
[41] На фиг.25 представлен вид для описания примеров определения типа преобразования текущего блока.[41] FIG. 25 is a view for describing examples of determining the conversion type of the current block.
[42] На фиг.26 представлен вид, показывающий пример определения типа преобразования подблока.[42] FIG. 26 is a view showing an example of determining a sub-block conversion type.
[43] На фиг.27 представлен вид для описания примера, в котором остаточные коэффициенты подблоков устанавливают равными 0.[43] Fig. 27 is a view for describing an example in which the subblock residual coefficients are set to 0.
[44] На фиг.28 представлен вид, показывающий пример, в котором положение подблока, в отношении которого были выполнены преобразование и/или квантование, указано на основании информации, переданной посредством битового потока.[44] FIG. 28 is a view showing an example in which the position of a sub-block on which transformation and/or quantization has been performed is indicated based on information transmitted by the bitstream.
[45] На фиг.29 представлена блок-схема, изображающая процесс определения качественного показателя блока.[45] FIG. 29 is a flowchart showing a block quality determination process.
[46] На фиг.30 представлен вид, показывающий предварительно заданные фильтры-кандидаты.[46] FIG. 30 is a view showing predefined candidate filters.
ПОДРОБНОЕ ОПИСАНИЕ ПРЕДПОЧТИТЕЛЬНОГО ВАРИАНТА ОСУЩЕСТВЛЕНИЯDETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
[47] Далее будет подробно описан вариант осуществления настоящего изобретения со ссылкой на прилагаемые графические материалы.[47] Next, an embodiment of the present invention will be described in detail with reference to the accompanying drawings.
[48] Кодирование и декодирование видео выполняется посредством элемента блока. Например, процесс кодирования/декодирования, такой как преобразование, квантование, предсказание, фильтрование в контуре, восстановление и т.п., может выполняться в отношении блока кодирования, блока преобразования или блока предсказания.[48] Video encoding and decoding is performed by the block element. For example, an encoding/decoding process such as transformation, quantization, prediction, loop filtering, reconstruction, and the like may be performed on an encoding block, a transformation block, or a prediction block.
[49] Далее блок, подлежащий кодированию/декодированию, будет называться «текущим блоком». Например, текущий блок может представлять блок кодирования, блок преобразования или блок предсказания согласно текущему этапу процесса кодирования/декодирования.[49] Hereinafter, the block to be encoded/decoded will be referred to as the "current block". For example, the current block may represent an encoding block, a transformation block, or a prediction block according to the current stage of the encoding/decoding process.
[50] Кроме того, следует понимать, что термин «элемент», используемый в настоящем описании, обозначает базовый элемент для выполнения конкретного процесса кодирования/декодирования, и термин «блок» обозначает массив отсчетов предварительно определенного размера. Если не указано иное, «блок» и «элемент» могут использоваться с одинаковым значением. Например, в варианте осуществления, описанном ниже, следует понимать, что блок кодирования и элемент кодирования имеют одинаковое значение.[50] In addition, it should be understood that the term "element" used in the present description denotes a basic element for performing a particular encoding/decoding process, and the term "block" denotes an array of samples of a predetermined size. Unless otherwise noted, "block" and "element" may be used with the same meaning. For example, in the embodiment described below, it should be understood that a coding block and a coding unit have the same meaning.
[51] На фиг.1 представлена структурная схема, показывающая видеокодер согласно одному варианту осуществления настоящего изобретения.[51] FIG. 1 is a block diagram showing a video encoder according to one embodiment of the present invention.
[52] Как показано на фиг.1, устройство 100 для кодирования видео может содержать часть 110 для разбиения изображений, части 120 и 125 для предсказания, часть 130 для преобразования, часть 135 для квантования, часть 160 для перестановки, часть 165 для энтропийного кодирования, часть 140 для обратного квантования, часть 145 для обратного преобразования, часть 150 для фильтрации и запоминающее устройство 155.[52] As shown in FIG. 1, the video encoding apparatus 100 may comprise an image splitting part 110, prediction parts 120 and 125, a transform part 130, a quantization part 135, a permutation part 160, an entropy coding part 165, an inverse quantization part 140, an inverse transform part 145, a filtering part 150, and a storage device 15 5.
[53] Каждый из компонентов, показанных на фиг.1, показан независимо, чтобы представить характерные функции, отличающие их друг от друга в устройстве для кодирования видео, но это не означает, что каждый компонент образован элементом конфигурации отдельного аппаратного обеспечения или одного программного обеспечения. То есть каждый компонент включен в список в качестве компонента для удобства объяснения, и по меньшей мере два из компонентов могут быть объединены для образования единого компонента, или один компонент может быть разбит на множество компонентов для выполнения функции. Варианты осуществления с объединением и варианты осуществления с разделением компонентов также входят в объем настоящего изобретения, если они не выходят за рамки сущности настоящего изобретения.[53] Each of the components shown in FIG. 1 is shown independently to represent the characteristic functions that distinguish them from each other in the video encoding device, but this does not mean that each component is formed by a configuration element of a separate hardware or one software. That is, each component is listed as a component for convenience of explanation, and at least two of the components may be combined to form a single component, or one component may be broken into multiple components to perform a function. Embodiments with integration and embodiments with separation of components are also included in the scope of the present invention, if they do not go beyond the essence of the present invention.
[54] Кроме того, некоторые из компонентов не являются важными компонентами, которые выполняют основные функции в настоящем изобретении, но могут быть необязательными компонентами только для повышения эффективности. Настоящее изобретение может быть реализовано путем включения только компонентов, необходимых для реализации сущности настоящего изобретения, за исключением компонентов, используемых для повышения эффективности, и конструкция, содержащая только необходимые компоненты, за исключением необязательных компонентов, используемых для повышения эффективности, также включена в объем настоящего изобретения.[54] In addition, some of the components are not essential components that perform the main functions in the present invention, but may be optional components only to improve efficiency. The present invention can be implemented by including only the components necessary to realize the essence of the present invention, excluding components used to improve efficiency, and a structure containing only the necessary components, excluding optional components used to improve efficiency, is also included in the scope of the present invention.
[55] Часть 110 для разбиения изображений может разбивать входное изображение на по меньшей мере один элемент обработки. В этом случае элемент обработки может представлять собой элемент предсказания (PU), элемент преобразования (TU) или элемент кодирования (CU). Часть 110 для разбиения изображений может разбивать изображение на совокупность, состоящую из множества элементов кодирования, элементов предсказания и элементов преобразования, и кодировать изображение за счет выбора совокупности элемента кодирования, элемента предсказания и элемента преобразования на основании предварительно определенного критерия (например, функции стоимости).[55] The image splitting part 110 may split the input image into at least one processing element. In this case, the processing element may be a prediction element (PU), a transform element (TU), or a coding element (CU). The image splitting part 110 may partition an image into a plurality of coding elements, prediction elements, and transform elements, and encode the image by selecting a plurality of coding element, prediction element, and transform element based on a predetermined criterion (e.g., a cost function).
[56] Например, одно изображение может быть разбито на множество элементов кодирования. Для разбиения элементов кодирования в изображении может использоваться структура в виде рекурсивного дерева, такая как структура в виде четвертичного дерева. Видео или элемент кодирования, разбитые на разные элементы кодирования с использованием наибольшего элемента кодирования в качестве корня, могут быть разбиты так, чтобы иметь столько же узлов-потомков, сколько разбитых элементов кодирования. Элемент кодирования, который больше не разбивается согласно предварительно определенному ограничению, становится листовым узлом. То есть, если предполагается, что возможно только квадратное разбиение для одного элемента кодирования, один элемент кодирования может быть разбит на не более чем четыре разных элемента кодирования.[56] For example, one image may be split into multiple coding units. A recursive tree structure, such as a quaternary tree structure, may be used to partition the coding elements in an image. A video or coding unit split into different coding units using the largest coding unit as the root can be split to have the same number of child nodes as the split coding units. An encoding element that no longer splits according to a predetermined constraint becomes a leaf node. That is, if it is assumed that only square splitting is possible for one coding unit, one coding unit can be split into no more than four different coding units.
[57] Далее в варианте осуществления настоящего изобретения элемент кодирования может использоваться в значении элемента, выполняющего кодирование, или в значении элемента, выполняющего декодирование.[57] Further, in an embodiment of the present invention, an encoding element can be used in the value of an element that performs encoding, or in the meaning of an element that performs decoding.
[58] Элемент предсказания может представлять собой элемент, разбитый в форме по меньшей мере одного квадрата, прямоугольника и т.п.одинакового размера в пределах одного элемента кодирования, или он может представлять собой любой элемент предсказания из элементов предсказания, разбитых в пределах одного элемента кодирования, который разбит так, что имеет форму и/или размер, отличающиеся от таковых другого элемента предсказания.[58] A prediction element may be an element that is partitioned into at least one square, rectangle, or the like of the same size within one coding element, or it can be any prediction element of prediction elements partitioned within one coding element that is partitioned such that it has a shape and/or size that is different from those of another prediction element.
[59] Если элемент кодирования не является наименьшим элементом кодирования, когда генерируется элемент предсказания, который выполняет внутреннее предсказание на основании элемента кодирования, внутреннее предсказание может выполняться без разбиения изображения на множество элементов предсказания N×N.[59] If a coding unit is not the smallest coding unit, when a prediction unit that performs intra prediction based on the coding unit is generated, intra prediction can be performed without splitting an image into a plurality of N×N prediction units.
[60] Части 120 и 125 для предсказания могут содержать часть 120 для предсказания, осуществляемого между изображениями, которая выполняет предсказание, осуществляемое между изображениями, и часть 125 для внутреннего предсказания, которая выполняет внутреннее предсказание. Может быть определено, использовать ли предсказание, осуществляемое между изображениями, или выполнить внутреннее предсказание для элемента предсказания и определить конкретную информацию (например, режим внутреннего предсказания, вектор движения, опорное изображение или т.п.) согласно каждому способу предсказания. В этом случае элемент обработки для выполнения предсказания может отличаться от элемента обработки для определения способа предсказания и конкретно содержимого. Например, способ предсказания и режим предсказания могут быть определены в элементе предсказания, и предсказание может выполняться в элементе преобразования. Остаточный коэффициент (остаточный блок) между сгенерированным блоком предсказания и первоначальным блоком может быть введен в часть 130 для преобразования. Кроме того, информация о режиме предсказания, информация о векторе движения и т.п., используемые для предсказания, могут быть кодированы посредством части 165 для энтропийного кодирования вместе с остаточным коэффициентом и переданы на декодер. Когда используется конкретный режим кодирования, первоначальный блок может быть кодирован как есть и передан на декодер без генерирования блока предсказания посредством частей 120 и 125 для предсказания.[60] The prediction portions 120 and 125 may comprise an inter-picture prediction portion 120 that performs inter-picture prediction and an intra prediction portion 125 that performs intra prediction. It can be determined whether to use inter-picture prediction or perform intra prediction on a prediction element and determine specific information (eg, intra prediction mode, motion vector, reference picture, or the like) according to each prediction method. In this case, the processing element for performing prediction may be different from the processing element for determining the prediction method and specifically the content. For example, a prediction method and a prediction mode may be defined in the prediction element, and prediction may be performed in the transform element. The residual coefficient (residual block) between the generated prediction block and the original block may be input to the transform portion 130. In addition, prediction mode information, motion vector information, and the like used for prediction may be encoded by the entropy encoding portion 165 together with the residual coefficient and transmitted to the decoder. When a particular coding mode is used, the original block may be encoded as is and transmitted to the decoder without generating a prediction block by prediction portions 120 and 125.
[61] Часть 120 для предсказания, осуществляемого между изображениями, может предсказывать элемент предсказания на основании информации о по меньшей мере одном изображении из изображений перед текущим изображением или после него, и в некоторых случаях она может предсказывать элемент предсказания на основании информации о частичной области, которая была закодирована в текущем изображении. Часть 120 для предсказания, осуществляемого между изображениями, может содержать часть для интерполяции опорного изображения, часть для предсказания движения и часть для компенсации движения.[61] The inter-picture prediction portion 120 may predict a prediction element based on information about at least one image from images before or after the current image, and in some cases, it may predict the prediction element based on information about a partial area that has been encoded in the current image. The inter-picture prediction portion 120 may include a reference picture interpolation portion, a motion prediction portion, and a motion compensation portion.
[62] Часть для интерполяции опорного изображения может принимать информацию об опорном изображении от запоминающего устройства 155 и генерировать информацию о пикселе для целого числа пикселей или меньше из опорного изображения. В случае пикселя яркости 8-отводный интерполяционный фильтр на основе DCT с переменным коэффициентом фильтрования может использоваться для генерирования информации о пикселе целого числа пикселей или меньше посредством элемента, состоящего из 1/4 пикселей. В случае цветоразностного сигнала 4-отводный интерполяционный фильтр на основе DCT с переменным коэффициентом фильтрования может использоваться для генерирования информации о пикселе целого числа пикселей или меньше посредством элемента, состоящего из 1/8 пикселей.[62] The reference picture interpolation portion may receive reference picture information from the storage device 155 and generate pixel information for an integer number of pixels or less from the reference picture. In the case of a luminance pixel, an 8-tap interpolation filter based on a DCT with a variable filter coefficient may be used to generate pixel information of an integer number of pixels or less by an element consisting of 1/4 pixels. In the case of a color difference signal, a 4-tap interpolation filter based on a DCT with a variable filter coefficient may be used to generate pixel information of an integer number of pixels or less by an element consisting of 1/8 pixels.
[63] Часть для предсказания движения может выполнять предсказание движения на основании опорного изображения, интерполированного частью для интерполяции опорного изображения. Различные способы, такие как алгоритм сопоставления блоков на основе полного поиска (FBMA), трехступенчатый поиск (TSS), алгоритм нового трехступенчатого поиска (NTS) и т.п., могут использоваться в качестве способа вычисления вектора движения. Вектор движения может иметь значение вектора движения в виде элемента, состоящего из 1/2 или 1/4 пикселей, на основании интерполированных пикселей. Часть для предсказания движения может предсказывать текущий элемент предсказания за счет изменения способа предсказания движения. Различные способы, такие как способ пропуска, способ слияния, способ усовершенствованного предсказания вектора движения (AMVP), способ внутриблочного копирования и т.п., могут использоваться в качестве способа предсказания движения.[63] The motion prediction part may perform motion prediction based on the reference image interpolated by the reference image interpolation part. Various methods such as full search block matching algorithm (FBMA), three-step search (TSS), new three-step search (NTS) algorithm, and the like can be used as a motion vector calculation method. The motion vector may have a 1/2 or 1/4 pixel motion vector value based on the interpolated pixels. The motion prediction part can predict the current prediction item by changing the motion prediction method. Various methods such as a skip method, a merge method, an advanced motion vector prediction (AMVP) method, an intra-block copy method, and the like, can be used as a motion prediction method.
[64] Часть 125 для внутреннего предсказания может генерировать элемент предсказания на основании информации об опорных пикселях, расположенных поблизости от текущего блока, которая представляет собой информацию о пикселе в текущем изображении. Когда блок, находящийся поблизости от текущего элемента предсказания, представляет собой блок, в отношении которого было выполнено предсказание, осуществляемое между изображениями, и, таким образом, опорный пиксель представляет собой пиксель, в отношении которого было выполнено предсказание, осуществляемое между изображениями, опорный пиксель, включенный в блок, в отношении которого было выполнено предсказание, осуществляемое между изображениями, может использоваться вместо информации об опорном пикселе блока, находящегося поблизости, в отношении которого было выполнено внутреннее предсказание. То есть, когда опорный пиксель недоступен, по меньшей мере один опорный пиксель из доступных опорных пикселей может использоваться вместо недоступной информации об опорном пикселе.[64] Part 125 for intra prediction may generate a prediction element based on information about reference pixels located in the vicinity of the current block, which is information about a pixel in the current image. When a block in the vicinity of the current prediction element is a block on which inter-picture prediction has been performed, and thus the reference pixel is a pixel on which inter-picture prediction has been performed, the reference pixel included in the block on which inter-picture prediction has been performed may be used instead of the reference pixel information of a nearby block on which intra prediction has been performed. That is, when the reference pixel is unavailable, at least one reference pixel of the available reference pixels may be used in place of the unavailable reference pixel information.
[65] При внутреннем предсказании режим предсказания может предусматривать режим предсказания, основанный на информации об углах, в котором используется информация об опорном пикселе согласно направлению предсказания, и режим предсказания, не основанный на информации об углах, в котором не используется информация о направлении при выполнении предсказания. Режим для предсказания информации о яркости может отличаться от режима для предсказания информации о цветовой разности, и информация о режиме внутреннего предсказания, используемая для предсказания информации о яркости или информации о предсказанном сигнале яркости, может использоваться для предсказания информации о цветовой разности.[65] In intra prediction, the prediction mode may include a prediction mode based on angle information that uses reference pixel information according to the prediction direction, and a prediction mode not based on angle information that does not use direction information when performing prediction. The mode for predicting luminance information may be different from the mode for predicting color difference information, and intra prediction mode information used for predicting luminance information or predicted luminance signal information may be used for predicting color difference information.
[66] Если размер элемента предсказания такой же, как размер элемента преобразования, когда выполняется внутреннее предсказание, внутреннее предсказание может выполняться для элемента предсказания на основании пикселя на левой стороне, пикселя на верхней левой стороне и пикселя сверху от элемента предсказания. Однако, если размер элемента предсказания отличается от размера элемента преобразования, когда выполняется внутреннее предсказание, внутреннее предсказание может выполняться с использованием опорного пикселя на основании элемента преобразования. Кроме того, внутреннее предсказание с использованием разбиения N×N может использоваться только для наименьшего элемента кодирования.[66] If the prediction element size is the same as the transform element size when intra prediction is performed, intra prediction can be performed on the prediction element based on a pixel on the left side, a pixel on the upper left side, and a pixel above the prediction element. However, if the size of the prediction element is different from the size of the transform element when intra prediction is performed, intra prediction can be performed using the reference pixel based on the transform element. In addition, intra prediction using N×N partitioning can only be used for the smallest bin.
[67] Посредством способа внутреннего предсказания можно генерировать блок предсказания после применения фильтра адаптивного внутреннего сглаживания (AIS) к опорному пикселю согласно режиму предсказания. Тип фильтра AIS, применяемого к опорному пикселю, может меняться. Для выполнения способа внутреннего предсказания режим внутреннего предсказания текущего элемента предсказания может быть предсказан из режима внутреннего предсказания элемента предсказания, существующего поблизости от текущего элемента предсказания. Когда режим предсказания текущего элемента предсказания предсказан с использованием информации о режиме, предсказанной из соседнего элемента предсказания, если режимы внутреннего предсказания текущего элемента предсказания такие же, как элемент предсказания поблизости, то информация, указывающая, что режимы предсказания текущего элемента предсказания такие же, как элемент предсказания поблизости, может передаваться с использованием информации о предварительно определенном флаге, и если режимы предсказания текущего элемента предсказания и элемента предсказания поблизости отличаются друг от друга, информация о режиме предсказания текущего блока может быть кодирована за счет выполнения энтропийного кодирования.[67] By means of the intra prediction method, it is possible to generate a prediction block after applying an adaptive intra-smoothing (AIS) filter to a reference pixel according to the prediction mode. The type of AIS filter applied to the reference pixel may vary. To perform the intra prediction method, the intra prediction mode of the current prediction element may be predicted from the intra prediction mode of the prediction element existing in the vicinity of the current prediction element. When the prediction regime of the current prediction element is predicted using the information about the regime predicted from the neighboring element of prediction, if the internal prediction modes of the current prediction element are the same as the element of prediction nearby, then the information indicating that the prediction of the current prediction element of the close -ups can be transmitted using information about the preliminary certain flavor Ge, and if the predictions of the current element of prediction and the element of prediction nearby differ from each other, information about the prediction of the current block can be encoded by performing entropy coding.
[68] Кроме того, может быть сгенерирован остаточный блок, содержащий элемент предсказания, который выполнил предсказание на основании элемента предсказания, сгенерированного частями 120 и 125 для предсказания, и информации об остаточном коэффициенте, которая представляет собой значение разницы элемента предсказания от первоначального блока. Сгенерированный остаточный блок может быть введен в часть 130 для преобразования.[68] In addition, a residual block may be generated containing a prediction element that performed prediction based on the prediction element generated by the prediction portions 120 and 125 and the residual coefficient information, which is the difference value of the prediction element from the original block. The generated residual block may be input to part 130 for transformation.
[69] Часть 130 для преобразования может преобразовывать остаточный блок, содержащий первоначальный блок и информацию об остаточном коэффициенте элемента предсказания, сгенерированного посредством частей 120 и 125 для предсказания, с помощью способа преобразования, такого как дискретное косинусное преобразование (DCT), дискретное синусное преобразование (DST) или KLT. Применение DCT, DST или KLT для преобразования остаточного блока, может быть определено на основании информации о режиме внутреннего предсказания элемента предсказания, используемого для генерирования остаточного блока.[69] The transform part 130 may transform the residual block containing the original block and information about the residual coefficient of the prediction element generated by the prediction parts 120 and 125 with a transform method such as discrete cosine transform (DCT), discrete sine transform (DST), or KLT. The use of DCT, DST, or KLT to transform the residual block may be determined based on information about the intra prediction mode of the prediction element used to generate the residual block.
[70] Часть 135 для квантования может квантовать значения, преобразованные в частотную область посредством части 130 для преобразования. Коэффициенты квантования могут изменяться в зависимости от блока или важности видео. Значение, вычисленное частью 135 для квантования, может быть предоставлено в часть 140 для обратного квантования и часть 160 для перестановки.[70] The quantization part 135 may quantize the values converted into the frequency domain by the transform part 130. The quantization factors may vary depending on the block or importance of the video. The value calculated by the quantization part 135 may be provided to the inverse quantization part 140 and the permutation part 160.
[71] Часть 160 для перестановки может выполнять перестановку значений коэффициентов для квантованных остаточных коэффициентов.[71] The permutation part 160 may perform permutation of coefficient values for the quantized residual coefficients.
[72] Часть 160 для перестановки может изменять коэффициенты двумерной формы блока на одномерную векторную форму посредством способа сканирования коэффициентов. Например, часть 160 для перестановки может сканировать от коэффициентов DC до коэффициентов высокочастотной области с использованием способа зигзагообразного сканирования и менять коэффициенты с приданием им одномерной векторной формы. Согласно размеру элемента преобразования и режиму внутреннего предсказания вместо зигзагообразного сканирования может использоваться вертикальное сканирование в виде сканирования коэффициентов двумерной формы блока в направлении столбцов и горизонтальное сканирование коэффициентов двумерной формы блока в направлении строк. То есть, согласно размеру элемента преобразования и режиму внутреннего предсказания может быть определен способ сканирования, который будет использоваться, из зигзагообразного сканирования, сканирования в вертикальном направлении и сканирования в горизонтальном направлении.[72] The permutation part 160 may change the coefficients of a two-dimensional block shape to a one-dimensional vector shape by a coefficient scanning method. For example, the permutation part 160 may scan from the DC coefficients to the high frequency region coefficients using a zigzag scanning method and change the coefficients into a one-dimensional vector form. According to the transform element size and the intra prediction mode, instead of zigzag scanning, vertical scanning of the 2D block shape coefficients in the column direction and horizontal scanning of the 2D block shape coefficients in the row direction can be used. That is, according to the transform element size and the intra prediction mode, the scanning method to be used can be determined from zigzag scanning, scanning in the vertical direction, and scanning in the horizontal direction.
[73] Часть 165 для энтропийного кодирования может выполнять энтропийное кодирование на основании значений, вычисленных частью 160 для перестановки. Для энтропийного кодирования могут использоваться различные способы кодирования, такие как кодирование экспоненциальным способом Голомба, контекстно-адаптивное кодирование с переменной длиной слова (CAVLC), контекстно-адаптивное двоичное арифметическое кодирование (CABAC) и т.п.[73] The entropy encoding part 165 may perform entropy encoding based on the values calculated by the permutation part 160. Various coding methods can be used for entropy coding, such as exponential Golomb coding, context adaptive variable length coding (CAVLC), context adaptive binary arithmetic coding (CABAC), and the like.
[74] Часть 165 для энтропийного кодирования может кодировать различную информацию, такую как информация об остаточном коэффициенте и информация о типе блока элемента кодирования, информация о режиме предсказания, информация об элементе разбиения, информация об элементе предсказания и информация об элементе передачи, информация о векторе движения, информация об опорном кадре, информация об интерполяции блока и информация о фильтрации, которая введена из части 160 для перестановки и частей 120 и 125 для предсказания.[74] The entropy encoding part 165 can encode various information such as residual coefficient information and coding element block type information, prediction mode information, split element information, prediction element information and transmission element information, motion vector information, reference frame information, block interpolation information, and filtering information which is input from the permutation part 160 and the prediction parts 120 and 125.
[75] Часть 165 для энтропийного кодирования может выполнять энтропийное кодирование значения коэффициента элемента кодирования, введенного из части 160 для перестановки.[75] The entropy encoding part 165 may perform entropy encoding of the coefficient value of the coding element inputted from the permutation part 160.
[76] Часть 140 для обратного квантования и часть 145 для обратного преобразования выполняют обратное квантование значений, квантованных посредством части 135 для квантования, и обратное преобразование значений, преобразованных посредством части 130 для преобразования. Остаточный коэффициент, сгенерированный частью 140 для обратного квантования и частью 145 для обратного преобразования, может быть объединен с элементом предсказания, предсказанным посредством части для оценки движения, часть для компенсации движения и части для внутреннего предсказания, включенных в части 120 и 125 для предсказания, для генерирования восстановленного блока.[76] The inverse quantization part 140 and the inverse transform part 145 perform inverse quantization of the values quantized by the quantization part 135 and inverse transformation of the values transformed by the transform part 130. The residual coefficient generated by the inverse quantization part 140 and the inverse transform part 145 may be combined with the prediction element predicted by the motion estimation part, the motion compensation part, and the intra prediction part included in the prediction parts 120 and 125 to generate a reconstructed block.
[77] Часть 150 для фильтрации может содержать по меньшей мере одно из деблочного фильтра, элемента для компенсации смещения и адаптивного контурного фильтра (ALF).[77] The filtering portion 150 may comprise at least one of a deblocking filter, an element for offset compensation, and an adaptive loop filter (ALF).
[78] Деблочный фильтр может удалять искажение блока, генерируемое на границе между блоками в восстановленном изображении. Определение того, следует ли выполнять удаление блочности, применять ли деблочный фильтр к текущему блоку, может осуществляться на основании пикселей, содержащихся в нескольких столбцах или строках, содержащихся в блоке. Сильный фильтр или слабый фильтр может применяться согласно необходимой степени фильтрации для удаления блочности, при применении деблочного фильтра к блоку. Кроме того, когда выполняются фильтрация в вертикальном направлении и фильтрация в горизонтальном направлении при применении деблочного фильтра, фильтрация в вертикальном направлении и фильтрация в горизонтальном направлении могут осуществляться параллельно.[78] A deblock filter can remove block distortion generated at a boundary between blocks in a reconstructed image. The determination of whether to perform deblocking, whether to apply a deblocking filter to the current block, may be based on the pixels contained in multiple columns or rows contained in the block. A strong filter or a weak filter can be applied according to the required degree of filtering to remove blockiness when applying a deblocking filter to a block. In addition, when vertical direction filtering and horizontal direction filtering are performed by applying the deblocking filter, vertical direction filtering and horizontal direction filtering can be performed in parallel.
[79] Элемент для коррекции смещения может корректировать смещение первоначального видео посредством элемента, состоящего из пикселей, для видео, в отношении которого было выполнено удаление блочности. Для выполнения коррекции смещения для конкретного изображения можно использовать способ разделения пикселей, включенных в видео, на определенное количество областей, определения области для выполнения смещения, и применения смещения к области, или способ применения смещения, учитывающий информацию о крае каждого пикселя.[79] The offset correction element may correct the offset of the original video by the pixel element for the video that has been deblocked. To perform the offset correction for a specific image, a method of dividing the pixels included in the video into a certain number of areas, determining an area to perform the offset, and applying the offset to the area, or a method of applying the offset taking into account the edge information of each pixel, can be used.
[80] Адаптивная контурная фильтрация (ALF) может выполняться на основании значения, полученного посредством сравнения восстановленного и отфильтрованного видео с первоначальным видео. После разделения пикселей, включенных в видео, на предварительно определенные группы, может быть определен один фильтр, который должен применяться к соответствующей группе, и фильтрация может выполняться по-разному для каждой группы. Сигнал яркости, который представляет собой информацию, связанную с тем, следует или нет применять ALF, может передаваться для каждого элемента кодирования (CU), и форма и коэффициент фильтрования фильтра ALF, который должен быть применен, могут меняться в зависимости от каждого блока. Кроме того, фильтр ALF того же типа (фиксированного типа) может применяться независимо от характеристики применяемого блока.[80] Adaptive loop filtering (ALF) may be performed based on a value obtained by comparing the reconstructed and filtered video with the original video. After dividing the pixels included in the video into predefined groups, one filter can be defined to be applied to the corresponding group, and filtering can be performed differently for each group. The luminance signal, which is information related to whether or not to apply ALF, may be transmitted for each coding unit (CU), and the shape and filter factor of the ALF to be applied may vary depending on each block. Also, the ALF filter of the same type (fixed type) can be applied regardless of the characteristic of the applied block.
[81] Запоминающее устройство 155 может хранить восстановленный блок или изображение, вычисленные посредством части 150 для фильтрации, и восстановленный и сохраненный блок или изображение могут быть предоставлены в части 120 и 125 для предсказания при выполнении предсказания, осуществляемого между изображениями.[81] The memory 155 may store the reconstructed block or image computed by the filtering portion 150, and the reconstructed and stored block or image may be provided in the prediction portions 120 and 125 when performing inter-picture prediction.
[82] На фиг.2 представлена структурная схема, показывающая видеодекодер согласно одному варианту осуществления настоящего изобретения.[82] FIG. 2 is a block diagram showing a video decoder according to one embodiment of the present invention.
[83] Как показано на фиг.2, видеодекодер 200 может содержать часть 210 для энтропийного декодирования, часть 215 для перестановки, часть 220 для обратного квантования, часть 225 для обратного преобразования, части 230 и 235 для предсказания, часть 240 для фильтрации и запоминающее устройство 245.[83] As shown in FIG. 2, video decoder 200 may include an entropy decoding part 210, a permutation part 215, an inverse quantization part 220, an inverse transform part 225, prediction parts 230 and 235, a filtering part 240, and a memory 245.
[84] Когда битовый поток видео вводится из видеокодера, входной битовый поток может быть декодирован согласно процедуре, противоположной процедуре работы видеокодера.[84] When a video bitstream is input from a video encoder, the input bitstream may be decoded according to a procedure opposite to that of the video encoder.
[85] Часть 210 для энтропийного декодирования может выполнять энтропийное декодирование согласно процедуре, противоположной процедуре выполнения энтропийного кодирования в части для энтропийного декодирования видеокодера. Например, могут применяться различные способы, соответствующие способу, выполняемому видеокодером, такие как кодирование экспоненциальным способом Голомба, контекстно-адаптивное кодирование с переменной длиной слова (CAVLC) и контекстно-адаптивное двоичное арифметическое кодирование (CABAC).[85] The entropy decoding part 210 may perform entropy decoding according to a procedure opposite to that of performing entropy encoding in the entropy decoding part of the video encoder. For example, various methods may be applied corresponding to the method performed by the video encoder, such as exponential Golomb coding, context adaptive variable length coding (CAVLC), and context adaptive binary arithmetic coding (CABAC).
[86] Часть 210 для энтропийного декодирования может декодировать информацию, связанную с внутренним предсказанием и предсказанием, осуществляемым между изображениями, выполняемыми кодером.[86] The entropy decoding part 210 may decode information related to intra prediction and prediction performed between pictures performed by the encoder.
[87] Часть 215 для перестановки может выполнять перестановку в отношении битового потока, подвергнутого энтропийному декодированию посредством части 210 для энтропийного декодирования, на основании способа перестановки, выполняемого кодером. Коэффициенты, выраженные в одномерной векторной форме, могут быть восстановлены и переставлены как коэффициенты в двумерной форме блока. Часть 215 для перестановки может принимать информацию, связанную со сканированием коэффициентов, выполняемым частью для кодирования, и выполнять восстановление посредством способа обратного сканирования на основании порядка сканирования, выполняемого соответствующей частью для кодирования.[87] The permutation part 215 may perform permutation on the bitstream subjected to entropy decoding by the entropy decoding part 210 based on the permutation method performed by the encoder. Coefficients expressed in one-dimensional vector form can be retrieved and rearranged as coefficients in two-dimensional block form. The permutation part 215 may receive information related to the coefficient scan performed by the encoding part, and perform reconstruction by the inverse scanning method based on the scan order performed by the corresponding encoding part.
[88] Часть 220 для обратного квантования может выполнять обратное квантование на основании параметра квантования, предоставленного кодером, и значения коэффициента переставленного блока.[88] The inverse quantization part 220 may perform inverse quantization based on the quantization parameter provided by the encoder and the coefficient value of the permuted block.
[89] Часть 225 для обратного преобразования может выполнять обратное преобразование, т.е. обратное DCT, обратное DST или обратное KLT, для преобразования, т.е. DCT, DST или KLT, выполняемого частью для преобразования в отношении результата квантования, выполняемого видеокодером. Обратное преобразование может выполняться на основании элемента передачи, определенного видеокодером. Часть 225 для обратного преобразования видеодекодера может выборочно выполнять метод преобразования (например, DCT, DST, KLT) согласно множеству фрагментов информации, такой как способ предсказания, размер текущего блока, направление предсказания и т.п.[89] The inverse transformation part 225 may perform inverse transformation, i. e. reverse DCT, reverse DST, or reverse KLT, to convert i.e. DCT, DST or KLT performed by the transformation part with respect to the quantization result performed by the video encoder. The inverse transformation may be performed based on the transmission element determined by the video encoder. The video decoder inverse transformation part 225 may selectively perform a transformation method (eg, DCT, DST, KLT) according to a plurality of pieces of information such as a prediction method, a current block size, a prediction direction, and the like.
[90] Части 230 и 235 для предсказания могут генерировать блок предсказания на основании информации, относящейся к генерированию блока предсказания, предоставленного энтропийным декодером 210, и информации о ранее декодированном блоке или изображении, предоставленном запоминающим устройством 245.[90] The prediction parts 230 and 235 can generate a prediction block based on information related to generating a prediction block provided by the entropy decoder 210 and information about a previously decoded block or picture provided by the memory 245.
[91] Как описано выше, если размер элемента предсказания и размер элемента преобразования одинаковы, когда внутреннее предсказание выполняется таким же образом, как операция в видеокодере, внутреннее предсказание выполняется в отношении элемента предсказания на основании пикселя, находящегося на левой стороне, пикселя на верхней левой стороне и пикселя сверху от элемента предсказания. Однако, если размер элемента предсказания и размер элемента преобразования отличаются друг от друга, когда выполняется внутреннее предсказание, внутреннее предсказание может выполняться с использованием опорного пикселя на основании элемента преобразования. Кроме того, внутреннее предсказание с использованием разбиения N×N может использоваться только для наименьшего элемента кодирования.[91] As described above, if the prediction element size and the transform element size are the same when intra prediction is performed in the same manner as the operation in the video encoder, intra prediction is performed on the prediction element based on the pixel on the left side, the pixel on the upper left side, and the pixel above the prediction element. However, if the prediction element size and the transform element size are different from each other when intra prediction is performed, intra prediction can be performed using a reference pixel based on the transform element. In addition, intra prediction using N×N partitioning can only be used for the smallest bin.
[92] Части 230 и 235 для предсказания могут содержать часть для определения элемента предсказания, часть для предсказания, осуществляемого между изображениями, и часть для внутреннего предсказания. Часть для определения элемента предсказания может принимать различную информацию, такую как информация об элементе предсказания, введенная от части 210 для энтропийного декодирования, информация о режиме предсказания для способа внутреннего предсказания, информация, относящаяся к предсказанию движения для способа предсказания, осуществляемого между изображениями, и т.п., идентифицировать элемент предсказания из текущего элемента кодирования и определять, выполняет элемент предсказания предсказание, осуществляемое между изображениями, или внутреннее предсказание. Часть 230 для предсказания, осуществляемого между изображениями, может выполнять предсказание, осуществляемое между изображениями, в отношении текущего элемента предсказания на основании информации, включенной в по меньшей мере одно изображение из изображений до или после текущего изображения, включая текущий элемент предсказания, за счет использования информации, необходимой для предсказания, осуществляемого между изображениями, текущего элемента предсказания, предоставленного видеокодером. Альтернативно часть 230 для предсказания, осуществляемого между изображениями, может выполнять предсказание, осуществляемое между изображениями, на основании информации о частичной области, ранее восстановленной в текущем изображении, содержащем текущий элемент предсказания.[92] The prediction portions 230 and 235 may include a prediction element determination portion, an inter-picture prediction portion, and an intra prediction portion. The prediction element determination part may receive various information such as prediction element information input from the entropy decoding part 210, prediction mode information for the intra prediction method, information related to motion prediction for the inter-picture prediction method, and the like, identify the prediction element from the current coding element, and determine whether the prediction element performs inter-picture prediction or intra prediction. The inter-picture prediction part 230 can perform inter-picture prediction on the current prediction bin based on information included in at least one picture from pictures before or after the current picture, including the current prediction bin, by using information necessary for inter-picture prediction of the current prediction bin provided by the video encoder. Alternatively, the inter-picture prediction portion 230 may perform inter-picture prediction based on partial area information previously reconstructed in the current picture containing the current prediction element.
[93] Для выполнения предсказания, осуществляемого между изображениями, можно определить на основании элемента кодирования, является ли способ предсказания движения элемента предсказания, включенного в соответствующий элемент кодирования, режимом пропуска, режимом слияния, режимом предсказания вектора движения (режимом AMVP) или режимом копирования внутри блока.[93] To perform inter-picture prediction, it can be determined based on the coding unit whether the motion prediction method of the prediction unit included in the corresponding coding unit is a skip mode, a merge mode, a motion vector prediction mode (AMVP mode), or an intra-block copy mode.
[94] Часть 235 для внутреннего предсказания может генерировать блок предсказания на основании информации о пикселе в текущем изображении. Когда элемент предсказания представляет собой элемент предсказания, который выполнил внутреннее предсказание, внутреннее предсказание может быть выполнено на основании информации о режиме внутреннего предсказания элемента предсказания, предоставленного видеокодером. Часть 235 для внутреннего предсказания может содержать фильтр адаптивного внутреннего сглаживания (AIS), часть для интерполяции опорного пикселя и фильтр DC. Фильтр AIS представляет собой часть, которая выполняет фильтрацию в отношении опорного пикселя текущего блока, и может определять, следует применять или нет фильтр согласно режиму предсказания текущего элемента предсказания, и применять фильтр. Фильтрация AIS может выполняться в отношении опорного пикселя текущего блока за счет использования режима предсказания и информации о фильтре AIS элемента предсказания, предоставленного видеокодером. Когда режим предсказания текущего блока представляет собой режим, который не выполняет фильтрацию AIS, фильтр AIS может не применяться.[94] The intra prediction part 235 may generate a prediction block based on pixel information in the current image. When the prediction element is a prediction element that has performed intra prediction, intra prediction may be performed based on information about the intra prediction mode of the prediction element provided by the video encoder. The intra prediction portion 235 may comprise an adaptive intra-smoothing (AIS) filter, a reference pixel interpolation portion, and a DC filter. The AIS filter is a part that performs filtering on the reference pixel of the current block, and can determine whether or not to apply the filter according to the prediction mode of the current prediction element, and apply the filter. The AIS filtering can be performed on the reference pixel of the current block by using the prediction mode and the prediction element AIS filter information provided by the video encoder. When the prediction mode of the current block is a mode that does not perform AIS filtering, the AIS filter may not be applied.
[95] Когда режим предсказания элемента предсказания представляет собой элемент предсказания, который выполняет внутреннее предсказание на основании значения пикселя, полученного посредством интерполяции опорного пикселя, часть для интерполяции опорного пикселя может генерировать опорный пиксель элемента, состоящего из пикселей, который имеет целое значение или меньше посредством интерполяции опорного пикселя. Когда режим предсказания текущего элемента предсказания представляет собой режим предсказания, который генерирует блок предсказания без интерполяции опорного пикселя, опорный пиксель может не быть интерполирован. Фильтр DC может генерировать блок предсказания посредством фильтрации, когда режим предсказания текущего блока представляет собой режим DC.[95] When the prediction element prediction mode is a prediction element that performs intra prediction based on a pixel value obtained by interpolation of the reference pixel, the reference pixel interpolation part can generate a reference pixel of a pixel element that has an integer value or less by interpolation of the reference pixel. When the prediction mode of the current prediction element is a prediction mode that generates a prediction block without interpolation of the reference pixel, the reference pixel may not be interpolated. The DC filter may generate a prediction block by filtering when the prediction mode of the current block is the DC mode.
[96] Восстановленный блок или изображение могут быть предоставлены в часть 240 для фильтрации. Часть 240 для фильтрации может содержать деблочный фильтр, элемент для коррекции смещения и ALF.[96] The restored block or image may be provided to part 240 for filtering. The filtering portion 240 may include a deblocking filter, an element for offset correction, and an ALF.
[97] Информация о том, следует ли применять деблочный фильтр к соответствующему блоку или изображению, и информация о том, следует применять сильный фильтр или слабый фильтр, когда применяется деблочный фильтр, могут быть предоставлены видеокодером. В деблочный фильтр видеодекодера может быть предоставлена информация, связанная с деблочным фильтром, предоставленная видеокодером, и видеодекодер может выполнять фильтрацию для удаления блочности в отношении соответствующего блока.[97] Information on whether to apply a deblocking filter to a corresponding block or picture, and information on whether to apply a strong filter or a weak filter when a deblocking filter is applied, may be provided by the video encoder. The deblocking filter of the video decoder may be provided with information related to the deblocking filter provided by the video encoder, and the video decoder may perform deblocking filtering on the corresponding block.
[98] Элемент для коррекции смещения может выполнять коррекцию смещения в отношении восстановленного видео на основании типа коррекции смещения и информации о значении смещения, применяемых к видео при выполнении кодирования.[98] The offset correction element may perform offset correction on the reconstructed video based on the offset correction type and offset value information applied to the video when encoding is performed.
[99] ALF может применяться к элементу кодирования на основании информации о том, следует или нет применять ALF, и информации о коэффициентах ALF, предоставленной кодером. Информация об ALF может быть предоставлена для включения в набор конкретных параметров.[99] ALF may be applied to a coding element based on information about whether or not to apply ALF and information about ALF coefficients provided by the encoder. ALF information may be provided for inclusion in a set of specific parameters.
[100] Запоминающее устройство 245 может хранить восстановленное изображение или блок и использовать их в качестве опорного изображения или опорного блока и может предоставлять восстановленное изображение на элемент вывода.[100] The storage device 245 may store the reconstructed image or block and use it as a reference image or reference block, and may provide the reconstructed image to an output element.
[101][101]
[102] На фиг.3 представлен вид, показывающий базовый элемент кодового дерева согласно одному варианту осуществления настоящего изобретения.[102] FIG. 3 is a view showing a base element of a code tree according to one embodiment of the present invention.
[103] Блок кодирования максимального размера может быть определен как блок кодового дерева. Изображение разбивается на множество элементов кодового дерева (CTU). Элемент кодового дерева представляет собой элемент кодирования, имеющий максимальный размер, и может называться большой элемент кодирования (LCU). На фиг.3 представлен пример, в котором изображение разбивается на множество элементов кодового дерева.[103] A maximum size coding block may be defined as a code tree block. The image is split into multiple code tree elements (CTUs). A code tree element is a coding element having a maximum size, and may be referred to as a large coding unit (LCU). 3 shows an example in which an image is split into a plurality of code tree elements.
[104] Размер элемента кодового дерева может быть определен на уровне изображения или уровне последовательности. Для этого информация, указывающая размер элемента кодового дерева, может быть передана посредством набора параметров изображения или набора параметров последовательности.[104] The size of the element of the code tree can be determined at the image level or the sequence level. For this, information indicating the size of the element of the code tree may be transmitted by a set of picture parameters or a set of sequence parameters.
[105] Например, размер элемента кодового дерева для всего изображения в последовательности может быть установлен равным 128×128. Альтернативно на уровне изображения любой размер из 128×128 и 256×256 может быть определен как размер элемента кодового дерева. Например, размер элемента кодового дерева может быть установлен равным 128×128 в первом изображении, и размер элемента кодового дерева может быть установлен равным 256×256 во втором изображении.[105] For example, the size of the code tree element for the entire image in the sequence may be set to 128×128. Alternatively, at the image level, any size between 128x128 and 256x256 can be defined as the size of a code tree element. For example, the code tree element size may be set to 128×128 in the first picture, and the code tree element size may be set to 256×256 in the second picture.
[106] Блоки кодирования могут быть сгенерированы посредством разбиения элемента кодового дерева. Блок кодирования указывает базовый элемент для выполнения кодирования/декодирования. Например, предсказание или преобразование может выполняться для каждого блока кодирования, или режим кодирования с предсказанием может быть определен для каждого блока кодирования. В данном случае режим кодирования с предсказанием указывает способ генерирования изображения предсказания. Например, режим кодирования с предсказанием может включать предсказание в пределах изображения (внутреннее предсказание), предсказание между изображениями (предсказание, осуществляемое между изображениями), привязку к текущему изображению (CPR), или внутриблочное копирование (IBC), или комбинированное предсказание. Для блока кодирования блок предсказания может быть сгенерирован за счет использования по меньшей мере одного режима кодирования с предсказанием из внутреннего предсказания, предсказания, осуществляемого между изображениями, привязки к текущему изображению и комбинированного предсказания.[106] Encoding blocks may be generated by splitting an element of a code tree. The encoding block specifies the base element to perform encoding/decoding. For example, prediction or transformation may be performed for each coding block, or a predictive coding mode may be determined for each coding block. Here, the predictive coding mode indicates a prediction image generation method. For example, the predictive coding mode may include intra-picture prediction (intra prediction), inter-picture prediction (inter-picture prediction), current picture referencing (CPR), or intra-block copying (IBC), or combined prediction. For a coding block, a prediction block may be generated by using at least one predictive coding mode of intra prediction, inter-picture prediction, current picture anchoring, and combined prediction.
[107] Информация, указывающая режим кодирования с предсказанием текущего блока, может передаваться посредством битового потока. Например, информация может представлять собой 1-битный флаг, указывающий, является режим кодирования с предсказанием внутренним режимом или режимом, осуществляемым между изображениями. Только когда режим кодирования с предсказанием текущего блока определен как режим, осуществляемый между изображениями, может использоваться привязка к текущему изображению или комбинированное предсказание.[107] Information indicating the predictive coding mode of the current block may be transmitted via a bitstream. For example, the information may be a 1-bit flag indicating whether the predictive coding mode is an intra mode or an inter-picture mode. Only when the prediction coding mode of the current block is determined to be an inter-picture mode, current picture anchoring or combined prediction can be used.
[108] Привязка к текущему изображению предназначена для установления текущего изображения как опорного изображения и получения блока предсказания текущего блока из области, которая уже была кодирована/декодирована в текущем изображении. В данном случае текущее изображение означает изображение, содержащее текущий блок. Информация, указывающая, применяется ли привязка к текущему изображению к текущему блоку, может быть передана посредством битового потока. Например, информация может представлять собой 1-битный флаг.Когда флаг является истинным, режим кодирования с предсказанием текущего блока может быть определен как привязка к текущему изображению, а когда флаг является ложным, режим предсказания текущего блока может быть определен как предсказание, осуществляемое между изображениями.[108] Linking to the current picture is for setting the current picture as a reference picture and obtaining a prediction block of the current block from an area that has already been coded/decoded in the current picture. In this case, the current image means the image containing the current block. Information indicating whether the current picture anchor is applied to the current block may be transmitted via a bitstream. For example, the information may be a 1-bit flag. When the flag is true, the prediction coding mode of the current block may be defined as anchoring to the current picture, and when the flag is false, the prediction mode of the current block may be defined as inter-picture prediction.
[109] Альтернативно режим кодирования с предсказанием текущего блока может быть определен на основании индекса опорного изображения. Например, когда индекс опорного изображения указывает текущее изображение, режим кодирования с предсказанием текущего блока может быть определен как привязка к текущему изображению. Когда индекс опорного изображения указывает изображение, отличающееся от текущего изображения, режим кодирования с предсказанием текущего блока может быть определен как предсказание, осуществляемое между изображениями. То есть, привязка к текущему изображению представляет собой способ предсказания, использующий информацию об области, в которой было осуществлено кодирование/декодирование, в текущем изображении, и предсказание, осуществляемое между изображениями, представляет собой способ предсказания, использующий информацию о другом изображении, в котором было осуществлено кодирование/декодирование.[109] Alternatively, the predictive coding mode of the current block may be determined based on the reference picture index. For example, when the reference picture index indicates the current picture, the predictive coding mode of the current block may be defined as anchoring to the current picture. When the reference picture index indicates a picture different from the current picture, the prediction coding mode of the current block may be defined as a prediction performed between pictures. That is, linking to the current image is a prediction method using information about an area in which encoding/decoding has been performed in the current image, and prediction performed between images is a prediction method using information about another image in which encoding/decoding has been performed.
[110] Комбинированное предсказание представляет режим кодирования, в котором объединены два или более из внутреннего предсказания, предсказания, осуществляемого между изображениями, и текущего опорного изображения. Например, при применении комбинированного предсказания первый блок предсказания может быть сгенерирован на основании одно из внутреннего предсказания, предсказания, осуществляемого между изображениями, и привязки к текущему изображению, а второй блок предсказания может быть сгенерирован на основании другого из них. При генерировании первого блока предсказания и второго блока предсказания, конечный блок предсказания может быть сгенерирован посредством операции усреднения или операции взвешенного суммирования первого блока предсказания и второго блока предсказания. Информация, указывающая, применяется или нет комбинированное предсказание, может быть передана посредством битового потока. Информация может представлять собой 1-битный флаг.[110] Combined prediction represents a coding mode in which two or more of intra prediction, inter-picture prediction, and the current reference picture are combined. For example, when applying combined prediction, a first prediction block may be generated based on one of intra prediction, inter-picture prediction, and current picture anchoring, and a second prediction block may be generated based on the other of them. When the first prediction block and the second prediction block are generated, the final prediction block may be generated by an averaging operation or a weighted summation operation of the first prediction block and the second prediction block. Information indicating whether or not combined prediction is applied may be transmitted via a bitstream. The information may be a 1-bit flag.
[111] На фиг.4 представлен вид, показывающий различные типы разбиения блока кодирования.[111] FIG. 4 is a view showing various types of partitioning of a coding block.
[112] Блок кодирования может быть разбит на множество блоков кодирования на основании разбиения на основе четверичного дерева, разбиения на основе двоичного дерева или разбиения на основе троичного дерева. Разбитый блок кодирования может быть разбит снова на множество блоков кодирования на основании разбиения на основе четверичного дерева, разбиения на основе двоичного дерева или разбиения на основе троичного дерева.[112] A coding block may be partitioned into a plurality of coding blocks based on a quaternary tree partition, a binary tree partition, or a ternary tree partition. The split coding block may be split again into a plurality of coding units based on a quaternary tree split, a binary tree split, or a ternary tree split.
[113] Разбиение на основе четверичного дерева относится к методу разбиения, который разбивает текущий блок на четыре блока. В результате разбиения на основе четвертичного дерева текущий блок может быть разбит на четыре раздела квадратной формы (см. «SPLIT_QT» на фиг.4 (a)).[113] Quaternary tree splitting refers to a splitting method that splits the current block into four blocks. As a result of splitting based on a quaternary tree, the current block can be split into four square-shaped partitions (see "SPLIT_QT" in FIG. 4(a)).
[114] Разбиение на основе двоичного дерева относится к методу разбиения, который разбивает текущий блок на два блока. Разбиение текущего блока на два блока вдоль вертикального направления (т.е. с использованием вертикальной линии, пересекающей текущий блок) может называться разбиением на основе двоичного дерева в вертикальном направлении, и разбиение текущего блока на два блока вдоль горизонтального направления (т.е. с использованием горизонтальной линии, пересекающей текущий блок) может называться разбиением на основе двоичного дерева в горизонтальном направлении. В результате разбиения на основе двоичного дерева текущий блок может быть разбит на два раздела неквадратной формы. «SPLIT_BT_VER» на фиг.4 (b) представляет результат разбиения на основе двоичного дерева в вертикальном направлении, а «SPLIT_BT_HOR» на фиг.4 (c) представляет результат разбиения на основе двоичного дерева в горизонтальном направлении.[114] Binary tree splitting refers to a splitting method that splits the current block into two blocks. Splitting the current block into two blocks along the vertical direction (i.e. using a vertical line crossing the current block) may be referred to as binary tree splitting in the vertical direction, and splitting the current block into two blocks along the horizontal direction (i.e. using a horizontal line crossing the current block) may be referred to as binary tree splitting in the horizontal direction. As a result of splitting based on a binary tree, the current block can be split into two non-square sections. "SPLIT_BT_VER" in Fig. 4(b) represents the split result based on the binary tree in the vertical direction, and "SPLIT_BT_HOR" in Fig. 4(c) represents the result of the split based on the binary tree in the horizontal direction.
[115] Разбиение на основе троичного дерева относится к методу разбиения, который разбивает текущий блок на три блока. Разбиение текущего блока на три блока вдоль вертикального направления (т.е. с использованием двух вертикальных линий, пересекающих текущий блок) может называться разбиением на основе троичного дерева в вертикальном направлении, и разбиение текущего блока на три блока вдоль горизонтального направления (т.е. с использованием двух горизонтальных линий, пересекающих текущий блок) может называться разбиением на основе троичного дерева в горизонтальном направлении. В результате разбиения на основе троичного дерева текущий блок может быть разбит на три раздела неквадратной формы. В этом случае ширина/высота раздела, расположенного в центре текущего блока, может быть вдвое больше ширины/высоты других разделов. «SPLIT_TT_VER» на фиг.4 (d) представляет результат разбиения на основе троичного дерева в вертикальном направлении, а «SPLIT_TT_HOR» на фиг.4 (e) представляет результат разбиения на основе троичного дерева в горизонтальном направлении.[115] Ternary tree splitting refers to a splitting method that splits the current block into three blocks. Splitting the current box into three boxes along the vertical direction (i.e. using two vertical lines crossing the current box) may be referred to as ternary tree splitting in the vertical direction, and splitting the current box into three boxes along the horizontal direction (i.e. using two horizontal lines crossing the current box) may be referred to as ternary tree splitting in the horizontal direction. As a result of splitting based on a ternary tree, the current block can be split into three non-square sections. In this case, the width/height of the section located in the center of the current block can be twice the width/height of other sections. "SPLIT_TT_VER" in Fig. 4(d) represents a ternary tree split result in the vertical direction, and "SPLIT_TT_HOR" in Fig. 4(e) represents a ternary tree split result in the horizontal direction.
[116] Количество разбиений элемента кодового дерева может быть определено как глубина разбиения. Максимальная глубина разбиения элемента кодового дерева может быть определена на уровне последовательности или уровне изображения. Соответственно, максимальная глубина разбиения элемента кодового дерева может отличаться для каждой последовательности или изображения.[116] The number of splits of the element of the code tree can be defined as the split depth. The maximum splitting depth of a code tree element can be defined at the sequence level or the image level. Accordingly, the maximum splitting depth of a code tree element may differ for each sequence or image.
[117] Альтернативно максимальная глубина разбиения для каждого метода разбиения может быть определена отдельно. Например, максимальная глубина разбиения, допускаемая для разбиения на основе четверичного дерева, может быть отличной от максимальной глубины разбиения, допускаемой для разбиения на основе двоичного дерева и/или разбиения на основе троичного дерева.[117] Alternatively, the maximum splitting depth for each splitting method can be determined separately. For example, the maximum split depth allowed for a quad tree split may be different from the maximum split depth allowed for a binary tree split and/or a ternary tree split.
[118] Кодер может передавать информацию, указывающую по меньшей мере одно из типа разбиения и глубины разбиения текущего блока посредством битового потока. Декодер может определять тип разбиения и глубину разбиения элемента кодового дерева на основании информации, проанализированной из битового потока.[118] The encoder may transmit information indicative of at least one of the split type and split depth of the current block via the bitstream. The decoder may determine the split type and split depth of the code tree element based on the information parsed from the bitstream.
[119] На фиг.5 представлен вид, показывающий схему разбиения элемента кодового дерева.[119] FIG. 5 is a view showing a partitioning scheme of a code tree element.
[120] Разбиение блока кодирования с использованием такого метода разбиения, как разбиение на основе четверичного дерева, разбиение на основе двоичного дерева и/или разбиение на основе троичного дерева, может называться разбиением на основе нескольких деревьев.[120] Partitioning a coding block using a partitioning technique such as quaternary tree partitioning, binary tree partitioning, and/or ternary tree partitioning may be referred to as multi-tree partitioning.
[121] Блоки кодирования, сгенерированные путем применения разбиения на основе нескольких деревьев к блоку кодирования, могут называться нижними блоками кодирования. Когда глубина разбиения блока кодирования представляет собой k, глубина разбиения нижних блоков кодирования установлена равной k+1.[121] Encoding blocks generated by applying partitioning based on multiple trees to a coding block may be referred to as lower coding blocks. When the split depth of a coding block is k, the split depth of lower coding blocks is set to k+1.
[122] И наоборот, для блоков кодирования, имеющих глубину разбиения k+1, блок кодирования, имеющий глубину разбиения k, может называться верхним блоком кодирования.[122] Conversely, for coding blocks having a split depth of k+1, the coding block having a split depth of k may be referred to as an upper coding block.
[123] Тип разбиения текущего блока кодирования может быть определен на основании по меньшей мере одного из типа разбиения верхнего блока кодирования и типа разбиения соседнего блока кодирования. В данном случае соседний блок кодирования представляет собой блок кодирования, смежный с текущим блоком кодирования, и может включать по меньшей мере один из верхнего соседнего блока и левого соседнего блока текущего блока кодирования, и соседний блок, смежный с верхним левым углом. В данном случае тип разбиения может включать по меньшей мере одно из следующего: применялось ли разбиение на основе четверичного дерева, применялось ли разбиение на основе двоичного дерева, направление разбиения на основе двоичного дерева, применялось ли разбиение на основе троичного дерева и направление разбиения на основе троичного дерева.[123] A split type of a current coding block may be determined based on at least one of a split type of an upper coding block and a split type of an adjacent coding block. In this case, an adjacent coding block is a coding block adjacent to the current coding block, and may include at least one of the top neighboring block and the left neighboring block of the current coding block, and the neighboring block adjacent to the upper left corner. Here, the split type may include at least one of whether a quaternary tree split was applied, whether a binary tree based split was applied, a binary tree split direction, a ternary tree split, and a ternary tree split direction.
[124] Чтобы определить тип разбиения блока кодирования, информация, указывающая то, может ли быть разбит блок кодирования, может быть передана посредством битового потока. Информация представляет собой 1-битный флаг «split_cu_flag», и, когда флаг является истинным, она указывает, что блок кодирования разбит с помощью метода разбиения на основе четверичного дерева.[124] To determine the splitting type of a coding block, information indicating whether a coding block can be split can be transmitted via a bitstream. The information is a 1-bit flag "split_cu_flag", and when the flag is true, it indicates that the coding block has been split using a quad tree splitting method.
[125] Когда split_cu_flag является истинным, информация, указывающая то, разбит ли блок кодирования на основе четверичного дерева, может быть передана посредством битового потока. Информация представляет собой 1-битный флаг в виде split_qt_flag, и, когда флаг является истинным, блок кодирования может быть разбит на четыре блока.[125] When the split_cu_flag is true, information indicating whether the coding block is split based on a quaternary tree may be transmitted via a bitstream. The information is a 1-bit flag in the form of split_qt_flag, and when the flag is true, the coding block may be split into four blocks.
[126] Например, в примере, показанном на фиг.5, когда элемент кодового дерева разбит на основе четвертичного дерева, генерируются четыре блока кодирования, имеющие глубину разбиения 1. Кроме того, показано, что разбиение на основе четвертичного дерева применяется снова к первому и четвертому блокам кодирования из четырех блоков кодирования, сгенерированных в результате разбиения на основе четвертичного дерева. В результате могут быть сгенерированы четыре блока кодирования, имеющие глубину разбиения 2.[126] For example, in the example shown in FIG. 5, when a coding tree element is split based on a quaternary tree, four coding blocks having a split depth of 1 are generated. In addition, it is shown that splitting based on a quaternary tree is applied again to the first and fourth coding units of the four coding blocks generated as a result of splitting based on a quaternary tree. As a result, four coding blocks having a split depth of 2 can be generated.
[127] Кроме того, блоки кодирования, имеющие глубину разбиения, равную 3, могут быть сгенерированы путем повторного применения разбиения на основе четверичного дерева к блоку кодирования, имеющему глубину разбиения, равную 2.[127] In addition, coding blocks having a split depth of 3 can be generated by re-applying a quaternary tree split to a coding block having a split depth of 2.
[128] Когда разбиение на основе четверичного дерева не применяется к блоку кодирования, может быть определено то, выполняется ли разбиение на основе двоичного дерева или разбиение на основе троичного дерева в отношении блока кодирования, с учетом по меньшей мере одного из следующего: размера блока кодирования, расположен ли блок кодирования на границе изображения, максимальной глубины разбиения и типа разбиения соседнего блока. Когда определено, что следует выполнить разбиение на основе двоичного дерева или разбиение на основе троичного дерева в отношении блока кодирования, информация, указывающая направление разбиения, может быть передана посредством битового потока. Информация может представлять собой 1-битный флаг в виде mtt_split_cu_vertical_flag. На основании флага может быть определено, является направление разбиения вертикальным направлением или горизонтальным направлением. Дополнительно информация, указывающая то, применено ли разбиение на основе двоичного дерева или разбиение на основе троичного дерева к блоку кодирования, может быть передана посредством битового потока. Информация может представлять собой 1-битный флаг в виде mtt_split_cu_binary_flag. На основании флага может быть определено то, применено ли разбиение на основе двоичного дерева или разбиение на основе троичного дерева к блоку кодирования.[128] When quaternary tree splitting is not applied to a coding block, whether binary tree splitting or ternary tree splitting is performed on the coding block can be determined based on at least one of the coding block size, whether the coding block is located on an image boundary, the maximum splitting depth, and the neighboring block splitting type. When it is determined that binary tree splitting or ternary tree splitting is to be performed on a coding block, information indicating the splitting direction may be transmitted via a bitstream. The information may be a 1-bit flag in the form mtt_split_cu_vertical_flag. Based on the flag, it can be determined whether the splitting direction is the vertical direction or the horizontal direction. Additionally, information indicating whether binary tree splitting or ternary tree splitting has been applied to a coding block may be transmitted via a bitstream. The information may be a 1-bit flag in the form mtt_split_cu_binary_flag. Based on the flag, it can be determined whether binary tree splitting or ternary tree splitting is applied to the coding block.
[129] Например, в примере, показанном на фиг.5, показано, что разбиение на основе двоичного дерева в вертикальном направлении применено к блоку кодирования, имеющему глубину разбиения, равную 1, разбиение на основе троичного дерева в вертикальном направлении применено к левому блоку кодирования из блоков кодирования, сгенерированных в результате разбиения, и разбиение на основе двоичного дерева в вертикальном направлении применено к правому блоку кодирования.[129] For example, in the example shown in FIG. 5, vertical direction binary tree splitting is applied to a coding block having a split depth of 1, vertical direction ternary tree splitting is applied to the left coding block of the coding blocks generated by the splitting, and vertical direction binary tree splitting is applied to the right coding block.
[130][130]
[131] Предсказание, осуществляемое между изображениями, представляет собой режим кодирования с предсказанием, который предсказывает текущий блок путем использования информации о предшествующем изображении. Например, блок в том же положении, что и текущий блок в предшествующем изображении (далее - совмещаемый блок), может быть установлен как блок предсказания текущего блока. Далее блок предсказания, сгенерированный на основании блока в том же положении, что и текущий блок, будет называться совмещаемым блоком предсказания.[131] Inter-picture prediction is a predictive coding mode that predicts the current block by using information about the previous picture. For example, a block at the same position as the current block in the previous picture (hereinafter referred to as the matching block) may be set as the current block prediction block. Hereinafter, a prediction block generated based on a block at the same position as the current block will be referred to as a matching prediction block.
[132] С другой стороны, когда объект, находящийся в предшествующем изображении, переместился в другое положение в текущем изображении, текущий блок может быть эффективным образом предсказан путем использования движения объекта. Например, когда направление движения и размер объекта можно узнать путем сравнения предшествующего изображения и текущего изображения, блок предсказания (или изображение предсказания) текущего блока может быть сгенерирован с учетом информации о движении объекта. Далее блок предсказания, сгенерированный путем использования информации о движении, может называться блоком предсказания движения.[132] On the other hand, when an object in the previous image has moved to a different position in the current image, the current block can be effectively predicted by using the movement of the object. For example, when the direction of motion and the size of the object can be known by comparing the previous image and the current image, a prediction block (or prediction image) of the current block can be generated considering the motion information of the object. Hereinafter, a prediction block generated by using motion information may be referred to as a motion prediction block.
[133] Остаточный блок может быть сгенерирован путем вычитания блока предсказания из текущего блока. В этом случае, когда имеется движение объекта, энергия остаточного блока может быть уменьшена путем использования блока предсказания движения вместо совмещаемого блока предсказания, и, таким образом, эффективность сжатия остаточного блока может быть улучшена.[133] A residual block may be generated by subtracting a prediction block from the current block. In this case, when there is motion of an object, the energy of the residual block can be reduced by using a motion prediction block instead of a co-located prediction block, and thus the compression efficiency of the residual block can be improved.
[134] Как описано выше, генерирование блока предсказания путем использования информации о движении может называться предсказанием с компенсацией движения. В большинстве предсказаний, осуществляемых между изображениями, блок предсказания может быть сгенерирован на основании предсказания с компенсацией движения.[134] As described above, generating a prediction block by using motion information may be referred to as motion-compensated prediction. In most inter-picture predictions, a prediction block may be generated based on motion-compensated prediction.
[135] Информация о движении может содержать по меньшей мере одно из вектора движения, индекса опорного изображения, направления предсказания и двунаправленного весового индекса. Вектор движения указывает направление движения и размер объекта. Индекс опорного изображения указывает опорное изображение текущего блока из опорных изображений, включенных в список опорных изображений. Направление предсказания указывает любое из однонаправленного предсказания L0, однонаправленного предсказания L1 и двунаправленного предсказания (предсказания L0 и предсказания L1). Согласно направлению предсказания текущего блока может использоваться по меньшей мере одно из информации о движении в направлении L0 и информации о движении в направлении L1. Двунаправленный весовой индекс указывает значение взвешивания, примененное к блоку предсказания L0, и значение взвешивания, примененное к блоку предсказания L1.[135] The motion information may comprise at least one of a motion vector, a reference picture index, a prediction direction, and a bidirectional weight index. The motion vector indicates the direction of motion and the size of the object. The reference picture index indicates the reference picture of the current block among the reference pictures included in the reference picture list. The prediction direction indicates any one of L0 unidirectional prediction, L1 unidirectional prediction, and bidirectional prediction (L0 prediction and L1 prediction). According to the prediction direction of the current block, at least one of the motion information in the L0 direction and the motion information in the L1 direction may be used. The bidirectional weight index indicates the weighting value applied to the L0 prediction block and the weighting value applied to the L1 prediction block.
[136] На фиг.6 представлена блок-схема, изображающая способ предсказания, осуществляемого между изображениями, согласно одному варианту осуществления настоящего изобретения.[136] Figure 6 is a flowchart depicting a prediction method performed between pictures, according to one embodiment of the present invention.
[137] Как показано на фиг.6, способ предсказания, осуществляемого между изображениями, включает этапы определения (S601) режима предсказания, осуществляемого между изображениями, текущего блока, получения (S602) информации о движении текущего блока согласно определенному режиму предсказания, осуществляемого между изображениями, и выполнения (S603) предсказания с компенсацией движения для текущего блока на основании полученной информации о движении.[137] As shown in FIG. 6, the inter-picture prediction method includes the steps of determining (S601) an inter-picture prediction mode of the current block, obtaining (S602) motion information of the current block according to the determined inter-picture prediction mode, and performing (S603) motion compensation prediction for the current block based on the acquired motion information.
[138] В данном случае режим предсказания, осуществляемого между изображениями, представляет различные методы определения информации о движении текущего блока и может включать режим предсказания, осуществляемого между изображениями, который использует информацию о поступательном движении, и режим предсказания, осуществляемого между изображениями, который использует информацию об аффинном движении. Например, режим предсказания, осуществляемого между изображениями, который использует информацию о поступательном движении, может включать режим слияния и режим предсказания вектора движения, и режим предсказания, осуществляемого между изображениями, который использует информацию об аффинном движении, может включать аффинный режим слияния и режим предсказания вектора аффинного движения. Информация о движении текущего блока может быть определена на основании соседнего блока, смежного с текущим блоком, или информации, проанализированной из битового потока согласно режиму предсказания, осуществляемого между изображениями.[138] Here, the inter-picture prediction mode represents various methods for determining motion information of the current block, and may include an inter-picture prediction mode that uses translational motion information and an inter-picture prediction mode that uses affine motion information. For example, an inter-picture prediction mode that uses translational motion information may include a fusion mode and a motion vector prediction mode, and an inter-picture prediction mode that uses affine motion information may include an affine fusion mode and an affine motion vector prediction mode. The motion information of the current block may be determined based on a neighboring block adjacent to the current block or information parsed from the bitstream according to the inter-picture prediction mode.
[139] Например, информация о движении текущего блока может быть получена на основании информации о движении соседнего в пространственном отношении блока, включенного в изображение, который является таким же, как текущий блок, или совмещаемого блока, включенного в изображение, который является отличным от текущего блока. Соседний в пространственном отношении блок включает по меньшей мере один из соседнего блока, смежного с верхней стороной текущего блока, соседнего блока, смежного с левой стороной, соседнего блока, смежного с верхним левым углом, соседнего блока, смежного с верхним правым углом, и соседнего блока, смежного с нижним левым углом. Совмещаемый блок может иметь такие же положение и размер, как и у текущего блока в совмещаемом изображении. Например, на фиг.7 представлен вид, показывающий совмещаемый блок. Совмещаемое изображение может быть указано с помощью информации об индексах, указывающей любое из опорных изображений.[139] For example, the motion information of the current block may be obtained based on the motion information of a spatially adjacent block included in the image that is the same as the current block, or a matching block included in the image that is different from the current block. A spatially adjacent block includes at least one of a neighboring block adjacent to the top side of the current block, a neighboring block adjacent to the left side, a neighboring block adjacent to the upper left corner, a neighboring block adjacent to the upper right corner, and a neighboring block adjacent to the lower left corner. The merged block can have the same position and size as the current block in the merged image. For example, Fig. 7 is a view showing a matching block. The matching image may be indicated by index information indicating any one of the reference images.
[140] Любое из множества кандидатных значений точности вектора движения может быть определено как значение точности вектора движения текущего блока. Например, кандидатное значение точности вектора движения может включать по меньшей мере одно из одной восьмой пикселя, четверти пикселя, половины пикселя, целого пикселя, 2 целых пикселей и 4 целых пикселей. Количество или тип кандидатных значений точности вектора движения можно определить с помощью элемента последовательности, слайса или блока. Например, информация для определения количества или типа кандидатных значений точности вектора движения может быть передана посредством битового потока. Альтернативно количество или тип кандидатных значений точности вектора движения можно определить на основании того, используется ли режим предсказания, осуществляемого между изображениями, или модель аффинного движения. Информация для указания любого из множества кандидатных значений точности вектора движения может быть передана посредством битового потока.[140] Any of the plurality of candidate motion vector precision values may be determined as the motion vector precision value of the current block. For example, a candidate motion vector accuracy value may include at least one of one eighth of a pixel, a quarter of a pixel, a half of a pixel, an integer pixel, 2 integer pixels, and 4 integer pixels. The number or type of candidate motion vector accuracy values may be determined by a sequence element, slice, or block. For example, information for determining the number or type of candidate motion vector accuracy values may be transmitted via a bitstream. Alternatively, the number or type of candidate motion vector accuracy values may be determined based on whether an inter-picture prediction mode or an affine motion model is used. Information for indicating any of a plurality of candidate motion vector accuracy values may be transmitted via a bitstream.
[141] Внутреннее предсказание предназначено для предсказания текущего блока с использованием восстановленных отсчетов, которые были кодированы/декодированы поблизости от текущего блока. В этом случае отсчеты, восстановленные до применения фильтра в контуре, могут использоваться для внутреннего предсказания текущего блока.[141] Intra prediction is for predicting the current block using recovered samples that have been coded/decoded in the vicinity of the current block. In this case, the samples recovered before the application of the filter in the loop can be used for intra-prediction of the current block.
[142] Метод внутреннего предсказания включает внутреннее предсказание на основе матрицы и общее внутреннее предсказание, учитывающее направленность относительно соседних восстановленных отсчетов. Информация, указывающая метод внутреннего предсказания текущего блока, может передаваться посредством битового потока. Информация может представлять собой 1-битный флаг.Альтернативно метод внутреннего предсказания текущего блока может быть определен на основании по меньшей мере одного из положения текущего блока, размера текущего блока, формы текущего блока и метода внутреннего предсказания соседнего блока. Например, когда текущий блок находится на границе изображения, может быть установлено, что нет необходимости применять внутреннее предсказание на основе матрицы к текущему блоку.[142] The intra prediction method includes matrix-based intra prediction and general intra prediction considering directionality with respect to neighboring recovered samples. Information indicating the intra prediction method of the current block may be transmitted via a bitstream. The information may be a 1-bit flag. Alternatively, the intra prediction method of the current block may be determined based on at least one of the position of the current block, the size of the current block, the shape of the current block, and the intra prediction method of the neighboring block. For example, when the current block is on an image boundary, it may be determined that there is no need to apply matrix-based intra prediction to the current block.
[143] Внутреннее предсказание, представляющее собой внутреннее предсказание на основе матрицы, представляет собой способ получения блока предсказания текущего блока кодером и декодером на основании матричного произведения между ранее сохраненной матрицей и восстановленными отсчетами поблизости от текущего блока. Информация для указания любой из множества ранее сохраненных матриц может передаваться посредством битового потока. Декодер может определять матрицу для внутреннего предсказания текущего блока на основании информации и размера текущего блока.[143] Matrix-based intra prediction is a method for deriving a prediction block of a current block by an encoder and a decoder based on a matrix product between a previously stored matrix and reconstructed samples in the vicinity of the current block. Information for specifying any of a plurality of previously stored matrices may be transmitted via a bit stream. The decoder may determine a matrix for intra prediction of the current block based on the information and the size of the current block.
[144] Общее внутреннее предсказание представляет собой способ получения блока предсказания для текущего блока на основании режима внутреннего предсказания, не основанного на информации об углах, или режима внутреннего предсказания, основанного на информации об углах. Далее процесс выполнения внутреннего предсказания на основании общего внутреннего предсказания будет описан более подробно со ссылкой на графические материалы.[144] General intra prediction is a method for obtaining a prediction block for the current block based on an intra prediction mode not based on angle information or an intra prediction mode based on angle information. Next, the process of performing intra prediction based on the total intra prediction will be described in more detail with reference to the drawings.
[145] На фиг.8 представлена блок-схема, изображающая способ внутреннего предсказания согласно одному варианту осуществления настоящего изобретения.[145] FIG. 8 is a flowchart showing an intra prediction method according to one embodiment of the present invention.
[146] Может быть определена (S801) линия опорных отсчетов текущего блока. Линия опорных отсчетов означает набор опорных отсчетов, включенных в k-ю линию от верхней и/или левой стороны текущего блока. Опорные отсчеты могут быть получены из восстановленных отсчетов, которые были кодированы/декодированы поблизости от текущего блока.[146] A reference sample line of the current block can be determined (S801). Reference line means a set of reference points included in the k-th line from the top and/or left side of the current block. Reference samples may be derived from reconstructed samples that have been coded/decoded in the vicinity of the current block.
[147] Информация об индексах для идентификации линии опорных отсчетов текущего блока из множества линий опорных отсчетов может быть передана посредством битового потока. Например, информация об индексах intra_luma_ref_idx для указания линии опорных отсчетов текущего блока может быть передана посредством битового потока. Информация об индексах может быть передана элементом блока кодирования.[147] Index information for identifying a reference sample line of a current block from a plurality of reference sample lines may be transmitted via a bitstream. For example, information about indexes intra_luma_ref_idx to indicate the reference sample line of the current block may be transmitted via a bitstream. The index information may be conveyed by the coding block element.
[148] Множество линий опорных отсчетов может содержать по меньшей мере одно из первой линии, второй линии, третьей линии и четвертой линии сверху и/или слева от текущего блока. Линия опорных отсчетов, состоящая из строки, смежной с верхней стороной текущего блока, и столбца, смежного с левой стороной текущего блока из множества линий опорных отсчетов, называется смежной линией опорных отсчетов, и другие линии опорных отсчетов могут называться несмежными линиями опорных отсчетов.[148] The plurality of reference sample lines may comprise at least one of a first line, a second line, a third line, and a fourth line from above and/or to the left of the current block. A reference line consisting of a row adjacent to the top side of the current block and a column adjacent to the left side of the current block of the plurality of reference lines is referred to as an adjacent reference line, and other reference lines may be referred to as non-adjacent reference lines.
[149] На фиг.9 представлен вид, показывающий опорные отсчеты.[149] Fig. 9 is a view showing reference samples.
[150] На фиг.9 показана одна смежная линия опорных отсчетов, состоящая из строк и столбцов, смежных с текущим блоком, и три несмежные линии опорных отсчетов, состоящие из строк и столбцов, не смежных с текущим блоком.[150] Figure 9 shows one adjacent reference line consisting of rows and columns adjacent to the current block and three non-adjacent reference lines consisting of rows and columns not adjacent to the current block.
[151] Только некоторые из множества линий опорных отсчетов могут быть выбраны как линия опорных отсчетов текущего блока. Например, остальные линии опорных отсчетов, за исключением второй несмежной линии опорных отсчетов, из линий опорных отсчетов, показанных на фиг.9, могут быть установлены как кандидатные линии опорных отсчетов. В таблице 1 показаны индексы, соответственно присвоенные кандидатным линиям опорных отсчетов.[151] Only some of the plurality of reference sample lines may be selected as the reference sample line of the current block. For example, the rest of the reference lines except for the second non-adjacent reference line of the reference lines shown in FIG. 9 can be set as candidate reference lines. Table 1 shows the indexes respectively assigned to candidate reference sample lines.
[152] Таблица 1[152] Table 1
[153] Может быть установлено большее количество кандидатных линий опорных отсчетов или меньшее количество кандидатных линий опорных отсчетов, чем описанное выше количество кандидатных линий опорных отсчетов. Кроме того, количество или положения несмежных линий опорных отсчетов, установленных как кандидатные линии опорных отсчетов, не ограничиваются описанным выше примером. Например, первая несмежная линия опорных отсчетов и третья несмежная линия опорных отсчетов могут быть установлены как кандидатные линии опорных отсчетов, или вторая несмежная линия опорных отсчетов и третья несмежная линия опорных отсчетов могут быть установлены как кандидатные линии опорных отсчетов. Альтернативно все из первой несмежной линии опорных отсчетов, второй несмежной линии опорных отсчетов и третьей несмежной линии опорных отсчетов могут быть установлены как кандидатные линии опорных отсчетов.[153] More candidate reference sample lines or fewer candidate reference sample lines than the number of candidate reference sample lines described above may be set. In addition, the number or positions of non-adjacent reference sample lines set as candidate reference sample lines are not limited to the example described above. For example, the first non-adjacent reference line and the third non-adjacent reference line may be set as candidate reference lines, or the second non-adjacent reference line and the third non-adjacent reference line may be set as candidate reference lines. Alternatively, all of the first non-adjacent reference sample line, the second non-adjacent reference sample line, and the third non-adjacent reference sample line may be set as candidate reference sample lines.
[154] Количество или типы кандидатных линий опорных отсчетов могут быть определены на основании по меньшей мере одного из следующего: размера текущего блока, формы текущего блока, положения текущего блока, разбит ли текущий блок на подблоки и режима внутреннего предсказания текущего блока.[154] The number or types of candidate reference sample lines may be determined based on at least one of the current block size, the shape of the current block, the position of the current block, whether the current block is subblocked, and the intra prediction mode of the current block.
[155] Линия опорных отсчетов текущего блока может быть определена на основании по меньшей мере одного из положения текущего блока, размера текущего блока, формы текущего блока и режима кодирования с предсказанием соседнего блока. Например, когда текущий блок находится в контакте с границей изображения, тайла, слайса или элемента кодового дерева, смежная линия опорных отсчетов может быть определена как линия опорных отсчетов текущего блока.[155] The reference sample line of the current block may be determined based on at least one of the position of the current block, the size of the current block, the shape of the current block, and the neighboring block predictive coding mode. For example, when the current block is in contact with the border of an image, tile, slice, or code tree element, an adjacent reference sample line may be defined as the reference sample line of the current block.
[156] Альтернативно, когда текущий блок имеет неквадратную форму, смежная линия опорных отсчетов может быть определена как линия опорных отсчетов текущего блока. Альтернативно, когда соотношение ширины и высоты текущего блока больше, чем пороговое значение, или меньше, чем пороговое значение, смежная линия опорных отсчетов может быть определена как линия опорных отсчетов текущего блока.[156] Alternatively, when the current block has a non-square shape, an adjacent reference sample line may be defined as the reference sample line of the current block. Alternatively, when the width-to-height ratio of the current block is greater than the threshold value or less than the threshold value, the adjacent reference sample line may be determined as the reference sample line of the current block.
[157] Линия опорных отсчетов может включать верхние опорные отсчеты, расположенные сверху от текущего блока, и левые опорные отсчеты, расположенные слева от текущего блока. Верхние опорные отсчеты и левые опорные отсчеты могут быть получены из восстановленных отсчетов поблизости от текущего блока. Восстановленные отсчеты могут быть в состоянии до применения фильтра в контуре.[157] The reference sample line may include top reference samples located above the current block and left reference samples located to the left of the current block. The top reference points and the left reference points can be obtained from the reconstructed samples in the vicinity of the current block. The recovered samples may be in the state prior to applying the filter to the loop.
[158] Количество опорных отсчетов, включенных в линию опорных отсчетов, может быть определено на основании расстояния между линиями опорных отсчетов. Например, количество опорных отсчетов, включенных в линию опорных отсчетов, имеющих расстояние i от текущего блока, может быть больше, чем количество опорных отсчетов, включенных в линию опорных отсчетов, имеющих расстояние i-1 от текущего блока. Соответственно, количество опорных отсчетов, включенных в несмежную линию опорных отсчетов, может быть больше, чем количество опорных отсчетов, включенных в смежную линию опорных отсчетов.[158] The number of reference samples included in the reference sample line may be determined based on the distance between the reference sample lines. For example, the number of reference samples included in the reference line having distance i from the current block may be greater than the number of reference samples included in the reference line having distance i-1 from the current block. Accordingly, the number of reference samples included in a non-adjacent reference sample line may be greater than the number of reference samples included in an adjacent reference sample line.
[159] Разница между количеством опорных отсчетов, включенных в несмежную линию опорных отсчетов, имеющих расстояние i от текущего блока, и количеством опорных отсчетов, включенных в смежную линию опорных отсчетов, может быть определена как смещение количества опорных отсчетов. В этом случае разница в количестве верхних опорных отсчетов, расположенных сверху от текущего блока, может быть определена как offsetX[i], и разница в количестве левых опорных отсчетов, расположенных слева от текущего блока, может быть определена как offsetY[i]. offsetX и offsetY могут быть определены на основании расстояния между текущим блоком и несмежной линией опорных отсчетов. Например, offsetX и offsetY могут быть установлены равными целому кратному i. Например, offsetX[i] и offset[i] могут равняться 2i.[159] The difference between the number of reference samples included in a non-adjacent reference sample line having a distance i from the current block and the number of reference samples included in the adjacent reference sample line can be defined as a reference sample number offset. In this case, the difference in the number of top reference samples located above the current block may be defined as offsetX[i], and the difference in the number of left reference samples located to the left of the current block can be defined as offsetY[i]. offsetX and offsetY may be determined based on the distance between the current block and a non-adjacent reference sample line. For example, offsetX and offsetY can be set to an integer multiple of i. For example, offsetX[i] and offset[i] may be 2i.
[160] Альтернативно смещение количества опорных отсчетов может быть определено на основании соотношения ширины и высоты текущего блока. В уравнении 1 показан пример подсчета соотношения ширины и высоты текущего блока.[160] Alternatively, the offset of the number of reference samples may be determined based on the ratio of the width and height of the current block. Equation 1 shows an example of calculating the ratio of the width and height of the current box.
[161] [Уравнение 1][161] [Equation 1]
[162] Также можно подсчитать соотношение ширины и высоты текущего блока способом, отличным от выраженного в уравнении 1.[162] It is also possible to calculate the ratio of the width and height of the current box in a manner other than that expressed in Equation 1.
[163] Значения offsetX и offsetY могут быть определены на основании соотношения ширины и высоты текущего блока. Например, когда значение whRatio больше чем 1, значение offsetX может быть установлено так, чтобы быть больше, чем значение offsetY. Например, значение offsetX может быть установлено равным 1, и значение offsetY может быть установлено равным 0. С другой стороны, когда значение whRatio меньше чем 1, значение offsetY может быть установлено так, чтобы быть больше, чем значение offsetX. Например, значение offsetX может быть установлено равным 0, и значение offsetY может быть установлено равным 1.[163] The values of offsetX and offsetY may be determined based on the ratio of the width and height of the current block. For example, when the value of whRatio is greater than 1, the value of offsetX may be set to be greater than the value of offsetY. For example, the offsetX value may be set to 1, and the offsetY value may be set to 0. On the other hand, when the whRatio value is less than 1, the offsetY value may be set to be greater than the offsetX value. For example, the offsetX value may be set to 0 and the offsetY value may be set to 1.
[164] За исключением верхнего левого опорного отсчета, имеющего одинаковые координаты по оси x и оси y, несмежная линия опорных отсчетов, имеющая расстояние i от текущего блока, может состоять из верхних опорных отсчетов в количестве вплоть до (refW+offsetX[i]) и левых опорных отсчетов в количестве вплоть до (refH+offsetY[i]). В данном случае refW и refH обозначают длину смежной линии опорных отсчетов и могут быть установлены так, как показано в уравнениях 2 и 3 соответственно.[164] With the exception of the upper left reference sample having the same x-axis and y-axis coordinates, a non-adjacent reference sample line having a distance i from the current block may consist of up to (refW+offsetX[i]) upper reference samples and up to (refH+offsetY[i]) left reference samples. In this case, refW and refH denote the length of the adjacent reference sample line and can be set as shown in Equations 2 and 3, respectively.
[165] [Уравнение 2][165] [Equation 2]
[166] [Уравнение 3][166] [Equation 3]
[167] В уравнениях 2 и 3 nTbW обозначает ширину блока кодирования или блока преобразования, в отношении которого выполняют внутреннее предсказание, и nTbH обозначает высоту блока кодирования или блока преобразования, в отношении которого выполняют внутреннее предсказание.[167] In Equations 2 and 3, nTbW indicates the width of the coding block or transform block on which intra prediction is performed, and nTbH indicates the height of the coding block or transform block on which intra prediction is performed.
[168] В результате линия опорных отсчетов, которая находится на расстоянии i от текущего блока, может состоять из опорных отсчетов в количестве вплоть до (refW+refH+offsetX[i]+offsetY[i]+1).[168] As a result, a reference sample line that is at a distance i from the current block may consist of up to (refW+refH+offsetX[i]+offsetY[i]+1) reference samples.
[169] Согласно режиму внутреннего предсказания текущего блока отсчет предсказания может быть получен путем использования по меньшей мере одного из опорных отсчетов, принадлежащих к линии опорных отсчетов.[169] According to the intra prediction mode of the current block, a prediction sample can be obtained by using at least one of the reference samples belonging to the reference sample line.
[170] Далее может быть определен (S802) режим внутреннего предсказания текущего блока. Что касается режима внутреннего предсказания текущего блока, по меньшей мере один из режима внутреннего предсказания, не основанного на информации об углах, и режима внутреннего предсказания, основанного на информации об углах, может быть определен как режим внутреннего предсказания текущего блока. Режим внутреннего предсказания, не основанный на информации об углах, включает планарный режим и режим DC, а режим внутреннего предсказания, основанный на информации об углах, включает 33 или 65 режимов между диагональным направлением вниз и влево и диагональным направлением вверх и вправо.[170] Next, the intra prediction mode of the current block can be determined (S802). As for the intra prediction mode of the current block, at least one of the intra prediction mode not based on angle information and the intra prediction mode based on angle information can be defined as the intra prediction mode of the current block. The non-angle information intra prediction mode includes planar mode and DC mode, and the angle information based intra prediction mode includes 33 or 65 modes between diagonal down and left and diagonal up and right.
[171] На фиг.10 представлен вид, показывающий режимы внутреннего предсказания.[171] Fig. 10 is a view showing intra prediction modes.
[172] На фиг.10 (a) показаны 35 режимов внутреннего предсказания, и на фиг.10 (b) показаны 67 режимов внутреннего предсказания.[172] FIG. 10(a) shows 35 intra prediction modes, and FIG. 10(b) shows 67 intra prediction modes.
[173] Может быть определено большее или меньшее количество режимов внутреннего предсказания, чем показано на фиг.10.[173] More or fewer intra prediction modes may be defined than shown in FIG.
[174] Наиболее вероятный режим (MPM) может быть установлен на основании режима внутреннего предсказания соседнего блока, смежного с текущим блоком. В данном случае соседний блок может включать левый соседний блок, смежный с левой стороной текущего блока, и верхний соседний блок, смежный с верхней стороной текущего блока. Когда координаты верхнего левого отсчета текущего блока представляют собой (0, 0), левый соседний блок может содержать отсчет в положении (-1, 0), (-1, H-1) или (-1, (H-1)/2). В данном случае H обозначает высоту текущего блока. Верхний соседний блок может содержать отсчет в положении (0, -1), (W-1, -1) или ((W-1)/2, -1). В данном случае W обозначает ширину текущего блока.[174] The most probable mode (MPM) may be set based on the intra prediction mode of an adjacent block adjacent to the current block. In this case, the adjacent block may include a left adjacent block adjacent to the left side of the current block and a top adjacent block adjacent to the top side of the current block. When the coordinates of the top left reference of the current block are (0, 0), the left adjacent block may contain the reference at position (-1, 0), (-1, H-1) or (-1, (H-1)/2). In this case, H is the height of the current block. The top adjacent block may contain a count at position (0, -1), (W-1, -1) or ((W-1)/2, -1). In this case, W is the width of the current block.
[175] Когда соседний блок кодирован с помощью нормального внутреннего предсказания, MPM может быть получен на основании режима внутреннего предсказания соседнего блока. В частности, режим внутреннего предсказания левого соседнего блока может быть установлен как переменная candIntraPredModeA, а режим внутреннего предсказания верхнего соседнего блока может быть установлен как переменная candIntraPredModeB.[175] When a neighboring block is encoded with normal intra prediction, the MPM may be obtained based on the intra block mode of the neighboring block. Specifically, the left neighbor intra prediction mode may be set as the variable candIntraPredModeA, and the intra prediction mode of the upper neighbor block may be set as the variable candIntraPredModeB.
[176] В этом случае, когда соседний блок является недоступным (например, когда соседний блок еще не кодирован/декодирован или когда положение соседнего блока находится за границей изображения), когда соседний блок кодирован с помощью внутреннего предсказания на основе матрицы, когда соседний блок кодирован с помощью предсказания, осуществляемого между изображениями, или когда соседний блок включен в элемент кодового дерева, отличный от текущего блока, переменная candIntraPredModeX (в данном случае X представляет собой A или B), полученная на основании режима внутреннего предсказания соседнего блока, может быть установлена как режим по умолчанию. В данном случае режим по умолчанию может содержать по меньшей мере один из планарного режима, режима DC, режима в вертикальном направлении и режима в горизонтальном направлении.[176] In this case, when a neighboring block is unavailable (for example, when a neighboring block has not yet been coded/decoded or when the position of a neighboring block is outside a picture boundary), when a neighboring block is encoded with matrix-based intra prediction, when a neighboring block is encoded with inter-picture prediction, or when a neighboring block is included in a code tree element other than the current block, the variable candIntraPredModeX (in this case, X is A or B) obtained based on the intra prediction neighbor mode block, can be set as the default mode. Here, the default mode may comprise at least one of planar mode, DC mode, vertical direction mode, and horizontal direction mode.
[177] Альтернативно, когда соседний блок кодирован с помощью внутреннего предсказания на основе матрицы, режим внутреннего предсказания, соответствующий индексному значению для указания любой из матриц, может быть установлен равным candIntraPredModeX. Для этого в кодере и декодере может быть предварительно сохранена таблица поиска, показывающая взаимоотношение между индексными значениями для указания матрицы и режимов внутреннего предсказания.[177] Alternatively, when a neighboring block is encoded with matrix-based intra prediction, the intra prediction mode corresponding to an index value for indicating any of the matrices may be set to candIntraPredModeX. To this end, a lookup table showing the relationship between index values for indicating matrix and intra prediction modes may be previously stored in the encoder and decoder.
[178] MPM могут быть получены на основании переменной candIntraPredModeA и переменной candIntraPredModeB. Например, candIntraPredModeA и candIntraPredModeB могут быть установлены как MPM, или режим внутреннего предсказания, подобный большему или меньшему значению candIntraPredModeA или candIntraPredModeB, может быть установлен как MPM. В данном случае режим внутреннего предсказания, подобный candIntraPredModeX (X представляет собой A или B), может представлять собой режим внутреннего предсказания, значение индексной разницы с candIntraPredModeX которого составляет ±1 или ±2.[178] The MPMs can be obtained based on the candIntraPredModeA variable and the candIntraPredModeB variable. For example, candIntraPredModeA and candIntraPredModeB may be set to MPM, or an intra prediction mode like greater or lesser value of candIntraPredModeA or candIntraPredModeB may be set to MPM. Here, an intra prediction mode like candIntraPredModeX (X is A or B) may be an intra prediction mode whose index difference value with candIntraPredModeX is ±1 or ±2.
[179] Количество MPM, включенных в список MPM, может быть заранее установлено в кодере и декодере. Количество MPM, включенных в список MPM, может быть задано в кодере и декодере. Например, количество MPM может быть равно 3, 4, 5 или 6. Альтернативно информация, указывающая количество MPM, может быть передана посредством битового потока. Альтернативно количество MPM может быть определено на основании по меньшей мере одного из режима кодирования с предсказанием соседнего блока и размера, формы и индекса линии опорных отсчетов текущего блока. Например, когда смежная линия опорных отсчетов определена как линия опорных отсчетов текущего блока, могут быть использованы N MPM, тогда как, когда несмежная линия опорных отсчетов определена как линия опорных отсчетов текущего блока, могут быть использованы M MPM. M представляет собой натуральное число, которое меньше, чем N, и, например, N может быть равно 6, и M может быть равно 5, 4 или 3. Соответственно, когда индекс линии опорных отсчетов текущего блока равен 0, и флаг MPM является истинным, любой из 6 кандидатных режимов внутреннего предсказания может быть определен как режим внутреннего предсказания текущего блока, тогда как, когда индекс линии опорных отсчетов текущего блока больше чем 0 и флаг MPM является истинным, любой из 5 кандидатных режимов внутреннего предсказания может быть определен как режим внутреннего предсказания текущего блока.[179] The number of MPMs included in the MPM list may be preset in the encoder and decoder. The number of MPMs included in the MPM list may be set in the encoder and decoder. For example, the number of MPMs may be 3, 4, 5, or 6. Alternatively, information indicating the number of MPMs may be transmitted via a bitstream. Alternatively, the number of MPMs may be determined based on at least one of the adjacent block predictive coding mode and the size, shape, and reference sample line index of the current block. For example, when an adjacent reference line is defined as the current block reference line, N MPMs can be used, while when a non-adjacent reference sample line is defined as the current block reference line, M MPMs can be used. M is a natural number less than N, and for example, N may be 6, and M may be 5, 4, or 3. Accordingly, when the reference sample line index of the current block is 0 and the MPM flag is true, any of the 6 candidate intra prediction modes can be determined as the intra prediction mode of the current block, while when the reference sample line index of the current block is greater than 0 and the MPM flag is true, any of the 5 candidate intra prediction modes may be defined as the intra prediction mode of the current block.
[180] Альтернативно фиксированное количество (например, 6 или 5) MPM-кандидатов может быть использовано независимо от индекса линии опорных отсчетов текущего блока.[180] Alternatively, a fixed number (eg, 6 or 5) of MPM candidates may be used regardless of the reference sample line index of the current block.
[181] В вариантах осуществления, описанных ниже, предполагается, что количество MPM равно 6, и 6 MPM называются MPM[0], MPM[1], MPM[2], MPM[3], MPM[4] и MPM[5]. Вариант осуществления, в котором количество MPM меньше чем 6, может быть реализован путем использования только некоторых из 6 MPM, описанных в вариантах осуществления, описанных ниже. Альтернативно вариант осуществления, в котором количество MPM больше чем 6, может быть реализован так, чтобы включать 6 MPM, описанных в вариантах осуществления, описанных ниже.[181] In the embodiments described below, the number of MPMs is assumed to be 6, and the 6 MPMs are called MPM[0], MPM[1], MPM[2], MPM[3], MPM[4], and MPM[5]. An embodiment in which the number of MPMs is less than 6 can be realized by using only some of the 6 MPMs described in the embodiments described below. Alternatively, an embodiment in which the number of MPMs is greater than 6 may be implemented to include the 6 MPMs described in the embodiments described below.
[182] Исходные значения MPM могут быть установлены равными режиму внутреннего предсказания, не основанному на информации об углах, или режиму внутреннего предсказания, основанному на информации об углах, отличному от candIntraPredModeA и candIntraPredModeA. В данном случае режим внутреннего предсказания, основанный на информации об углах, который может быть установлен как MPM, может включать по меньшей мере один из режима внутреннего предсказания в вертикальном направлении, режима внутреннего предсказания в горизонтальном направлении, режима внутреннего предсказания в диагональном направлении вниз и влево, режима внутреннего предсказания в диагональном направлении вверх и влево и режима внутреннего предсказания в диагональном направлении вверх и вправо. Например, исходные значения MPM могут быть установлены следующим образом.[182] The initial MPM values may be set to an intra prediction mode not based on angle information or an intra prediction mode based on angle information other than candIntraPredModeA and candIntraPredModeA. Here, the angle information-based intra prediction mode, which can be set to MPM, may include at least one of the vertical intra prediction mode, the horizontal intra prediction mode, the down and left diagonal intra prediction mode, the up and left diagonal intra prediction mode, and the up and right diagonal intra prediction mode. For example, initial MPM values can be set as follows.
[183] MPM[0]=candIntraPredModeA[183] MPM[0]=candIntraPredModeA
[184] MPM[1]=(candIntraPredModeA=INTRA_PLANAR) ? INTRA_DC: INTRA_PLANAR[184] MPM[1]=(candIntraPredModeA=INTRA_PLANAR) ? INTRA_DC: INTRA_PLANAR
[185] MPM[2]=INTRA_ANGULAR50[185] MPM[2]=INTRA_ANGULAR50
[186] MPM[3]=INTRA_ANGULAR18[186] MPM[3]=INTRA_ANGULAR18
[187] MPM[4]=INTRA_ANGULAR2[187] MPM[4]=INTRA_ANGULAR2
[188] MPM[5]=INTRA_ANGULAR34[188] MPM[5]=INTRA_ANGULAR34
[189] В примере, описанном выше, ((A) ? B: C) представляет функцию, которая возвращает значение B, когда условие, раскрытое в A, является истинным, и возвращает значение C, когда условие, раскрытое в A, является ложным.[189] In the example above, ((A) ? B: C) represents a function that returns the value B when the condition expanded in A is true, and returns the value C when the condition expanded in A is false.
[190] Когда candIntraPredModeA и candIntraPredModeB являются одинаковыми, и candIntraPredModeA представляет собой режим внутреннего предсказания, основанный на информации об углах, MPM[0] может быть установлен равным candIntraPredModeA, и MPM могут быть установлены равными режимам внутреннего предсказания, подобным candIntraPredModeA. Режим внутреннего предсказания, подобный candIntraPredModeA, может представлять собой режим внутреннего предсказания, значение индексной разницы с candIntraPredModeA которого составляет ±1 или ±2. Операция по модулю (%) и смещение могут быть использованы для получения режима внутреннего предсказания, подобного candIntraPredModeA. Кроме того, MPM может быть установлен равным по меньшей мере одному из режима внутреннего предсказания, не основанного на информации об углах, и режима внутреннего предсказания, угловая разница от candIntraPredModeA которого представляет собой предварительно заданное значение. В данном случае режим внутреннего предсказания, угловая разница от candIntraPredModeA которого представляет собой предварительно заданное значение, может представлять собой режим внутреннего предсказания, перпендикулярный candIntraPredModeA, или режим внутреннего предсказания в направлении, противоположном направлению candIntraPredModeA. Например, MPM могут быть получены следующим образом.[190] When candIntraPredModeA and candIntraPredModeB are the same, and candIntraPredModeA is an intra prediction mode based on angle information, MPM[0] may be set to candIntraPredModeA, and MPM may be set to intra prediction modes like candIntraPredModeA. An intra prediction mode like candIntraPredModeA may be an intra prediction mode whose index difference value with candIntraPredModeA is ±1 or ±2. The modulo (%) operation and offset can be used to obtain an intra prediction mode like candIntraPredModeA. Further, the MPM may be set to at least one of an intra prediction mode not based on angle information and an intra prediction mode whose angle difference from candIntraPredModeA is a predetermined value. Here, the intra prediction mode whose angle difference from candIntraPredModeA is a predetermined value may be an intra prediction mode perpendicular to candIntraPredModeA or an intra prediction mode in a direction opposite to that of candIntraPredModeA. For example, MPM can be obtained as follows.
[191] MPM[0]=candIntraPredModeA[191] MPM[0]=candIntraPredModeA
[192] MPM[1]=INTRA_PLANAR[192] MPM[1]=INTRA_PLANAR
[193] MPM[2]=INTRA_DC[193] MPM[2]=INTRA_DC
[194] MPM[3]=2+((candIntraPredModeA+62) % 65)[194] MPM[3]=2+((candIntraPredModeA+62) % 65)
[195] MPM[4]=2+((candIntraPredModeA - 1) % 65)[195] MPM[4]=2+((candIntraPredModeA - 1) % 65)
[196] MPM[5]=2+((candIntraPredModeA+94) % 65)[196] MPM[5]=2+((candIntraPredModeA+94) % 65)
[197] MPM[3] соответствует (candIntraPredModeA-1), и MPM[4] соответствует (candIntraPredModeA+1). MPM[5] указывает режим внутреннего предсказания, перпендикулярный candIntraPredModeA.[197] MPM[3] matches (candIntraPredModeA-1) and MPM[4] matches (candIntraPredModeA+1). MPM[5] indicates the intra prediction mode perpendicular to candIntraPredModeA.
[198] Когда candIntraPredModeA и candIntraPredModeB отличаются друг от друга, candIntraPredModeA и candIntraPredModeB могут быть установлены как MPM[0] и MPM[1] соответственно. Альтернативно candIntraPredA сравнивают с candIntraPredModeB, и максимальное значение может быть установлено как MPM[0], и минимальное значение может быть установлено как MPM[1]. И наоборот, также можно установить минимальное значение как MPM[0], а максимальное значение как MPM[1].[198] When candIntraPredModeA and candIntraPredModeB differ from each other, candIntraPredModeA and candIntraPredModeB can be set to MPM[0] and MPM[1], respectively. Alternatively, candIntraPredA is compared to candIntraPredModeB and the maximum value may be set to MPM[0] and the minimum value may be set to MPM[1]. Conversely, you can also set the minimum value as MPM[0] and the maximum value as MPM[1].
[199] В этом случае, когда как candIntraPredModeA, так и candIntraPredModeB представляют собой режимы внутреннего предсказания, основанные на информации об углах, режим внутреннего предсказания, не основанный на информации об углах, может быть установлен как MPM. Например, планарный режим и режим DC могут быть установлены как MPM[2] и MPM[3] соответственно.[199] In this case, when both candIntraPredModeA and candIntraPredModeB are angle information based intra prediction modes, the angle information not based intra prediction mode can be set to MPM. For example, planar mode and DC mode can be set to MPM[2] and MPM[3] respectively.
[200] Дополнительно режим внутреннего предсказания, подобный любому из candIntraPredModeA и candIntraPredModeB, имеющий большее или меньшее значение, может быть установлен как MPM. Режим внутреннего предсказания, подобный candIntraPredModeX, может быть получен путем добавления смещения к candIntraPredModeX или вычитания из него. В этом случае максимальная величина смещения может быть определена на основании разницы между максимальным значением и минимальным значением candIntraPredModeA и candIntraPredModeB. Например, смещение может представлять собой натуральное число, такое как 1 или 2.[200] Additionally, an intra prediction mode like any of candIntraPredModeA and candIntraPredModeB having a larger or smaller value can be set to MPM. An intra prediction mode like candIntraPredModeX can be obtained by adding an offset to or subtracting from candIntraPredModeX. In this case, the maximum offset value may be determined based on the difference between the maximum value and the minimum value of candIntraPredModeA and candIntraPredModeB. For example, the offset can be a natural number such as 1 or 2.
[201] Например, когда значение разницы, полученное путем вычитания MIN(candIntraPredModeA, candIntraPredModeB) из MAX(candIntraPredModeA, candIntraPredModeB), не равно 64 или 1, MPM[4] и MPM[5] могут быть получены следующим образом.[201] For example, when the difference value obtained by subtracting MIN(candIntraPredModeA, candIntraPredModeB) from MAX(candIntraPredModeA, candIntraPredModeB) is not 64 or 1, MPM[4] and MPM[5] can be obtained as follows.
[202] MPM[4]=2+((MAX(MPM[0], MPM[1])+62) % 65[202] MPM[4]=2+((MAX(MPM[0], MPM[1])+62) % 65
[203] MPM[5]=2+((MAX(MPM[0], MPM[1]) - 1) % 65[203] MPM[5]=2+((MAX(MPM[0], MPM[1]) - 1) % 65
[204] В данном случае функция MAX(A, B) представляет собой функцию, которая возвращает большее значение из A и B, и функция MIN(A, B) представляет собой функцию, которая возвращает меньшее значение из A и B. MPM[4] соответствует (MAX(MPM[0], MPM[1]) - 1), и MPM[5] соответствует (MAX(MPM[0], MPM[1])+1). С другой стороны, когда значение разницы, полученное путем вычитания MIN (candIntraPredModeA, candIntraPredModeB) из MAX (candIntraPredModeA, candIntraPredModeB), равно 64 или 1, MPM[4] и MPM[5] могут быть получены следующим образом.[204] In this case, the MAX(A, B) function is a function that returns the larger value from A and B, and the MIN(A, B) function is a function that returns the smaller value from A and B. MPM[4] corresponds to (MAX(MPM[0], MPM[1]) - 1), and MPM[5] corresponds to (MAX(MPM[0], MPM[1])+1). On the other hand, when the difference value obtained by subtracting MIN (candIntraPredModeA, candIntraPredModeB) from MAX (candIntraPredModeA, candIntraPredModeB) is 64 or 1, MPM[4] and MPM[5] can be obtained as follows.
[205] MPM[4]=2+(MAX(MPM[0], MPM[1])+61) % 65[205] MPM[4]=2+(MAX(MPM[0], MPM[1])+61) % 65
[206] MPM[5]=2+MAX(MPM[0], MPM[1]) % 65[206] MPM[5]=2+MAX(MPM[0], MPM[1]) % 65
[207] MPM[4] соответствует (MAX(MPM[0], MPM[1]) - 2), и MPM[5] соответствует (MAX(MPM[0], MPM[1])+2).[207] MPM[4] corresponds to (MAX(MPM[0], MPM[1]) - 2), and MPM[5] corresponds to (MAX(MPM[0], MPM[1])+2).
[208] Когда один из candIntraPredModeA и candIntraPredModeB представляет собой режим внутреннего предсказания, основанный на информации об углах, тогда как другой представляет собой режим внутреннего предсказания, не основанный на информации об углах, по меньшей мере один из режима внутреннего предсказания, не основанного на информации об углах, который не равен MIN(candIntraPredModeA, candIntrapredModeB), режима внутреннего предсказания, основанного на информации об углах, который подобен MAX(candIntraPredModeA, candIntraPredModeB), и режима внутреннего предсказания, угловая разница от MAX(candIntraPredModeA, candIntraPredModeB) которого представляет собой предварительно заданное значение, может быть установлен как MPM. Например, MPM[2]-MPM[5] могут быть получены следующим образом.[208] When one of candIntraPredModeA and candIntraPredModeB is an intra prediction mode based on angle information, while the other is an intra prediction mode not based on angle information, at least one of the intra prediction mode not based on angle information that is not equal to MIN(candIntraPredModeA, candIntraPredModeB), an intra prediction mode based on angle information, which is like It is MAX(candIntraPredModeA, candIntraPredModeB), and the intra prediction mode whose angle difference from MAX(candIntraPredModeA, candIntraPredModeB) is a preset value can be set as MPM. For example, MPM[2]-MPM[5] can be obtained as follows.
[209] MPM[2]=! MIN(MPM[0], MPM[1])[209] MPM[2]=! MIN(MPM[0], MPM[1])
[210] MPM[3]=2+((MAX(MPM[0], MPM[1])+62) % 65[210] MPM[3]=2+((MAX(MPM[0], MPM[1])+62) % 65
[211] MPM[4]=2+((MAX(MPM[0], MPM[1]) - 1) % 65[211] MPM[4]=2+((MAX(MPM[0], MPM[1]) - 1) % 65
[212] MPM[5]=2+((MAX(MPM[0], MPM[1])+94) % 65[212] MPM[5]=2+((MAX(MPM[0], MPM[1])+94) % 65
[213] MPM[2] указывает режим внутреннего предсказания, не основанный на информации об углах, который не является таким же, как MPM[0] или MPM[1]. Например, когда MIN(MPM[0], MPM[1]) представляет собой режим DC, MPM[2] устанавливают в планарный режим, и, когда MIN(MPM[0], MPM[1]) представляет собой планарный режим, MPM[2] устанавливают в режим DC. MPM[3] соответствует ((MAX(MPM[0], MPM[1]) - 1), и MPM[4] соответствует ((MAX(MPM[0], MPM[1])+1). MPM[5] указывает режим внутреннего предсказания, перпендикулярный (MAX(MPM[0], MPM[1]). В отличие от примеров, перечисленных выше, MPM, полученный путем добавления 2 к MAX(MPM[0], MPM[1]) или вычитания из него, может быть добавлен в список MPM.[213] MPM[2] indicates an intra prediction mode not based on angle information, which is not the same as MPM[0] or MPM[1]. For example, when MIN(MPM[0], MPM[1]) is the DC mode, MPM[2] is set to the planar mode, and when MIN(MPM[0], MPM[1]) is the planar mode, MPM[2] is set to the DC mode. MPM[3] corresponds to ((MAX(MPM[0], MPM[1]) - 1), and MPM[4] corresponds to ((MAX(MPM[0], MPM[1])+1). MPM[5] indicates an intra prediction mode perpendicular to (MAX(MPM[0], MPM[1]). Unlike the examples listed above, an MPM obtained by adding 2 to or subtracting from MAX(MPM[0], MPM[1]) can be added to the list M P.M.
[214] Когда любой из candIntraPredA и candIntraPredB представляет собой внутренний режим, не основанный на информации об углах, а другой представляет собой режим внутреннего предсказания, основанный на информации об углах, т.е. любой из candIntraPredA и PredIntraPredB меньше чем 2, а другой равен или больше чем 2, максимальное значение из candIntraPredA и candIntraPredB может быть установлено как MPM. Кроме того, режим внутреннего предсказания, подобный максимальному значению, или режим внутреннего предсказания, перпендикулярный максимальному значению, может быть установлен как MPM. Например, MPM[0]-MPM[5] могут быть получены следующим образом.[214] When either of candIntraPredA and candIntraPredB is an intra mode not based on angle information and the other is an intra prediction mode based on angle information, i. e. either of candIntraPredA and PredIntraPredB is less than 2 and the other is equal to or greater than 2, the maximum value of candIntraPredA and candIntraPredB can be set to MPM. In addition, an intra prediction mode like the maximum value or an intra prediction mode perpendicular to the maximum value may be set to MPM. For example, MPM[0]-MPM[5] can be obtained as follows.
[215] MPM[0]=MAX(candIntraPredA, candIntraPredB)[215] MPM[0]=MAX(candIntraPredA, candIntraPredB)
[216] MPM[1]=INTRA_PLANAR[216] MPM[1]=INTRA_PLANAR
[217] MPM[2]=INTRA_DC[217] MPM[2]=INTRA_DC
[218] MPM[3]=2+((MAX(candIntraPredA, candIntraPredB)+62) % 65[218] MPM[3]=2+((MAX(candIntraPredA, candIntraPredB)+62) % 65
[219] MPM[4]=2+((MAX(candIntraPredA, candIntraPredB]) - 1) % 65[219] MPM[4]=2+((MAX(candIntraPredA, candIntraPredB]) - 1) % 65
[220] MPM[5]=2+((MAX(candIntraPredA, candIntraPredB)+94) % 65[220] MPM[5]=2+((MAX(candIntraPredA, candIntraPredB)+94) % 65
[221] MPM[3] соответствует (MAX(candIntraPredA, candIntraPredB) - 1), и MPM[4] соответствует (MAX(candIntraPredA, candIntraPredB)+1). MPM[5] указывает режим внутреннего предсказания, перпендикулярный MAX(candIntraPredA, candIntraPredB). В отличие от примеров, перечисленных выше, MPM, полученный путем добавления 2 к MAX(candIntraPredA, candIntraPredB) или вычитания из него, может быть добавлен в список MPM.[221] MPM[3] matches (MAX(candIntraPredA, candIntraPredB) - 1) and MPM[4] matches (MAX(candIntraPredA, candIntraPredB)+1). MPM[5] specifies the intra prediction mode perpendicular to MAX(candIntraPredA, candIntraPredB). Unlike the examples listed above, an MPM obtained by adding or subtracting 2 to MAX(candIntraPredA, candIntraPredB) can be added to the MPM list.
[222] MPM могут быть получены с учетом индекса линии опорных отсчетов текущего блока. В частности, когда несмежная линия опорных отсчетов определена как линия опорных отсчетов текущего блока, режим предсказания, не основанный на информации об углах, такой как планарный режим или режим DC, может не быть установлен как MPM. Например, исходные значения MPM могут быть установлены следующим образом согласно тому, определена ли смежная линия опорных отсчетов как линия опорных отсчетов текущего блока.[222] The MPMs may be obtained given the reference sample line index of the current block. In particular, when a non-adjacent reference sample line is determined to be the reference sample line of the current block, a prediction mode not based on angle information such as planar mode or DC mode may not be set to MPM. For example, the initial MPM values may be set as follows according to whether an adjacent reference sample line is determined to be the reference sample line of the current block.
[223] MPM[0]=(IntraLumaRefLineIdx=0) ? candIntraPredModeA: INTRA_ANGULAR2[223] MPM[0]=(IntraLumaRefLineIdx=0) ? candIntraPredModeA: INTRA_ANGULAR2
[224] MPM[1]=(IntraLumaRefLineIdx=0) ? (candIntraPredModeA:=INTRA_PLANAR ? INTRA_DC: INTRA_PLANAR): INTRA_ANGULAR18[224] MPM[1]=(IntraLumaRefLineIdx=0) ? (candIntraPredModeA:=INTRA_PLANAR ? INTRA_DC: INTRA_PLANAR): INTRA_ANGULAR18
[225] MPM[2]=INTRA_ANGULAR50[225] MPM[2]=INTRA_ANGULAR50
[226] MPM[3]=(IntraLumaRefLineIdx=0) ? INTRA_ANGULAR18: INTRA_ANGULAR34[226] MPM[3]=(IntraLumaRefLineIdx=0) ? INTRA_ANGULAR18: INTRA_ANGULAR34
[227] MPM[4]=(IntraLumaRefLineIdx=0) ? INTRA_ANGULAR2: INTRA_ANGULAR66[227] MPM[4]=(IntraLumaRefLineIdx=0) ? INTRA_ANGULAR2: INTRA_ANGULAR66
[228] MPM[5]=(IntraLumaRefLineIdx=0) ? INTRA_ANGULAR34: INTRA_ANGULAR42[228] MPM[5]=(IntraLumaRefLineIdx=0) ? INTRA_ANGULAR34: INTRA_ANGULAR42
[229] Когда линия опорных отсчетов текущего блока представляет собой несмежную линию опорных отсчетов, и как candIntraPredModeA, так и candIntraPredModeB представляют собой режимы внутреннего предсказания, основанные на информации об углах, MPM могут быть получены следующим образом.[229] When the reference sample line of the current block is a non-adjacent reference sample line, and both candIntraPredModeA and candIntraPredModeB are angle information-based intra prediction modes, the MPM can be obtained as follows.
[230] MPM[0]=candIntraPredModeA[230] MPM[0]=candIntraPredModeA
[231] MPM[1]=candIntraPredModeB[231] MPM[1]=candIntraPredModeB
[232] MPM[2]=INTRA_ANGULAR2[232] MPM[2]=INTRA_ANGULAR2
[233] MPM[3]=INTRA_ANGULAR18[233] MPM[3]=INTRA_ANGULAR18
[234] MPM[4]=INTRA_ANGULAR50[234] MPM[4]=INTRA_ANGULAR50
[235] MPM[5]=INTRA_ANGULAR34[235] MPM[5]=INTRA_ANGULAR34
[236] Когда линия опорных отсчетов текущего блока представляет собой несмежную линию опорных отсчетов, и любой из candIntraPredModeA и candIntraPredModeB представляет собой режим внутреннего предсказания, не основанный на информации об углах, а другой представляет собой режим внутреннего предсказания, основанный на информации об углах, MPM могут быть получены следующим образом.[236] When the reference sample line of the current block is a non-contiguous reference sample line, and either of candIntraPredModeA and candIntraPredModeB is an intra prediction mode not based on angle information, and the other is an intra prediction mode based on angle information, MPMs can be obtained as follows.
[237] MPM[0]=MAX(candIntraPredModeA, candIntraPredModeB)[237] MPM[0]=MAX(candIntraPredModeA, candIntraPredModeB)
[238] MPM[1]=INTRA_ANGULAR2[238] MPM[1]=INTRA_ANGULAR2
[239] MPM[2]=INTRA_ANGULAR18[239] MPM[2]=INTRA_ANGULAR18
[240] MPM[3]=INTRA_ANGULAR50[240] MPM[3]=INTRA_ANGULAR50
[241] MPM[4]=INTRA_ANGULAR34[241] MPM[4]=INTRA_ANGULAR34
[242] MPM[5]=INTRA_ANGULAR66[242] MPM[5]=INTRA_ANGULAR66
[243] Генерируется список MPM, содержащий множество MPM, и информация, указывающая, включен ли MPM, который является таким же, как режим внутреннего предсказания текущего блока, в список MPM, может быть передана посредством битового потока. Информация представляет собой 1-битный флаг и может называться флагом MPM. Когда флаг MPM указывает, что MPM, являющийся таким же, как у текущего блока, включен в список MPM, информация об индексах, указывающая один из MPM, может быть передана посредством битового потока. Например, информация об индексах mpm_idx, указывающая любой из множества MPM, может быть передана посредством битового потока. MPM, указанный информацией об индексах, может быть установлен как режим внутреннего предсказания текущего блока. Когда флаг MPM указывает, что MPM, являющийся таким же, как у текущего блока, не включен в список MPM, информация об остаточных режимах, указывающая любой из остаточных режимов внутреннего предсказания, отличных от MPM, может быть передана посредством битового потока. Информация об остаточных режимах указывает индексное значение, соответствующее режиму внутреннего предсказания текущего блока, когда индексы повторно присвоены остаточным режимам внутреннего предсказания за исключением MPM. Декодер может располагать MPM в возрастающем порядке и определять режим внутреннего предсказания текущего блока путем сравнения информации об остаточных режимах с MPM. Например, когда информация об остаточных режимах меньше или равна MPM, режим внутреннего предсказания текущего блока может быть получен путем добавления 1 к информации об остаточных режимах.[243] An MPM list containing a plurality of MPMs is generated, and information indicating whether an MPM that is the same as the intra prediction mode of the current block is included in the MPM list can be transmitted via a bitstream. The information is a 1-bit flag and may be referred to as the MPM flag. When the MPM flag indicates that an MPM that is the same as that of the current block is included in the MPM list, index information indicating one of the MPMs may be transmitted via a bitstream. For example, index information mpm_idx indicating any one of a plurality of MPMs may be transmitted via a bitstream. The MPM indicated by the index information may be set as the intra prediction mode of the current block. When the MPM flag indicates that an MPM that is the same as that of the current block is not included in the MPM list, residual mode information indicating any of the non-MPM residual intra prediction modes may be transmitted via a bitstream. The residual mode information indicates an index value corresponding to the intra prediction mode of the current block when the indices are reassigned to the residual intra prediction modes except for MPM. The decoder may arrange the MPM in ascending order and determine the intra prediction mode of the current block by comparing the residual mode information with the MPM. For example, when the residual mode information is less than or equal to MPM, the intra prediction mode of the current block can be obtained by adding 1 to the residual mode information.
[244] Когда получен режим внутреннего предсказания текущего блока, сравнение между некоторым из MPM и информацией об остаточных режимах может быть пропущено. Например, MPM режима внутреннего предсказания, не основанного на информации об углах, из MPM могут быть исключены из целей сравнения. Когда режимы внутреннего предсказания, не основанные на информации об углах, установлены как MPM, очевидно, что информация об остаточных режимах указывает режим внутреннего предсказания, основанный на информации об углах, и, таким образом, режим внутреннего предсказания текущего блока может быть получен посредством сравнения между остаточными MPM, за исключением режимов внутреннего предсказания, не основанных на информации об углах, и информацией об остаточных режимах. Вместо исключения режимов внутреннего предсказания, не основанных на информации об углах, из целей сравнения, количество режимов внутреннего предсказания, не основанных на информации об углах, добавляется в информацию об остаточных режимах, а затем полученное в результате значение сравнения может быть сравнено с остаточными MPM.[244] When the intra prediction mode of the current block is obtained, the comparison between some of the MPMs and the residual mode information may be skipped. For example, the MPM of the angle information-free intra prediction mode of the MPM may be excluded from comparison purposes. When the intra prediction modes not based on the angle information are set to MPM, it is obvious that the residual mode information indicates the intra prediction mode based on the angle information, and thus the intra prediction mode of the current block can be obtained by comparison between the residual MPMs except for the intra prediction modes not based on the angle information and the residual mode information. Instead of excluding intra prediction modes not based on angle information from comparison purposes, the number of intra prediction modes not based on angle information is added to the residual mode information, and then the resulting comparison value can be compared with the residual MPMs.
[245] Вместо установки режима по умолчанию как MPM, информация, указывающая, является ли режим внутреннего предсказания текущего блока режимом по умолчанию, может быть передана посредством битового потока. Информация представляет собой 1-битный флаг, и флаг может называться флагом режима по умолчанию. Флаг режима по умолчанию может быть передан только тогда, когда флаг MPM указывает, что MPM, являющийся таким же, как у текущего блока, включен в список MPM. Как описано выше, режим по умолчанию может содержать по меньшей мере один из планарного режима, режима DC, режима в вертикальном направлении и режима в горизонтальном направлении. Например, когда планарный режим установлен как режим по умолчанию, флаг режима по умолчанию может указывать, является ли режим внутреннего предсказания текущего блока планарным режимом. Когда флаг режима по умолчанию указывает, что режим внутреннего предсказания текущего блока не является режимом по умолчанию, один из MPM, указанных информацией об индексах, может быть установлен как режим внутреннего предсказания текущего блока.[245] Instead of setting the default mode as MPM, information indicating whether the intra prediction mode of the current block is the default mode may be transmitted via a bitstream. The information is a 1-bit flag, and the flag may be referred to as the default mode flag. The default mode flag can only be transmitted when the MPM flag indicates that an MPM that is the same as the current block is included in the MPM list. As described above, the default mode may comprise at least one of planar mode, DC mode, vertical direction mode, and horizontal direction mode. For example, when the planar mode is set as the default mode, the default mode flag may indicate whether the intra prediction mode of the current block is the planar mode. When the default mode flag indicates that the intra prediction mode of the current block is not the default mode, one of the MPMs indicated by the index information may be set as the intra prediction mode of the current block.
[246] Когда используют флаг режима по умолчанию, он может быть установлен так, чтобы не устанавливать режим внутреннего предсказания, который является таким же, как режим по умолчанию, как MPM. Например, когда флаг режима по умолчанию указывает, является ли режим внутреннего предсказания текущего блока планарным режимом, MPM, соответствующий планарному режиму, из 6 MPM, описанных выше, заменяется другим режимом, или режим внутреннего предсказания текущего блока может быть получен путем использования 5 MPM, за исключением MPM, соответствующего планарному режиму.[246] When using the default mode flag, it can be set to not set the intra prediction mode, which is the same as the default mode as MPM. For example, when the default mode flag indicates whether the intra prediction mode of the current block is the planar mode, the MPM corresponding to the planar mode of the 6 MPMs described above is replaced by another mode, or the intra prediction mode of the current block can be obtained by using 5 MPMs except for the MPM corresponding to the planar mode.
[247] Когда множество режимов внутреннего предсказания установлены как режимы по умолчанию, информация об индексах, указывающая любой из режимов по умолчанию, может быть передана дальше. Режим внутреннего предсказания текущего блока может быть установлен как режим по умолчанию, указанный информацией об индексах.[247] When a plurality of intra prediction modes are set as default modes, index information indicating any of the default modes can be passed on. The intra prediction mode of the current block may be set as the default mode indicated by the index information.
[248] Когда индекс линии опорных отсчетов текущего блока не равен 0, может быть установлено не использовать режим по умолчанию. Например, может быть установлено не использовать режим внутреннего предсказания, не основанный на информации об углах, такой как режим DC или планарный режим, когда несмежная линия опорных отсчетов определена как линия опорных отсчетов текущего блока. Соответственно, когда индекс линии опорных отсчетов не равен 0, флаг режима по умолчанию не передается, и значение флага режима по умолчанию может быть установлено таким же, как предварительно заданное значение (т.е. ложное).[248] When the reference sample line index of the current block is not equal to 0, it may be set not to use the default mode. For example, it may be set not to use an intra prediction mode not based on angle information such as DC mode or planar mode when a non-adjacent reference sample line is determined to be the reference sample line of the current block. Accordingly, when the reference sample line index is not 0, the default mode flag is not transmitted, and the value of the default mode flag can be set to the same as a preset value (ie, false).
[249] Когда режим внутреннего предсказания текущего блока определен, отсчеты предсказания могут быть получены для текущего блока на основании определенного режима внутреннего предсказания (S803).[249] When the intra prediction mode of the current block is determined, prediction samples can be obtained for the current block based on the determined intra prediction mode (S803).
[250] Когда выбран режим DC, отсчеты предсказания генерируются для текущего блока на основании среднего значения опорных отсчетов. В частности, значения всех отсчетов в блоке предсказания могут быть сгенерированы на основании среднего значения опорных отсчетов. Среднее значение может быть получено с использованием по меньшей мере одного из верхних опорных отсчетов, расположенных сверху текущего блока, и левых опорных отсчетов, расположенных слева текущего блока.[250] When the DC mode is selected, prediction samples are generated for the current block based on the average value of the reference samples. In particular, the values of all samples in the prediction block may be generated based on the average value of the reference samples. The average value can be obtained using at least one of the top reference samples located on top of the current block and the left reference samples located on the left of the current block.
[251] В зависимости от формы текущего блока, количество или диапазон опорных отсчетов, используемых для получения среднего значения, могут меняться. Например, когда текущий блок представляет собой блок неквадратной формы, ширина которого больше, чем высота, среднее значение может быть вычислено с использованием только верхних опорных отсчетов. С другой стороны, когда текущий блок представляет собой блок неквадратной формы, ширина которого меньше, чем высота, среднее значение может быть вычислено с использованием только левых опорных отсчетов. То есть, когда ширина и высота текущего блока различаются, среднее значение может быть вычислено с использованием только опорных отсчетов, смежных с тем, что больше. Альтернативно на основании соотношения ширины и высоты текущего блока можно определить, следует вычислять среднее значение с использованием только верхних опорных отсчетов или следует вычислять среднее значение с использованием только левых опорных отсчетов.[251] Depending on the shape of the current block, the number or range of reference samples used to obtain the average may vary. For example, when the current block is a non-square block whose width is greater than its height, the average value may be calculated using only the top reference samples. On the other hand, when the current block is a non-square block whose width is smaller than the height, the average value can be calculated using only the left reference samples. That is, when the width and height of the current block are different, the average can be calculated using only the reference samples adjacent to the one that is larger. Alternatively, based on the ratio of the width and height of the current block, it can be determined whether the average value should be calculated using only the top reference samples, or whether the average value should be calculated using only the left reference samples.
[252] Когда выбран планарный режим, отсчет предсказания может быть получен с использованием отсчета предсказания в горизонтальном направлении и отсчета предсказания в вертикальном направлении. В данном случае отсчет предсказания в горизонтальном направлении получают на основании левого опорного отсчета и правого опорного отсчета, расположенных на той же горизонтальной линии, что и отсчет предсказания, а отсчет предсказания в вертикальном направлении получают на основании верхнего опорного отсчета и нижнего опорного отсчета, расположенных на той же вертикальной линии, что и отсчет предсказания. В данном случае правый опорный отсчет может быть сгенерирован путем копирования опорного отсчета, смежного с верхним правым углом текущего блока, а нижний опорный отсчет может быть сгенерирован путем копирования опорного отсчета, смежного с нижним левым углом текущего блока. Отсчет предсказания в горизонтальном направлении может быть получен на основании операции взвешенного суммирования левого опорного отсчета и правого опорного отсчета, а отсчет предсказания в вертикальном направлении может быть получен на основании операции взвешенного суммирования верхнего опорного отсчета и нижнего опорного отсчета. В этом случае значение взвешивания, присвоенное каждому опорному отсчету, может быть определено согласно положению отсчета предсказания. Отсчет предсказания может быть получен на основании операции усреднения или операции взвешенного суммирования отсчета предсказания в горизонтальном направлении и отсчета предсказания в вертикальном направлении. Когда выполняется операция взвешенного суммирования, значения взвешивания, применяемые к отсчету предсказания в горизонтальном направлении и отсчету предсказания в вертикальном направлении, могут быть определены на основании положения отсчета предсказания.[252] When the planar mode is selected, the prediction sample can be obtained using the prediction sample in the horizontal direction and the prediction sample in the vertical direction. In this case, the horizontal direction prediction sample is obtained based on the left reference sample and the right reference sample located on the same horizontal line as the prediction sample, and the vertical direction prediction sample is obtained based on the upper reference sample and the lower reference sample located on the same vertical line as the prediction sample. In this case, the right reference may be generated by copying the reference adjacent to the upper right corner of the current block, and the lower reference may be generated by copying the reference adjacent to the lower left corner of the current block. The horizontal direction prediction sample may be obtained based on the weighted sum operation of the left reference sample and the right reference sample, and the vertical direction prediction sample may be obtained based on the weighted sum operation of the upper reference sample and the lower reference sample. In this case, the weighting value assigned to each reference sample can be determined according to the position of the prediction sample. The prediction sample may be obtained based on an averaging operation or a weighted summing operation of the horizontal direction prediction sample and the vertical direction prediction sample. When the weighted sum operation is performed, the weighting values applied to the prediction sample in the horizontal direction and the prediction sample in the vertical direction may be determined based on the position of the prediction sample.
[253] Когда выбран режим предсказания, основанный на информации об углах, может быть определен параметр, указывающий направление предсказания (или угол предсказания) выбранного режима предсказания, основанного на информации об углах. В таблице 2 показан параметр intraPredAng внутреннего направления каждого режима внутреннего предсказания.[253] When a prediction mode based on angle information is selected, a parameter indicating a prediction direction (or a prediction angle) of the selected prediction mode based on angle information can be determined. Table 2 shows the intraPredAng parameter of the intra direction of each intra prediction mode.
[254] [Таблица 2][254] [Table 2]
[255] Когда определены 35 режимов внутреннего предсказания, в таблице 2 показан параметр внутреннего направления каждого режима внутреннего предсказания, имеющего любой индекс от 2 до 34. Когда определены более 33 режимов внутреннего предсказания, основанных на информации об углах, таблица 2 дополнительно поделена, чтобы установить параметр внутреннего направления каждого режима внутреннего предсказания, основанного на информации об углах.[255] When 35 intra prediction modes are defined, Table 2 shows the intra direction parameter of each intra prediction mode having any index from 2 to 34. When more than 33 intra prediction modes based on angle information are defined, Table 2 is further divided to set the intra direction parameter of each intra prediction mode based on angle information.
[256] После размещения верхних опорных отсчетов и левых опорных отсчетов текущего блока в линию отсчет предсказания может быть получен на основании значения параметра внутреннего направления. В этом случае, когда значение параметра внутреннего направления представляет собой отрицательное значение, левые опорные отсчеты и верхние опорные отсчеты могут быть расположены в линию.[256] After placing the top reference samples and left reference samples of the current block in a line, a prediction sample can be obtained based on the value of the inner direction parameter. In this case, when the value of the inside direction parameter is a negative value, the left reference samples and the upper reference samples may be aligned.
[257] На фиг.11 и 12 представлены виды, показывающие пример одномерного массива, размещающего опорные отсчеты в линию.[257] Figures 11 and 12 are views showing an example of a one-dimensional array placing reference samples in a line.
[258] На фиг.11 представлен вид, показывающий пример одномерного массива в вертикальном направлении, размещающего опорные отсчеты в вертикальном направлении, а на фиг.12 представлен вид, показывающий пример одномерного массива в горизонтальном направлении, размещающего опорные отсчеты в горизонтальном направлении. Варианты осуществления, представленные на фиг.11 и 12, будут описаны с предположением, что определены 35 режимов внутреннего предсказания.[258] FIG. 11 is a view showing an example of a one-dimensional array in the vertical direction arranging reference samples in the vertical direction, and FIG. 12 is a view showing an example of a 1-dimensional array in the horizontal direction arranging reference samples in the horizontal direction. The embodiments shown in FIGS. 11 and 12 will be described with the assumption that 35 intra prediction modes are defined.
[259] Когда индекс режима внутреннего предсказания является любым из 11-18, может быть применен одномерный массив в горизонтальном направлении, в котором верхние опорные отсчеты поворачиваются против часовой стрелки, а когда индекс режима внутреннего предсказания является любым из 19-25, может быть применен одномерный массив в вертикальном направлении, в котором левые опорные отсчеты поворачиваются по часовой стрелке. При расположении опорных отсчетов в линию можно учесть угол режима внутреннего предсказания.[259] When the intra prediction mode index is any of 11-18, a one-dimensional array in the horizontal direction in which the top reference samples are rotated counterclockwise can be applied, and when the intra prediction mode index is any of 19-25, a one-dimensional array in the vertical direction can be applied in which the left reference samples are rotated clockwise. When arranging the reference readings in a line, the angle of the intra prediction mode can be taken into account.
[260] Параметр определения опорного отсчета может быть определен на основании параметра внутреннего направления. Параметр определения опорного отсчета может содержать индекс опорного отсчета для указания опорного отсчета и параметр значения взвешивания для определения значения взвешивания, применяемого к опорному отсчету.[260] The reference sample determination parameter may be determined based on the internal direction parameter. The reference value determination parameter may comprise a reference value index for specifying the reference value and a weighting value parameter for determining a weighting value applied to the reference value.
[261] Индекс iIdx опорного отсчета и параметр ifact значения взвешивания могут быть получены с помощью уравнений 4 и 5, показанных ниже, соответственно.[261] The index iIdx of the reference sample and the parameter ifact of the weighting value can be obtained using Equations 4 and 5 shown below, respectively.
[262] [Уравнение 4][262] [Equation 4]
[263] [Уравнение 5][263] [Equation 5]
[264] В уравнениях 4 и 5 Pang обозначает параметр внутреннего направления. Опорный отсчет, указанный индексом iIdx опорного отсчета, соответствует целому пикселю.[264] In Equations 4 and 5, Pang denotes the internal direction parameter. The reference sample indicated by index iIdx of the reference sample corresponds to an integer pixel.
[265] По меньшей мере один или более опорных отсчетов могут быть указаны для получения отсчета предсказания. В частности, положение опорного отсчета, используемого для получения отсчета предсказания, может быть указано с учетом наклона режима предсказания. Например, опорный отсчет, используемый для получения отсчета предсказания, может быть указан с использованием индекса iIdx опорного отсчета.[265] At least one or more reference samples may be specified to obtain a prediction sample. In particular, the position of the reference sample used to obtain the prediction sample may be indicated in view of the slope of the prediction mode. For example, the reference sample used to obtain the prediction sample may be indicated using the index iIdx of the reference sample.
[266] В этом случае, когда наклон режима внутреннего предсказания не выражен одним опорным отсчетом, отсчет предсказания может быть сгенерирован путем интерполяции множества опорных отсчетов. Например, когда наклон режима внутреннего предсказания представляет собой значение между наклоном между отсчетом предсказания и первым опорным отсчетом и наклоном между отсчетом предсказания и вторым опорным отсчетом, отсчет предсказания может быть получен путем интерполяции первого опорного отсчета и второго опорного отсчета. То есть, когда угловая линия, проходящая под углом внутреннего предсказания, не проходит сквозь опорный отсчет, расположенный в целом пикселе, отсчет предсказания может быть получен путем интерполяции опорных отсчетов, смежных с левой и правой или верхней или нижней сторонами положения, в котором угловая линия проходит сквозь.[266] In this case, when the slope of the intra prediction mode is not expressed by one reference sample, the prediction sample can be generated by interpolating a plurality of reference samples. For example, when the slope of the intra prediction mode is a value between the slope between the prediction sample and the first reference sample and the slope between the prediction sample and the second reference sample, the prediction sample can be obtained by interpolating the first reference sample and the second reference sample. That is, when the corner line passing at the intra prediction angle does not pass through the reference sample located in the whole pixel, the prediction sample can be obtained by interpolating the reference samples adjacent to the left and right or upper or lower side of the position where the corner line passes through.
[267] В уравнении 6 показан пример получения отсчета предсказания на основании опорных отсчетов.[267] Equation 6 shows an example of obtaining a prediction sample based on reference samples.
[268] [Уравнение 6][268] [Equation 6]
[269] В уравнении 6 P обозначает отсчет предсказания, а Ref_1D обозначает любой из одномерно размещенных опорных отсчетов. В этом случае положение опорного отсчета может быть определено посредством положения (x, y) отсчета предсказания и индекса iIdx опорного отсчета.[269] In Equation 6, P denotes a prediction sample, and Ref_1D denotes any one of the one-dimensionally placed reference samples. In this case, the position of the reference sample can be determined by the position (x, y) of the prediction sample and the index iIdx of the reference sample.
[270] Когда наклон режима внутреннего предсказания может быть выражен в виде одного опорного отсчета, параметр значения взвешивания ifact установлен равным 0. Соответственно, уравнение 6 может быть упрощено, как показано в уравнении 7.[270] When the slope of the intra prediction mode can be expressed as one reference sample, the weighting value parameter ifact is set to 0. Accordingly, Equation 6 can be simplified as shown in Equation 7.
[271] [Уравнение 7][271] [Equation 7]
[272] Внутреннее предсказание для текущего блока может быть выполнено на основании множества режимов внутреннего предсказания. Например, режим внутреннего предсказания может быть получен для каждого отсчета предсказания, и отсчет предсказания может быть получен на основании режима внутреннего предсказания, присвоенного каждому отсчету предсказания.[272] Intra prediction for the current block may be performed based on a plurality of intra prediction modes. For example, the intra prediction mode may be obtained for each prediction sample, and the prediction sample may be obtained based on the intra prediction mode assigned to each prediction sample.
[273] Альтернативно режим внутреннего предсказания может быть получен для каждого участка, и внутреннее предсказание для каждого участка может быть выполнено на основании режима внутреннего предсказания, присвоенного каждому участку. В данном случае участок может содержать по меньшей мере один отсчет.По меньшей мере одно из размера и формы участка может быть адаптивно определен на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания текущего блока. Альтернативно по меньшей мере одно из размера и формы участка может быть предварительно задан в кодере и декодере, чтобы быть независимым от размера или формы текущего блока.[273] Alternatively, an intra prediction mode may be obtained for each section, and intra prediction for each section may be performed based on the intra prediction mode assigned to each section. In this case, the patch may comprise at least one sample. At least one of the size and shape of the patch may be adaptively determined based on at least one of the size, shape, and intra prediction mode of the current block. Alternatively, at least one of the chunk size and shape may be predetermined at the encoder and decoder to be independent of the size or shape of the current block.
[274] Альтернативно внутреннее предсказание может быть выполнено на основании каждого из множества внутренних предсказаний, и конечный отсчет предсказания может быть получен на основании операции усреднения или операции взвешенного суммирования множества отсчетов предсказания, полученных с помощью множества внутренних предсказаний. Например, первый отсчет предсказания может быть получен путем выполнения внутреннего предсказания на основании первого режима внутреннего предсказания, а второй отсчет предсказания может быть получен путем выполнения внутреннего предсказания на основании второго режима внутреннего предсказания. После этого конечный отсчет предсказания может быть получен на основании операции усреднения или операции взвешенного суммирования первого отсчета предсказания и второго отсчета предсказания. В этом случае значение взвешивания, присвоенное каждому из первого отсчета предсказания и второго отсчета предсказания, может быть определено с учетом по меньшей мере одного из того, является ли первый режим внутреннего предсказания режимом предсказания, не основанным на информации об углах / режимом предсказания, основанным на информации об углах, того, является ли второй режим внутреннего предсказания режимом предсказания, не основанным на информации об углах / режимом предсказания, основанным на информации об углах, и режима внутреннего предсказания соседнего блока.[274] Alternatively, intra prediction may be performed based on each of the plurality of intra predictions, and the final prediction sample may be obtained based on an averaging operation or a weighted summation operation of the plurality of prediction samples obtained by the plurality of intra predictions. For example, the first prediction sample may be obtained by performing intra prediction based on the first intra prediction mode, and the second prediction sample may be obtained by performing intra prediction based on the second intra prediction mode. Thereafter, the final prediction sample may be obtained based on an averaging operation or a weighted summation operation of the first prediction sample and the second prediction sample. In this case, the weighting value assigned to each of the first prediction sample and the second prediction sample can be determined considering at least one of whether the first intra prediction mode is a non-angle information based prediction mode/angle information based prediction mode, whether the second intra prediction mode is a non-angle information based prediction mode/angle information based prediction mode, and a neighboring block intra prediction mode.
[275] Множество режимов внутреннего предсказания могут представлять собой комбинацию режима внутреннего предсказания, не основанного на информации об углах, и режима предсказания, основанного на информации об углах, комбинацию режимов предсказания, основанных на информации об углах, или комбинацию режимов предсказания, не основанных на информации об углах.[275] The plurality of intra prediction modes may be a combination of an intra prediction mode not based on angle information and a prediction mode based on angle information, a combination of prediction modes based on angle information, or a combination of prediction modes not based on angle information.
[276] На фиг.13 представлен вид, показывающий пример углов, образованных между режимами внутреннего предсказания, основанными на информации об углах, и прямой линией, параллельной оси x.[276] FIG. 13 is a view showing an example of angles formed between angle information-based intra prediction modes and a straight line parallel to the x-axis.
[277] Как показано в примере на фиг.13, режимы предсказания, основанные на информации об углах, могут существовать между диагональным направлением вниз и влево и диагональным направлением вверх и вправо. При описании в отношении угла, образованного осью x и режимом предсказания, основанным на информации об углах, режимы предсказания, основанные на информации об углах, могут существовать между 45 градусами (диагональным направлением вниз и влево) и -135 градусами (диагональным направлением вверх и вправо).[277] As shown in the example of FIG. 13, prediction modes based on angle information can exist between diagonal down and left and diagonal up and right. When described with respect to the angle formed by the x-axis and the angle information based prediction mode, the angle information based prediction modes can exist between 45 degrees (diagonal down and left) and -135 degrees (diagonal up and right).
[278] Когда текущий блок имеет неквадратную форму, согласно режиму внутреннего предсказания текущего блока может иметь место случай получения отсчета предсказания благодаря использованию опорного отсчета дальше от отсчета предсказания вместо опорного отсчета еще ближе к отсчету предсказания из опорных отсчетов, расположенных на угловой линии, проходящей под углом внутреннего предсказания.[278] When the current block has a non-square shape, according to the intra prediction mode of the current block, there may be a case of obtaining a prediction sample by using a reference sample further from the prediction sample instead of a reference sample even closer to the prediction sample from the reference samples located on the angular line passing at the angle of intra prediction.
[279] На фиг.14 представлен вид, показывающий вариант осуществления получения отсчетов предсказания, когда текущий блок имеет неквадратную форму.[279] FIG. 14 is a view showing an embodiment of obtaining prediction samples when the current block has a non-square shape.
[280] Например, как показано в примере на фиг.14 (a), предполагается, что текущий блок имеет неквадратную форму, ширина которой больше, чем высота, и режим внутреннего предсказания текущего блока является режимом внутреннего предсказания, основанным на информации об углах, имеющим угол от 0 до 45 градусов. В приведенном выше случае, когда получают отсчет предсказания A возле правого столбца текущего блока, может иметь место случай использования левого опорного отсчета L далеко от отсчета предсказания вместо верхнего опорного отсчета T возле отсчета предсказания из опорных отсчетов, расположенных на угловом режиме, проходящим под углом.[280] For example, as shown in the example of FIG. 14(a), it is assumed that the current block has a non-square shape whose width is larger than the height, and the intra prediction mode of the current block is an intra prediction mode based on angle information having an angle of 0 to 45 degrees. In the above case, when a prediction sample A near the right column of the current block is obtained, there may be a case of using the left reference sample L away from the prediction sample instead of the upper reference sample T near the prediction sample from the reference samples located on the corner mode passing at the angle.
[281] В качестве другого примера, как показано в примере на фиг.14 (b), предполагается, что текущий блок имеет неквадратную форму, высота которой больше, чем ширина, и режим внутреннего предсказания текущего блока является режимом внутреннего предсказания, основанным на информации об углах, имеющим угол от -90 до -135 градусов. В приведенном выше случае, когда получают отсчет предсказания A возле нижней строки текущего блока, может иметь место случай использования верхнего опорного отсчета T далеко от отсчета предсказания вместо левого опорного отсчета L возле отсчета предсказания из опорных отсчетов, расположенных на угловом режиме, проходящим под углом.[281] As another example, as shown in the example of FIG. 14(b), it is assumed that the current block has a non-square shape whose height is greater than the width, and the intra prediction mode of the current block is an intra prediction mode based on angle information having an angle of -90 to -135 degrees. In the above case, when a prediction sample A near the bottom line of the current block is obtained, there may be a case of using the top reference sample T away from the prediction sample instead of the left reference sample L near the prediction sample from the reference samples located on the angular mode passing at the angle.
[282] Для решения проблемы, описанной выше, когда текущий блок имеет неквадратную форму, режим внутреннего предсказания текущего блока может быть заменен режимом внутреннего предсказания в противоположном направлении. Соответственно, режимы предсказания, основанные на информации об углах, имеющие угол больше или меньше, чем у режимов предсказания, основанных на информации об углах, показанных на фиг.10, могут быть использованы для блока неквадратной формы. Такой режим внутреннего предсказания, основанный на информации об углах, может быть определен как широкоугольный режим внутреннего предсказания. Широкоугольный режим внутреннего предсказания представляет режим внутреннего предсказания, основанный на информации об углах, который не принадлежит к диапазону от 45 до -135 градусов.[282] To solve the problem described above, when the current block has a non-square shape, the intra prediction mode of the current block may be replaced by the intra prediction mode in the opposite direction. Accordingly, angle information based prediction modes having an angle greater than or smaller than the angle information based prediction modes shown in FIG. 10 can be used for a non-square shaped block. Such an intra prediction mode based on angle information may be defined as a wide-angle intra prediction mode. The wide-angle intra prediction mode represents an intra prediction mode based on angle information that does not belong to the range of 45 to -135 degrees.
[283] На фиг.15 представлен вид, показывающий широкоугольные режимы внутреннего предсказания.[283] FIG. 15 is a view showing wide-angle intra prediction modes.
[284] В примере, показанном на фиг.15, режимы внутреннего предсказания с индексом от -1 до -14 и режимы внутреннего предсказания с индексом от 67 до 80 представляют широкоугольные режимы внутреннего предсказания.[284] In the example shown in FIG. 15, intra prediction modes with an index of -1 to -14 and intra prediction modes with an index of 67 to 80 represent wide-angle intra prediction modes.
[285] Хотя на фиг.15 показаны 14 широкоугольных режимов внутреннего предсказания (от -1 до -14), имеющих угол, который больше 45 градусов, и 14 широкоугольных режимов внутреннего предсказания (от 67 до 80), имеющих угол, который меньше -135 градусов, может быть определено большее или меньшее количество широкоугольных режимов внутреннего предсказания.[285] Although Fig. 15 shows 14 wide-angle intra prediction modes (-1 to -14) having an angle that is greater than 45 degrees and 14 wide-angle intra prediction modes (67 to 80) having an angle that is less than -135 degrees, more or fewer wide-angle intra prediction modes can be defined.
[286] Когда используется широкоугольный режим внутреннего предсказания, длина верхних опорных отсчетов может быть установлена равной 2W+1, а длина левых опорных отсчетов может быть установлена равной 2H+1.[286] When the wide-angle intra prediction mode is used, the length of the top reference samples may be set to 2W+1, and the length of the left reference samples may be set to 2H+1.
[287] Так как используется широкоугольный режим внутреннего предсказания, отсчет A, показанный на фиг.14 (a), может быть предсказан с использованием опорного отсчета T, а отсчет A, показанный на фиг.14 (b), может быть предсказан с использованием опорного отсчета L.[287] Since the wide-angle intra prediction mode is used, the sample A shown in Fig. 14(a) can be predicted using the reference sample T, and the sample A shown in Fig. 14(b) can be predicted using the reference sample L.
[288] Путем сложения существующих режимов внутреннего предсказания и N широкоугольных режимов внутреннего предсказания можно использовать суммарно 67+N режимов внутреннего предсказания. Например, в таблице 3 показаны параметры внутреннего направления режимов внутреннего предсказания, когда определены 20 широкоугольных режимов внутреннего предсказания.[288] By adding the existing intra prediction modes and N wide-angle intra prediction modes, a total of 67+N intra prediction modes can be used. For example, Table 3 shows the intra direction parameters of the intra prediction modes when 20 wide-angle intra prediction modes are defined.
[289] [Таблица 3][289] [Table 3]
[290] Когда текущий блок имеет неквадратную форму, и режим внутреннего предсказания текущего блока, полученный на этапе S802, принадлежит к диапазону преобразования, режим внутреннего предсказания текущего блока может быть преобразован в широкоугольный режим внутреннего предсказания. Диапазон преобразования может быть определен на основании по меньшей мере одного из размера, формы и соотношения текущего блока. В данном случае соотношение может представлять соотношение ширины и высоты текущего блока.[290] When the current block has a non-square shape, and the intra prediction mode of the current block obtained in step S802 belongs to the transform range, the intra prediction mode of the current block can be converted to a wide-angle intra prediction mode. The transform range may be determined based on at least one of the size, shape, and ratio of the current block. In this case, the ratio can represent the ratio of the width and height of the current box.
[291] Когда текущий блок имеет неквадратную форму, ширина которой больше, чем высота, диапазон преобразования может быть установлен от индекса режима внутреннего предсказания (например, 66) диагонального направления вверх и вправо (индекса режима внутреннего предсказания в диагональном направлении вверх и вправо - N). В данном случае N может быть определен на основании соотношения текущего блока. Когда режим внутреннего предсказания текущего блока принадлежит к диапазону преобразования, режим внутреннего предсказания может быть преобразован в широкоугольный режим внутреннего предсказания. Преобразование может представлять собой вычитание предварительно заданного значения из режима внутреннего предсказания, и предварительно заданное значение может представлять собой общее число (например, 67) режимов внутреннего предсказания за исключением широкоугольных режимов внутреннего предсказания.[291] When the current block has a non-square shape whose width is larger than the height, the transform range can be set from the up and right diagonal intra prediction mode index (e.g., 66) (up and right diagonal intra prediction mode index - N). In this case, N may be determined based on the ratio of the current block. When the intra prediction mode of the current block belongs to the transform range, the intra prediction mode can be converted to the wide-angle intra prediction mode. The transform may be a subtraction of a preset value from an intra prediction mode, and the preset value may be a total number (eg, 67) of intra prediction modes excluding wide-angle intra prediction modes.
[292] Согласно варианту осуществления, описанному выше, режимы внутреннего предсказания с 66-го по 53-й могут быть преобразованы в широкоугольные режимы внутреннего предсказания с -1-го по -14-й соответственно.[292] According to the embodiment described above, intra prediction modes 66 to 53 can be converted to wide-angle intra prediction modes -1 to -14, respectively.
[293] Когда текущий блок имеет неквадратную форму, высота которой больше, чем ширина, диапазон преобразования может быть установлен от индекса режима внутреннего предсказания (например, 2) диагонального направления вниз и влево (индекса режима внутреннего предсказания в диагональном направлении вниз и влево+M). В данном случае M может быть определен на основании соотношения текущего блока. Когда режим внутреннего предсказания текущего блока принадлежит к диапазону преобразования, режим внутреннего предсказания может быть преобразован в широкоугольный режим внутреннего предсказания. Преобразование может представлять собой добавление предварительно заданного значения к режиму внутреннего предсказания, и предварительно заданное значение может представлять собой общее число (например, 65) режимов внутреннего предсказания, основанных на информации об углах, за исключением широкоугольных режимов внутреннего предсказания.[293] When the current block has a non-square shape whose height is greater than the width, the transform range may be set from the diagonal down-left intra prediction mode index (e.g., 2) (down-left diagonal intra prediction mode index+M). In this case, M may be determined based on the ratio of the current block. When the intra prediction mode of the current block belongs to the transform range, the intra prediction mode can be converted to the wide-angle intra prediction mode. The transform may be an addition of a predetermined value to an intra prediction mode, and the predetermined value may be a total number (eg, 65) of intra prediction modes based on angle information, excluding wide-angle intra prediction modes.
[294] Согласно варианту осуществления, описанному выше, режимы внутреннего предсказания со 2-го по 15-й могут быть преобразованы в широкоугольные режимы внутреннего предсказания с 67-го по 80-й соответственно.[294] According to the embodiment described above, intra prediction modes 2 to 15 can be converted to wide-angle intra prediction modes 67 to 80, respectively.
[295] Далее режимы внутреннего предсказания, принадлежащие к диапазону преобразования, будут называться широкоугольными заменяющими режимами внутреннего предсказания.[295] In the following, the intra prediction modes belonging to the transform range will be referred to as wide-angle replacement intra prediction modes.
[296] Диапазон преобразования может быть определен на основании соотношения текущего блока. Например, в таблицах 4 и 5 показан диапазон преобразования, когда определены 35 режимов внутреннего предсказания и 67 режимов внутреннего предсказания за исключением широкоугольных режимов внутреннего предсказания соответственно.[296] The conversion range may be determined based on the ratio of the current block. For example, Tables 4 and 5 show the transform range when 35 intra prediction modes and 67 intra prediction modes are defined excluding wide-angle intra prediction modes, respectively.
[297] [Таблица 4][297] [Table 4]
[298] [Таблица 5][298] [Table 5]
[299] Как показано в примерах из таблиц 4 и 5, количество широкоугольных заменяющих режимов внутреннего предсказания, принадлежащих к диапазону преобразования, может меняться согласно соотношению текущего блока.[299] As shown in the examples of Tables 4 and 5, the number of wide-angle replacement intra prediction modes belonging to the transform range may vary according to the ratio of the current block.
[300] Диапазон преобразования, как показано в таблице 6, может быть установлен путем подразделения соотношения текущего блока.[300] The conversion range, as shown in Table 6, can be set by subdividing the ratio of the current block.
[301] [Таблица 6][301] [Table 6]
[302] Может быть установлено не использовать широкоугольный режим внутреннего предсказания, когда несмежная линия опорных отсчетов определена как линия опорных отсчетов текущего блока или когда используется способ кодирования с внутренним предсказанием с несколькими линиями для выбора любой из множества линий опорных отсчетов. То есть, хотя текущий блок имеет неквадратную форму, и режим внутреннего предсказания текущего блока принадлежит к диапазону преобразования, режим внутреннего предсказания текущего блока может не быть преобразован в широкоугольный режим внутреннего предсказания.[302] It may be set not to use the wide-angle intra prediction mode when a non-adjacent reference sample line is determined to be the reference sample line of the current block or when a multi-line intra prediction coding method is used to select any of the plurality of reference sample lines. That is, although the current block has a non-square shape and the intra prediction mode of the current block belongs to the transform range, the intra prediction mode of the current block may not be converted to the wide-angle intra prediction mode.
[303] Альтернативно могут быть установлены несмежные линии опорных отсчетов как недоступные в качестве линии опорных отсчетов текущего блока, или может быть установлено не использовать способ кодирования с внутренним предсказанием с несколькими линиями для выбора любой из множества линий опорных отсчетов, когда режим внутреннего предсказания текущего блока определен как широкоугольный режим внутреннего предсказания. Когда способ кодирования с внутренним предсказанием с несколькими линиями не используется, смежная линия опорных отсчетов может быть определена как линия опорных отсчетов текущего блока.[303] Alternatively, non-adjacent reference sample lines may be set to not be available as the reference sample line of the current block, or may be set to not use the multi-line intra prediction coding method to select any of the plurality of reference sample lines when the intra prediction mode of the current block is determined to be the wide-angle intra prediction mode. When the multi-line intra prediction coding method is not used, an adjacent reference sample line may be determined as the reference sample line of the current block.
[304] Когда широкоугольный режим внутреннего предсказания не используется, сумма nTbW и nTbH может быть установлена как refW и refH. Соответственно, за исключением верхнего левого опорного отсчета, несмежный опорный отсчет, находящийся на расстоянии i от текущего блока, может включать вплоть до (nTbW+nTbH+offsetX[i]) верхних опорных отсчетов и вплоть до (nTbW+nTbH+offsetY[i]) левых опорных отсчетов. То есть несмежный опорный отсчет, находящийся на расстоянии i от текущего блока, может включать вплоть до (2nTbW+2nTbH+offsetX[i]+offsetY[i]+1) опорных отсчетов. Например, когда значение whRatio больше чем 1, значение offsetX может быть установлено так, чтобы быть больше, чем значение offsetY. Например, значение offsetX может быть установлено равным 1, и значение offsetY может быть установлено равным 0. С другой стороны, когда значение whRatio меньше чем 1, значение offsetY может быть установлено так, чтобы быть больше, чем значение offsetX. Например, значение offsetX может быть установлено равным 0, и значение offsetY может быть установлено равным 1.[304] When the wide-angle intra prediction mode is not used, the sum of nTbW and nTbH can be set as refW and refH. Accordingly, with the exception of the upper left reference sample, a non-adjacent reference sample at distance i from the current block may include up to (nTbW+nTbH+offsetX[i]) upper reference samples and up to (nTbW+nTbH+offsetY[i]) left reference samples. That is, a non-contiguous reference sample at distance i from the current block may include up to (2nTbW+2nTbH+offsetX[i]+offsetY[i]+1) reference samples. For example, when the value of whRatio is greater than 1, the value of offsetX may be set to be greater than the value of offsetY. For example, the offsetX value may be set to 1, and the offsetY value may be set to 0. On the other hand, when the whRatio value is less than 1, the offsetY value may be set to be greater than the offsetX value. For example, the offsetX value may be set to 0 and the offsetY value may be set to 1.
[305] Так как используются широкоугольные режимы внутреннего предсказания в дополнение к существующим режимам внутреннего предсказания, увеличиваются ресурсы, требуемые для кодирования широкоугольных режимов внутреннего предсказания, и, таким образом, эффективность кодирования может быть снижена. Соответственно, эффективность кодирования может быть улучшена за счет кодирования заменяющих режимов внутреннего предсказания для широкоугольных режимов внутреннего предсказания вместо кодирования широкоугольных режимов внутреннего предсказания как таковых.[305] Since wide-angle intra prediction modes are used in addition to the existing intra prediction modes, the resources required to encode the wide-angle intra prediction modes increase, and thus the coding efficiency can be reduced. Accordingly, coding efficiency can be improved by encoding substitute intra prediction modes for wide-angle intra prediction modes instead of encoding wide-angle intra prediction modes per se.
[306] Например, когда текущий блок кодируется с использованием 67-го широкоугольного режима внутреннего предсказания, 2-й режим внутреннего предсказания, который представляет собой заменяющий режим внутреннего предсказания 67-го широкоугольного режима внутреннего предсказания, может быть закодирован с использованием режима внутреннего предсказания текущего блока. Кроме того, когда текущий блок кодируется с использованием -1-го широкоугольного режима внутреннего предсказания, 66-й режим внутреннего предсказания, который представляет собой заменяющий режим внутреннего предсказания -1-го широкоугольного режима внутреннего предсказания, может быть закодирован с использованием режима внутреннего предсказания текущего блока.[306] For example, when the current block is encoded using the 67th wide-angle intra prediction mode, the 2nd intra-prediction mode, which is the replacement intra-prediction mode of the 67th wide-angle intra prediction mode, may be encoded using the intra prediction mode of the current block. In addition, when the current block is encoded using the -1st wide-angle intra prediction mode, the 66th intra prediction mode, which is a substitute intra prediction mode of the -1st wide-angle intra prediction mode, can be encoded using the intra prediction mode of the current block.
[307] Декодер может декодировать режим внутреннего предсказания текущего блока и определять, принадлежит ли декодированный режим внутреннего предсказания к диапазону преобразования. Когда декодированный режим внутреннего предсказания представляет собой широкоугольный заменяющий режим внутреннего предсказания, режим внутреннего предсказания может быть преобразован в широкоугольный режим внутреннего предсказания.[307] The decoder may decode the intra prediction mode of the current block and determine whether the decoded intra prediction mode belongs to the transform range. When the decoded intra prediction mode is the wide-angle intra-prediction substitute mode, the intra prediction mode can be converted to the wide-angle intra prediction mode.
[308] Альтернативно, когда текущий блок кодируется с использованием широкоугольного режима внутреннего предсказания, широкоугольный режим внутреннего предсказания может быть закодирован как есть.[308] Alternatively, when the current block is encoded using the intra-prediction wide-angle mode, the intra-prediction wide-angle mode may be encoded as is.
[309] Кодирование режима внутреннего предсказания может быть выполнено на основании списка MPM, описанного выше. В частности, когда соседний блок кодируется с использованием широкоугольного режима внутреннего предсказания, MPM может быть установлен на основании широкоугольного заменяющего режима внутреннего предсказания, соответствующего широкоугольному режиму внутреннего предсказания. Например, когда соседний блок кодируется в широкоугольном режиме внутреннего предсказания, переменная candIntraPredModeX (X представляет собой A или B) может быть установлена равной широкоугольному заменяющему режиму внутреннего предсказания.[309] Intra prediction mode encoding may be performed based on the MPM list described above. Specifically, when a neighboring block is encoded using the wide-angle intra prediction mode, the MPM may be set based on the wide-angle intra-prediction replacement mode corresponding to the wide-angle intra prediction mode. For example, when a neighboring block is encoded in a wide-angle intra prediction mode, the variable candIntraPredModeX (X is A or B) may be set equal to the wide-angle intra prediction substitute mode.
[310] Альтернативно MPM может быть установлен на основании широкоугольного режима внутреннего предсказания соседнего блока. Например, когда соседний блок кодируется в широкоугольном режиме внутреннего предсказания, переменная candIntraPredModeX может быть установлена равной широкоугольному режиму внутреннего предсказания.[310] Alternatively, the MPM may be set based on the wide-angle mode of the adjacent block intra prediction. For example, when a neighboring block is encoded in the wide-angle intra prediction mode, the variable candIntraPredModeX may be set equal to the wide-angle intra prediction mode.
[311] MPM может быть получен на основании того, является ли линия опорных отсчетов текущего блока несмежной линией опорных отсчетов, или того, применяется ли способ кодирования с внутренним предсказанием с несколькими линиями для выбора одной из множества линий опорных отсчетов. Например, когда линия опорных отсчетов текущего блока представляет собой несмежную линию опорных отсчетов, и режим внутреннего предсказания соседнего блока, смежного с текущим блоком, представляет собой широкоугольный режим внутреннего предсказания, режим по умолчанию может быть установлен как MPM текущего блока.[311] The MPM may be obtained based on whether the reference sample line of the current block is a non-adjacent reference sample line, or whether the multi-line intra prediction coding method is applied to select one of the plurality of reference sample lines. For example, when the reference sample line of the current block is a non-adjacent reference sample line, and the intra prediction mode of an adjacent block adjacent to the current block is the wide-angle intra prediction mode, the default mode may be set to MPM of the current block.
[312] Например, когда candIntraPredModeA, полученный на основании режима внутреннего предсказания левого соседнего блока, и candIntraPredModeB, полученный на основании режима внутреннего предсказания верхнего соседнего блока, являются одинаковыми, и candIntraPredModeA представляет собой планарный режим или режим DC, MPM могут быть получены следующим образом с учетом того, равен ли индекс линии опорных отсчетов текущего блока 0.[312] For example, when candIntraPredModeA obtained based on the intra prediction mode of the left neighboring block and candIntraPredModeB obtained based on the intra prediction mode of the upper neighboring block are the same, and candIntraPredModeA is a planar mode or a DC mode, MPMs can be obtained as follows considering whether the reference sample line index of the current block is 0.
[313] MPM[0]=(IntraLumaRefLineIdx=0) ? Intra_Planar: INTRA_ANGULAR 50[313] MPM[0]=(IntraLumaRefLineIdx=0) ? Intra_Planar: INTRA_ANGULAR 50
[314] MPM[1]=(IntraLumaRefLineIdx=0) ? Intra_DC: INTRA_ANGULAR 18[314] MPM[1]=(IntraLumaRefLineIdx=0) ? Intra_DC: INTRA_ANGULAR 18
[315] MPM[2]=INTRA_ANGULAR 2[315] MPM[2]=INTRA_ANGULAR 2
[316] То есть, когда индекс линии опорных отсчетов текущего блока равен 0, планарный режим и режим DC устанавливаются как MPM, тогда как, когда индекс линии опорных отсчетов текущего блока не равен 0, режим внутреннего предсказания в вертикальном направлении (INTRA_ANGULAR 50) и режим внутреннего предсказания в горизонтальном направлении (INTRA_ANGULAR 18) могут быть установлены как MPM.[316] That is, when the reference sample line index of the current block is 0, the planar mode and the DC mode are set to MPM, while when the reference sample line index of the current block is not 0, the vertical direction intra prediction mode (INTRA_ANGULAR 50) and the horizontal direction intra prediction mode (INTRA_ANGULAR 18) can be set to MPM.
[317] Когда индекс линии опорных отсчетов текущего блока не равен 0, и candIntraPredModeA и candIntraPredModeB являются одинаковыми, и candIntraPredModeA представляет собой широкоугольный режим внутреннего предсказания, MPM могут быть получены следующим образом.[317] When the reference sample line index of the current block is not equal to 0, and candIntraPredModeA and candIntraPredModeB are the same, and candIntraPredModeA is a wide-angle intra prediction mode, MPMs can be obtained as follows.
[318] MPM[0]=INTRA_ANGULAR2[318] MPM[0]=INTRA_ANGULAR2
[319] MPM[1]=INTRA_ANGULAR18[319] MPM[1]=INTRA_ANGULAR18
[320] MPM[2]=INTRA_ANGULAR50[320] MPM[2]=INTRA_ANGULAR50
[321] Альтернативно MPM могут быть получены следующим образом.[321] Alternatively, MPMs can be obtained as follows.
[322] MPM[0]=INTRA_ANGULAR50[322] MPM[0]=INTRA_ANGULAR50
[323] MPM[1]=INTRA_ANGULAR18[323] MPM[1]=INTRA_ANGULAR18
[324] MPM[2]=INTRA_ANGULAR2[324] MPM[2]=INTRA_ANGULAR2
[325] То есть, когда индекс линии опорных отсчетов текущего блока не равен 0, широкоугольный режим внутреннего предсказания может не быть установлен как MPM.[325] That is, when the reference sample line index of the current block is not equal to 0, the wide-angle intra prediction mode may not be set to MPM.
[326] Когда candIntraPredModeA и candIntraPredModeB являются одинаковыми, и candIntraPredModeA представляет собой режим внутреннего предсказания, основанный на информации об углах, MPM могут быть получены следующим образом.[326] When candIntraPredModeA and candIntraPredModeB are the same, and candIntraPredModeA is an intra prediction mode based on angle information, MPMs can be obtained as follows.
[327] MPM[0]=candIntraPredModeA[327] MPM[0]=candIntraPredModeA
[328] MPM[1]=2+((candIntraPredModeA+61) % 64)[328] MPM[1]=2+((candIntraPredModeA+61) % 64)
[329] MPM[2]=2+((candIntraPredModeA - 1) % 64)[329] MPM[2]=2+((candIntraPredModeA - 1) % 64)
[330] Когда индекс линии опорных отсчетов текущего блока равен 0, и candIntraPredModeA и candIntraPredModeB отличаются, MPM[0] и MPM[1] могут быть установлены равными candIntraPredModeA и candIntraPredModeB соответственно. MPM[2] может быть установлен равным любому из планарного режима, режима DC или вертикального режима, который не является таким же, как режимы MPM[0] и MPM[1].[330] When the reference sample line index of the current block is 0 and candIntraPredModeA and candIntraPredModeB are different, MPM[0] and MPM[1] may be set to candIntraPredModeA and candIntraPredModeB, respectively. MPM[2] can be set to any of planar mode, DC mode, or vertical mode, which is not the same as MPM[0] and MPM[1] modes.
[331] Когда индекс линии опорных отсчетов текущего блока не равен 0, и один из candIntraPredModeA и candIntraPredModeB представляет собой планарный режим, а другой представляет собой режим DC, MPM могут быть получены следующим образом.[331] When the reference sample line index of the current block is not equal to 0, and one of candIntraPredModeA and candIntraPredModeB is planar mode and the other is DC mode, MPMs can be obtained as follows.
[332] MPM[0]=INTRA_ANGULAR2[332] MPM[0]=INTRA_ANGULAR2
[333] MPM[1]=INTRA_ANGULAR18[333] MPM[1]=INTRA_ANGULAR18
[334] MPM[2]=INTRA_ANGULAR50[334] MPM[2]=INTRA_ANGULAR50
[335] Когда индекс линии опорных отсчетов текущего блока не равен 0, и как candIntraPredModeA, так и candIntraPredModeB представляют собой широкоугольные режимы внутреннего предсказания, MPM могут быть получены следующим образом.[335] When the reference sample line index of the current block is not equal to 0, and both candIntraPredModeA and candIntraPredModeB are wide-angle intra prediction modes, MPMs can be obtained as follows.
[336] MPM[0]=INTRA_ANGULAR2[336] MPM[0]=INTRA_ANGULAR2
[337] MPM[1]=INTRA_ANGULAR18[337] MPM[1]=INTRA_ANGULAR18
[338] MPM[2]=INTRA_ANGULAR50[338] MPM[2]=INTRA_ANGULAR50
[339] Когда индекс линии опорных отсчетов текущего блока не равен 0, и любой из candIntraPredModeA и candIntraPredModeB представляет собой широкоугольный режим внутреннего предсказания, любой, который не представляет собой широкоугольный режим внутреннего предсказания, из candIntrapredModeA и candIntraPredModeB может быть установлен как MPM[0], и режимы внутреннего предсказания, подобные MPM[0], могут быть установлены как MPM[1] и MPM[2]. Например, когда candIntraPredModeA не представляет собой широкоугольный режим внутреннего предсказания, и candIntraPredModeB представляет собой широкоугольный режим внутреннего предсказания, MPM могут быть получены следующим образом.[339] When the reference sample line index of the current block is not equal to 0, and any of candIntraPredModeA and candIntraPredModeB is a wide-angle intra prediction mode, any that is not a wide-angle intra prediction mode of candIntraPredModeA and candIntraPredModeB can be set to MPM[0], and intra prediction modes like MPM[0] can be set to MPM[1] and MPM[2 ]. For example, when candIntraPredModeA is not a wide-angle intra prediction mode and candIntraPredModeB is a wide-angle intra prediction mode, the MPMs can be obtained as follows.
[340] MPM[0]=candIntraPredModeA[340] MPM[0]=candIntraPredModeA
[341] MPM[1]=2+((candIntraPredModeA+61) % 64)[341] MPM[1]=2+((candIntraPredModeA+61) % 64)
[342] MPM[2]=2+((candIntraPredModeA - 1) % 64)[342] MPM[2]=2+((candIntraPredModeA - 1) % 64)
[343] С другой стороны, когда candIntraPredModeA представляет собой широкоугольный режим внутреннего предсказания, и candIntraPredModeB не представляет собой широкоугольный режим внутреннего предсказания, MPM могут быть получены следующим образом.[343] On the other hand, when candIntraPredModeA is a wide-angle intra prediction mode and candIntraPredModeB is not a wide-angle intra prediction mode, the MPMs can be obtained as follows.
[344] MPM[0]=candIntraPredModeB[344] MPM[0]=candIntraPredModeB
[345] MPM[1]=2+((candIntraPredModeB+61) % 64)[345] MPM[1]=2+((candIntraPredModeB+61) % 64)
[346] MPM[2]=2+((candIntraPredModeB - 1) % 64)[346] MPM[2]=2+((candIntraPredModeB - 1) % 64)
[347] Когда индекс линии опорных отсчетов текущего блока не равен 0, и любой из candIntraPredModeA и candIntraPredModeB представляет собой планарный режим или режим DC, а другой не представляет собой широкоугольный режим внутреннего предсказания, любой, который не представляет собой широкоугольный режим внутреннего предсказания, из candIntrapredModeA и candIntraPredModeB может быть установлен как MPM[0], и режимы внутреннего предсказания, подобные MPM[0], могут быть установлены как MPM[1] и MPM[2]. Например, когда candIntraPredModeA не представляет собой широкоугольный режим внутреннего предсказания, и candIntraPredModeB представляет собой планарный режим или режим DC, MPM могут быть получены следующим образом.[347] When the reference sample line index of the current block is not equal to 0, and either of candIntraPredModeA and candIntraPredModeB is a planar mode or a DC mode, and the other is not a wide-angle intra prediction mode, any that is not a wide-angle intra prediction mode of candIntraPredModeA and candIntraPredModeB may be set to MPM[0], and intra prediction modes like MPM[0] may be set to MPM[1] and MPM[2]. For example, when candIntraPredModeA is not a wide-angle intra prediction mode and candIntraPredModeB is a planar mode or a DC mode, the MPMs can be obtained as follows.
[348] MPM[0]=candIntraPredModeA[348] MPM[0]=candIntraPredModeA
[349] MPM[1]=2+((candIntraPredModeA+61) % 64)[349] MPM[1]=2+((candIntraPredModeA+61) % 64)
[350] MPM[2]=2+((candIntraPredModeA - 1) % 64)[350] MPM[2]=2+((candIntraPredModeA - 1) % 64)
[351] С другой стороны, когда candIntraPredModeA представляет собой планарный режим или режим DC, и candIntraPredModeB не представляет собой широкоугольный режим внутреннего предсказания, MPM могут быть получены следующим образом.[351] On the other hand, when candIntraPredModeA is a planar mode or DC mode, and candIntraPredModeB is not a wide-angle intra prediction mode, the MPMs can be obtained as follows.
[352] MPM[0]=candIntraPredModeB[352] MPM[0]=candIntraPredModeB
[353] MPM[1]=2+((candIntraPredModeB+61) % 64)[353] MPM[1]=2+((candIntraPredModeB+61) % 64)
[354] MPM[2]=2+((candIntraPredModeB - 1) % 64)[354] MPM[2]=2+((candIntraPredModeB - 1) % 64)
[355] Когда индекс линии опорных отсчетов текущего блока не равен 0, и как candIntraPredModeA, так и candIntraPredModeB не представляют собой широкоугольные режимы внутреннего предсказания, candIntraPredModeA и candIntraPredModeB могут быть установлены как MPM[0] и MPM[1] соответственно. Любой режим, который не перекрывается с MPM[0] и MPM[1], из режима внутреннего предсказания в вертикальном направлении (INTRA_ANGULAR50), режима внутреннего предсказания в горизонтальном направлении (INTRA_ANGULAR18) и режима внутреннего предсказания в диагональном направлении вниз и влево (INTRA_ANGULAR2) может быть установлен как MPM[2].[355] When the reference sample line index of the current block is not equal to 0, and both candIntraPredModeA and candIntraPredModeB are not wide-angle intra prediction modes, candIntraPredModeA and candIntraPredModeB may be set to MPM[0] and MPM[1], respectively. Any mode that does not overlap with MPM[0] and MPM[1], from the intra vertical direction prediction mode (INTRA_ANGULAR50), the horizontal intra prediction mode (INTRA_ANGULAR18), and the downward and left diagonal intra prediction mode (INTRA_ANGULAR2) can be set as MPM[2].
[356] Блок кодирования или блок преобразования может быть разбит на множество подблоков (или подразделов). Когда блок кодирования или блок преобразования разбит на множество подблоков, предсказание, преобразование и квантование могут быть выполнены в отношении каждого подблока. Разбиение блока кодирования или блока преобразования на множество подблоков может быть определено как способ внутреннего кодирования с подразбиением.[356] An encoding block or a transform block may be divided into a plurality of subblocks (or subsections). When a coding block or a transform block is partitioned into a plurality of subblocks, prediction, transformation, and quantization can be performed on each subblock. Splitting a coding block or a transform block into a plurality of sub-blocks may be defined as a sub-partitioning intra-coding method.
[357] Информация, указывающая то, применяется ли способ внутреннего кодирования с подразбиением, может быть передана посредством битового потока. Информация может представлять собой 1-битный флаг. Например, элемент синтаксиса «intra_subpartitions_mode_flag», указывающий то, разбит ли блок кодирования или блок преобразования на множество подблоков, может быть передан посредством битового потока.[357] Information indicating whether an intra subdivision coding method is applied may be transmitted by a bitstream. The information may be a 1-bit flag. For example, the "intra_subpartitions_mode_flag" syntax element indicating whether a coding block or a transformation block is divided into a plurality of sub-blocks may be transmitted via a bitstream.
[358] Альтернативно то, применяется ли способ внутреннего кодирования с подразбиением, может быть определено на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания блока кодирования или блока преобразования. Например, когда режим внутреннего предсказания блока кодирования представляет собой режим внутреннего предсказания, не основанный на информации об углах (например, планарный режим или режим DC) или предварительно заданный режим внутреннего предсказания, основанный на информации об углах (например, режим внутреннего предсказания в горизонтальном направлении, режим внутреннего предсказания в вертикальном направлении или режим внутреннего предсказания в диагональном направлении), способ внутреннего кодирования с подразбиением может не применяться. Альтернативно может быть установлено не использовать способ внутреннего кодирования с подразбиением, когда размер блока кодирования меньше, чем пороговое значение.[358] Alternatively, whether the intra subdivision coding method is applied may be determined based on at least one of the size, shape, and intra prediction mode of the coding block or transform block. For example, when the intra prediction mode of a coding block is an intra prediction mode not based on angle information (e.g., planar mode or DC mode) or a predetermined intra prediction mode based on angle information (e.g., horizontal direction intra prediction mode, vertical direction intra prediction mode, or diagonal direction intra prediction mode), the subdivision intra coding method may not be applied. Alternatively, it may be set not to use the subdivision intra coding method when the coding block size is less than a threshold value.
[359] Альтернативно, когда внутреннее предсказание выполняется в отношении подблока на основании режима внутреннего предсказания блока кодирования, тогда то, следует ли применять способ внутреннего кодирования с подразбиением, может быть определено на основании того, должен ли восстановленный отсчет, включенный в соседний подблок, использоваться как опорный отсчет, когда внутреннее предсказание выполняется в отношении подблока. Например, может быть установлено не использовать способ внутреннего кодирования с подразбиением, когда режим внутреннего предсказания блока кодирования представляет собой режим внутреннего предсказания в диагональном направлении или широкоугольный режим внутреннего предсказания, и соседний подблок может не использоваться как опорный отсчет, когда внутреннее предсказание выполняется в отношении подблока на основании режима внутреннего предсказания.[359] Alternatively, when intra prediction is performed on a subblock based on the intra prediction mode of a coding block, then whether the subdivision intra coding method should be applied may be determined based on whether a reconstructed sample included in an adjacent subblock should be used as a reference sample when intra prediction is performed on the subblock. For example, it may be set not to use the subdivision intra coding method when the intra prediction mode of the coding block is the diagonal direction intra prediction mode or the wide-angle intra prediction mode, and the neighboring subblock may not be used as a reference when intra prediction is performed on the subblock based on the intra prediction mode.
[360] Альтернативно может быть установлено не использовать способ внутреннего кодирования с подразбиением, когда соотношение высоты и ширины блока кодирования больше, чем пороговое значение, или меньше, чем пороговое значение. Альтернативно, когда по меньшей мере одно из высоты и ширины блока кодирования меньше, чем пороговое значение, или равняется ему, способ внутреннего кодирования с подразбиением может не использоваться. Например, когда как высота, так и ширина блока кодирования меньше, чем пороговое значение, или равняются ему, способ внутреннего кодирования с подразбиением может не использоваться. Пороговое значение может представлять собой значение, предварительно заданное в кодере и декодере. Альтернативно информация для определения порогового значения может быть передана посредством битового потока.[360] Alternatively, it may be set not to use the subdivision intra-coding method when the height-to-width ratio of the coding block is greater than a threshold value or less than a threshold value. Alternatively, when at least one of the height and width of the coding block is less than or equal to the threshold value, the intra subdivision coding method may not be used. For example, when both the height and the width of the coding block are less than or equal to the threshold value, the subdivision intra coding method may not be used. The threshold value may be a value predefined in the encoder and decoder. Alternatively, the information for determining the threshold value may be transmitted via a bitstream.
[361] Альтернативно то, следует ли передавать флаг, указывающий то, следует ли применять способ внутреннего кодирования с подразбиением, может быть определено на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания блока кодирования или блока преобразования. Например, только когда как высота, так и ширина блока кодирования меньше, чем пороговое значение, или равняются ему, и/или размер блока кодирования больше, чем пороговое значение, или равняется ему, флаг, указывающий то, следует ли применять способ внутреннего кодирования с подразбиением, может быть кодирован и передан. Когда флаг, указывающий то, следует ли применять способ внутреннего кодирования с подразбиением, не кодируется, способ внутреннего кодирования с подразбиением может не применяться.[361] Alternatively, whether a flag indicating whether to apply the intra subdivision coding method should be transmitted may be determined based on at least one of the size, shape, and intra prediction mode of the coding block or transform block. For example, only when both the height and width of the coding block is less than or equal to the threshold value and/or the size of the coding block is greater than or equal to the threshold value, a flag indicating whether to apply the subdivision intra coding method may be encoded and transmitted. When a flag indicating whether or not to apply the intra subdivision coding method is not encoded, the intra subdivision coding method may not be applied.
[362] Когда применяется способ внутреннего кодирования с подразбиением, может быть определен тип разбиения блока кодирования или блока преобразования. В данном случае тип разбиения указывает направление разбиения блока кодирования или блока преобразования. Например, разбиение в вертикальном направлении может означать разбиение блока кодирования или блока преобразования с использованием по меньшей мере одной вертикальной линии, и разбиение в горизонтальном направлении может означать разбиение блока кодирования или блока преобразования с использованием по меньшей мере одной горизонтальной линии.[362] When the subdivision intra coding method is applied, the partition type of the coding block or the transform block can be determined. In this case, the split type indicates the splitting direction of the coding block or transform block. For example, splitting in the vertical direction may mean splitting a coding block or a transform block using at least one vertical line, and splitting in a horizontal direction may mean splitting a coding block or a transform block using at least one horizontal line.
[363] На фиг.16 представлен вид, показывающий пример разбиения в вертикальном направлении и разбиения в горизонтальном направлении.[363] Fig. 16 is a view showing an example of splitting in the vertical direction and splitting in the horizontal direction.
[364] На фиг.16 (a) показан пример, в котором блок кодирования разбит на два подблока, и на фиг.16 (b) показан пример, в котором блок кодирования разбит на четыре подблока.[364] Fig. 16(a) shows an example in which the coding block is divided into two subblocks, and Fig. 16(b) shows an example in which the coding block is divided into four subblocks.
[365] Информация для определения типа разбиения блока кодирования или блока преобразования может быть передана посредством битового потока. Например, может быть передана информация, указывающая то, применяется ли разбиение в вертикальном направлении или разбиение в горизонтальном направлении к блоку кодирования или блоку преобразования. Информация может представлять собой intra_subpart_type_flag 1-битного флага. Когда значение флага равно 1, это указывает, что блок кодирования или блок преобразования разбит в горизонтальном направлении, а когда значение флага равно 0, это указывает, что блок кодирования или блок преобразования разбит в вертикальном направлении.[365] Information for determining the split type of a coding block or a transform block may be transmitted via a bitstream. For example, information indicating whether splitting in the vertical direction or splitting in the horizontal direction is applied to a coding block or a transform block may be transmitted. The information may be an intra_subpart_type_flag of a 1-bit flag. When the flag value is 1, it indicates that the coding block or transform block is split in the horizontal direction, and when the flag value is 0, it indicates that the coding block or transform block is split in the vertical direction.
[366] Альтернативно тип разбиения блока кодирования или блока преобразования может быть определен на основании размера, формы или режима внутреннего предсказания блока кодирования или блока преобразования. Например, тип разбиения блока кодирования может быть определен на основании соотношения ширины и высоты блока кодирования. Например, когда значение whRatio, указывающее соотношение высоты и ширины блока кодирования, больше, чем первое пороговое значение, или равняется ему, разбиение в вертикальном направлении может быть применено к блоку кодирования. В ином случае разбиение в горизонтальном направлении может быть применено к блоку кодирования.[366] Alternatively, the partition type of the coding block or transform block may be determined based on the size, shape, or intra prediction mode of the coding block or transform block. For example, the partition type of the coding block may be determined based on the ratio of the width and height of the coding block. For example, when the whRatio value indicating the ratio of the height and width of the coding block is greater than or equal to the first threshold value, splitting in the vertical direction may be applied to the coding block. Otherwise, splitting in the horizontal direction may be applied to the coding block.
[367] На фиг.17 представлен вид, показывающий пример определения типа разбиения блока кодирования.[367] FIG. 17 is a view showing an example of determining a splitting type of a coding block.
[368] Для удобства объяснения предполагается, что первое пороговое значение равняется 2. В примере, показанном на фиг.17 (a), whRatio блока кодирования равняется 1, что меньше, чем первое пороговое значение. Соответственно, кодирование информации, указывающей тип разбиения блока кодирования, может быть пропущено, и разбиение в горизонтальном направлении может быть применено к блоку кодирования.[368] For convenience of explanation, the first threshold value is assumed to be 2. In the example shown in FIG. 17(a), the coding block whRatio is 1, which is less than the first threshold value. Accordingly, encoding of information indicating the type of partitioning of the coding block can be skipped, and partitioning in the horizontal direction can be applied to the coding block.
[369] В примере, показанном на фиг.17 (b), whRatio блока кодирования равняется 2, что равняется первому пороговому значению. Соответственно, кодирование информации, указывающей тип разбиения блока кодирования, может быть пропущено, и разбиение в вертикальном направлении может быть применено к блоку кодирования.[369] In the example shown in FIG. 17(b), the whRatio of the coding block is 2, which is equal to the first threshold value. Accordingly, the encoding of information indicating the type of partitioning of the coding block can be skipped, and partitioning in the vertical direction can be applied to the coding block.
[370] Тип разбиения блока кодирования может быть определен с использованием второго порогового значения, имеющего знак, противоположный знаку первого порогового значения. Например, когда значение whRatio меньше, чем второе пороговое значение, или равняется ему, разбиение в горизонтальном направлении может быть применено к блоку кодирования, а в ином случае разбиение в вертикальном направлении может быть применено к блоку кодирования. Абсолютные значения первого порогового значения и второго порогового значения являются одинаковыми, а их знаки могут отличаться. Например, когда первое пороговое значение представляет собой N (в данном случае N представляет собой целое, такое как 1, 2, 4 или т.п.), второе пороговое значение может представлять собой -N.[370] The split type of the coding block may be determined using a second threshold having the opposite sign of the first threshold. For example, when the value of whRatio is less than or equal to the second threshold value, splitting in the horizontal direction may be applied to the coding block, and otherwise splitting in the vertical direction may be applied to the coding block. The absolute values of the first threshold value and the second threshold value are the same, and their signs may differ. For example, when the first threshold is N (in this case, N is an integer such as 1, 2, 4, or the like), the second threshold may be -N.
[371] На фиг.18 представлен вид, показывающий пример определения типа разбиения блока кодирования.[371] Fig. 18 is a view showing an example of determining a splitting type of a coding block.
[372] Для удобства объяснения предполагается, что второе пороговое значение равняется -2. В примере, показанном на фиг.18 (a), whRatio блока кодирования равняется -1, что больше, чем второе пороговое значение. Соответственно, кодирование информации, указывающей тип разбиения блока кодирования, может быть пропущено, и разбиение в вертикальном направлении может быть применено к блоку кодирования.[372] For convenience of explanation, the second threshold is assumed to be -2. In the example shown in FIG. 18(a), the coding block whRatio is -1, which is greater than the second threshold value. Accordingly, the encoding of information indicating the type of partitioning of the coding block can be skipped, and partitioning in the vertical direction can be applied to the coding block.
[373] В примере, показанном на фиг.18 (b), whRatio блока кодирования равняется -2, что равняется второму пороговому значению. Соответственно, кодирование информации, указывающей тип разбиения блока кодирования, может быть пропущено, и разбиение в горизонтальном направлении может быть применено к блоку кодирования.[373] In the example shown in FIG. 18(b), the whRatio of the coding block is -2, which is equal to the second threshold value. Accordingly, encoding of information indicating the type of partitioning of the coding block can be skipped, and partitioning in the horizontal direction can be applied to the coding block.
[374] Альтернативно тип разбиения блока кодирования может быть определен на основании первого порогового значения и второго порогового значения. Например, когда значение whRatio больше, чем первое пороговое значение, или равняется ему, разбиение в горизонтальном направлении может быть применено к блоку кодирования, а когда значение whRatio меньше, чем второе пороговое значение, или равняется ему, разбиение в вертикальном направлении может быть применено к блоку кодирования. Когда значение whRatio находится между первым пороговым значением и вторым пороговым значением, тип разбиения текущего блока может быть определен путем анализа информации из битового потока.[374] Alternatively, the splitting type of the coding block may be determined based on the first threshold and the second threshold. For example, when the value of whRatio is greater than or equal to the first threshold, splitting in the horizontal direction may be applied to the coding block, and when the value of whRatio is less than or equal to the second threshold, splitting in the vertical direction may be applied to the coding block. When the value of whRatio is between the first threshold value and the second threshold value, the partition type of the current block can be determined by parsing information from the bitstream.
[375] Первое пороговое значение и второе пороговое значение могут быть предварительно заданы в кодере и декодере. Альтернативно первое пороговое значение и второе пороговое значение могут быть определены для каждой последовательности, изображения или слайса.[375] The first threshold and the second threshold may be predefined in the encoder and decoder. Alternatively, the first threshold and the second threshold may be determined for each sequence, picture, or slice.
[376] Альтернативно тип разбиения может быть определен на основании размера блока кодирования или блока преобразования. Например, когда размер блока кодирования составляет N×n, может быть применено разбиение в вертикальном направлении, а когда размер блока кодирования составляет n×N, может быть применено разбиение в горизонтальном направлении. В данном случае n может представлять собой натуральное число, которое меньше, чем N. N и/или n могут представлять собой значения, предварительно заданные в кодере и декодере. Альтернативно информация для определения N и/или n может быть передана посредством битового потока. Например, N может равняться 32, 64, 128 или 256. Соответственно, когда размер блока кодирования составляет 128×n (где n представляет собой натуральное число, такое как 16, 32 или 64), может быть применено разбиение в вертикальном направлении, а когда размер блока кодирования составляет n×128, может быть применено разбиение в горизонтальном направлении.[376] Alternatively, the partition type may be determined based on the size of the coding block or transform block. For example, when the coding block size is N×n, splitting in the vertical direction can be applied, and when the coding block size is n×N, splitting in the horizontal direction can be applied. In this case, n may be a natural number that is less than N. N and/or n may be values predefined in the encoder and decoder. Alternatively, information for determining N and/or n may be transmitted via a bitstream. For example, N may be 32, 64, 128, or 256. Accordingly, when the coding block size is 128×n (where n is a natural number such as 16, 32, or 64), splitting in the vertical direction can be applied, and when the coding block size is n×128, splitting in the horizontal direction can be applied.
[377] Альтернативно тип разбиения блока кодирования или блока преобразования может быть определен на основании режима внутреннего предсказания блока кодирования или блока преобразования. Например, когда режим внутреннего предсказания блока кодирования имеет горизонтальное направление или направление, подобное горизонтальному направлению, разбиение в вертикальном направлении может быть применено к блоку кодирования. В данном случае режим внутреннего предсказания в направлении, подобном горизонтальному направлению, указывает режим внутреннего предсказания, значение индексной разницы от режима внутреннего предсказания в горизонтальном направлении (например, INTRA_ANGULAR18, как показано на фиг.10 (b)) которого меньше, чем пороговое значение, или равняется ему (например, INTRA_ANGULAR18 (N). С другой стороны, когда режим внутреннего предсказания блока кодирования имеет вертикальное направление или направление, подобное вертикальному направлению, разбиение в горизонтальном направлении может быть применено к блоку кодирования. В данном случае режим внутреннего предсказания в направлении, подобном вертикальному направлению, указывает режим внутреннего предсказания, значение индексной разницы от режима внутреннего предсказания в вертикальном направлении (например, INTRA_ANGULAR50, как показано на фиг.10 (b)) которого меньше, чем пороговое значение, или равняется ему (например, INTRA_ANGULAR50 (N). В данном случае пороговое значение N может представлять собой значение, предварительно заданное в кодере и декодере. Альтернативно информация для определения порогового значения N может быть передана на уровень последовательности, изображения или слайса.[377] Alternatively, the partition type of the coding block or transform block may be determined based on the intra prediction mode of the coding block or transform block. For example, when the intra prediction mode of a coding block has a horizontal direction or a direction similar to the horizontal direction, splitting in the vertical direction may be applied to the coding block. Here, the intra prediction mode in the direction similar to the horizontal direction indicates an intra prediction mode whose index difference value from the intra prediction mode in the horizontal direction (for example, INTRA_ANGULAR18 as shown in FIG. 10(b)) is less than or equal to the threshold value (for example, INTRA_ANGULAR18(N). On the other hand, when the intra prediction mode of a coding block has a vertical direction or a direction similar to the vertical direction, splitting in the horizontal direction can be applied to the block In this case, the intra prediction mode in a direction like the vertical direction indicates an intra prediction mode whose index difference value from the intra prediction mode in the vertical direction (for example, INTRA_ANGULAR50, as shown in Fig. 10(b)) is less than or equal to the threshold value (for example, INTRA_ANGULAR50(N). Here, the threshold value N may be a value preset in the encoder and decoder. Alternatively, the information for determining the threshold N may be passed to the sequence, image, or slice level.
[378] На фиг.19 представлен вид, показывающий пример, в котором тип разбиения блока кодирования определяют на основании режима внутреннего предсказания блока кодирования.[378] FIG. 19 is a view showing an example in which a split type of a coding block is determined based on the intra prediction mode of the coding block.
[379] Как показано в примере на фиг.19 (a), когда режим внутреннего предсказания блока кодирования имеет направление, подобное вертикальному направлению, разбиение в горизонтальном направлении может быть применено к блоку кодирования.[379] As shown in the example of FIG. 19(a), when the intra prediction mode of a coding block has a direction similar to the vertical direction, splitting in the horizontal direction can be applied to the coding block.
[380] С другой стороны, как показано в примере на фиг.19 (b), когда режим внутреннего предсказания блока кодирования имеет направление, подобное горизонтальному направлению, разбиение в вертикальном направлении может быть применено к блоку кодирования.[380] On the other hand, as shown in the example of FIG. 19(b), when the intra prediction mode of a coding block has a direction similar to the horizontal direction, splitting in the vertical direction can be applied to the coding block.
[381] В отличие от примера, описанного выше, когда режим внутреннего предсказания блока кодирования имеет горизонтальное направление или направление, подобное горизонтальному направлению, применяется разбиение в горизонтальном направлении, а когда режим внутреннего предсказания блока кодирования имеет вертикальное направление или направление, подобное вертикальному направлению, может быть применено разбиение в вертикальном направлении.[381] Unlike the example described above, when the intra prediction mode of a coding block has a horizontal direction or a direction similar to the horizontal direction, splitting in the horizontal direction is applied, and when the intra prediction mode of the coding unit has a vertical direction or a direction similar to the vertical direction, splitting in the vertical direction can be applied.
[382] Когда применяется разбиение в вертикальном или горизонтальном направлении, тип разбиения блока кодирования или блока преобразования может быть определен на основании того, меньше ли по меньшей мере одна из ширины и высоты подблока, сгенерированного путем разбиения блока кодирования или блока преобразования, чем пороговое значение. В данном случае пороговое значение может представлять собой целое, такое как 2, 4 или 8.[382] When splitting is applied in the vertical or horizontal direction, the type of splitting of a coding block or a transform block can be determined based on whether at least one of the width and height of a subblock generated by splitting a coding block or a transform block is less than a threshold value. In this case, the threshold value may be an integer such as 2, 4, or 8.
[383] На фиг.20 представлен вид для описания схемы разбиения блока кодирования.[383] FIG. 20 is a view for describing a coding block partition scheme.
[384] Когда разбиение в горизонтальном направлении применяется к блоку кодирования размером 4×8, как показано на фиг.20 (a), блок кодирования разбивается на подблоки размером 2×8. В этом случае, поскольку ширина подблока меньше, чем пороговое значение, разбиение в горизонтальном направлении может не допускаться для блока кодирования. С другой стороны, когда разбиение в вертикальном направлении применяется к блоку кодирования размером 4×8, блок кодирования разбивается на подблоки размером 4×4. Поскольку как ширина, так и высота подблока равняются пороговому значению или больше него, разбиение в вертикальном направлении может быть использовано для блока кодирования. Поскольку только разбиение в вертикальном направлении допускается для блока кодирования, кодирование информации, указывающей тип разбиения для блока кодирования, может быть пропущено, и разбиение в вертикальном направлении может быть применено к блоку кодирования.[384] When splitting in the horizontal direction is applied to a 4x8 coding block as shown in FIG. 20(a), the coding block is divided into 2x8 subblocks. In this case, since the sub-block width is smaller than the threshold value, splitting in the horizontal direction may not be allowed for the coding block. On the other hand, when splitting in the vertical direction is applied to a 4x8 coding block, the coding block is split into 4x4 subblocks. Since both the width and the height of the sub-block are equal to or greater than the threshold value, splitting in the vertical direction can be used for the coding block. Since only splitting in the vertical direction is allowed for a coding block, encoding information indicating a splitting type for a coding block can be skipped, and splitting in the vertical direction can be applied to the coding block.
[385] Когда разбиение в вертикальном направлении применяется к блоку кодирования размером 8×4, как показано на фиг.20 (b), блок кодирования разбивается на подблоки размером 8×2. В этом случае, поскольку высота подблока меньше, чем пороговое значение, разбиение в вертикальном направлении может не допускаться для блока кодирования. С другой стороны, когда разбиение в горизонтальном направлении применяется к блоку кодирования размером 8×4, блок кодирования разбивается на подблоки размером 4×4. Поскольку как ширина, так и высота подблока равняются пороговому значению или больше него, разбиение в горизонтальном направлении может быть использовано для блока кодирования. Поскольку только разбиение в горизонтальном направлении допускается для блока кодирования, кодирование информации, указывающей тип разбиения для блока кодирования, может быть пропущено, и разбиение в вертикальном направлении может быть применено к блоку кодирования.[385] When splitting in the vertical direction is applied to an 8x4 coding block as shown in FIG. 20(b), the coding block is divided into 8x2 subblocks. In this case, since the sub-block height is smaller than the threshold value, splitting in the vertical direction may not be allowed for the coding block. On the other hand, when splitting in the horizontal direction is applied to an 8x4 coding block, the coding block is divided into 4x4 subblocks. Since both the width and the height of the sub-block are equal to or greater than the threshold value, splitting in the horizontal direction can be used for the coding block. Since only splitting in the horizontal direction is allowed for a coding block, encoding information indicating a splitting type for a coding block can be skipped, and splitting in the vertical direction can be applied to the coding block.
[386] Когда могут быть использованы как разбиение в вертикальном направлении, так и разбиение в горизонтальном направлении, тип разбиения блока кодирования может быть определен путем анализа информации, указывающей тип разбиения блока кодирования.[386] When both splitting in the vertical direction and splitting in the horizontal direction can be used, the type of splitting of the coding block can be determined by analyzing information indicating the type of splitting of the coding block.
[387] Количество подблоков может быть определено на основании по меньшей мере одного из размера и формы блока кодирования или блока преобразования. Например, когда любая из ширины и высоты блока кодирования равняется 8, а другая равняется 4, блок кодирования может быть разбит на два подблока. С другой стороны, когда как ширина, так и высота блока кодирования равняются 8 или больше, или любая из ширины и высоты блока кодирования больше чем 8, блок кодирования может быть разбит на 4 подблока. В итоге, когда блок кодирования имеет размер 4×4, блок кодирования может не быть разбит на подблоки. Когда блок кодирования имеет размер 4×8 или 8×4, блок кодирования может быть разбит на два подблока. В других случаях блок кодирования может быть разбит на четыре подблока.[387] The number of subblocks may be determined based on at least one of the size and shape of the coding block or the transform block. For example, when either of the coding block width and height is 8 and the other is 4, the coding block may be split into two sub-blocks. On the other hand, when both the width and height of the coding block are 8 or more, or either of the width and height of the coding block is greater than 8, the coding block may be divided into 4 sub-blocks. As a result, when a coding block has a size of 4×4, the coding block may not be sub-blocked. When the coding block has a size of 4x8 or 8x4, the coding block may be split into two sub-blocks. In other cases, the coding block may be divided into four sub-blocks.
[388] Альтернативно информация, указывающая размер, форму или количество подблоков, может быть передана посредством битового потока. Размер или форма подблоков могут быть определены с помощью информации, указывающей количество подблоков. Альтернативно количество подблоков может быть определено с помощью информации, указывающей размер или форму подблоков.[388] Alternatively, information indicating the size, shape, or number of sub-blocks may be transmitted via a bitstream. The size or shape of the sub-blocks may be determined with information indicating the number of sub-blocks. Alternatively, the number of sub-blocks may be determined with information indicating the size or shape of the sub-blocks.
[389] Когда применяется способ внутреннего кодирования с подразбиением, подблоки, сгенерированные путем разбиения блока кодирования или блока преобразования, могут использовать одинаковый режим внутреннего предсказания. Например, MPM для блока кодирования могут быть получены на основании режимов внутреннего предсказания соседних блоков, смежных с блоком кодирования, и режим внутреннего предсказания для блока кодирования может быть определен на основании полученных MPM. Когда режим внутреннего предсказания блока кодирования определен, каждый подблок может выполнять внутреннее предсказание с использованием определенного режима внутреннего предсказания.[389] When a subdivision intra coding method is applied, subblocks generated by splitting a coding block or a transform block can use the same intra prediction mode. For example, the MPMs for a coding block may be derived based on the intra prediction modes of adjacent blocks adjacent to the coding block, and the intra prediction mode for the coding block may be determined based on the obtained MPMs. When the intra prediction mode of a coding block is determined, each subblock can perform intra prediction using the determined intra prediction mode.
[390] Когда применяется способ внутреннего кодирования с подразбиением, любой из MPM может быть определен как режим внутреннего предсказания блока кодирования. То есть, когда применяется способ внутреннего кодирования с подразбиением, может считаться, что флаг MPM является истинным, хотя флаг MPM не передан.[390] When the subdivision intra coding method is applied, any of the MPMs may be defined as the coding block intra prediction mode. That is, when the subdivision intra-coding method is applied, the MPM flag may be considered to be true although the MPM flag is not transmitted.
[391] Альтернативно, когда применяется способ внутреннего кодирования с подразбиением, любой из предварительно заданных кандидатных режимов внутреннего предсказания может быть определен как режим внутреннего предсказания блока кодирования. Например, любой из режима внутреннего предсказания в горизонтальном направлении, режима внутреннего предсказания в вертикальном направлении, режима внутреннего предсказания в диагональном направлении (например, по меньшей мере одного из режима внутреннего предсказания в направлении вверх и влево, режима внутреннего предсказания в направлении вверх и вправо и режима внутреннего предсказания в направлении вниз и влево) и режима внутреннего предсказания, не основанного на информации об углах, (например, по меньшей мере одного из планарного режима и режима DC) может быть определен как режим внутреннего предсказания блока кодирования. Информация об индексах, указывающая любой из предварительно заданных кандидатных режимов внутреннего предсказания, может быть передана посредством битового потока.[391] Alternatively, when the subdivision intra coding method is applied, any of the predefined candidate intra prediction modes may be determined as the coding block intra prediction mode. For example, any of the horizontal intra prediction mode, the vertical intra prediction mode, the diagonal intra prediction mode (e.g., at least one of the up and left intra prediction mode, the up and right intra prediction mode, and the down and left intra prediction mode), and the non-angle information based intra prediction mode (e.g., at least one of the planar mode and the DC mode) can be defined as a coding block intra prediction mode. Index information indicating any of the predefined candidate intra prediction modes may be transmitted via the bitstream.
[392] Согласно варианту осуществления настоящего изобретения режим внутреннего предсказания по меньшей мере одного из подблоков может быть установлен так, чтобы отличаться от режимов других подблоков. Например, режим внутреннего предсказания N-го подблока может быть получен путем добавления смещения к режиму внутреннего предсказания N-1-го подблока или вычитания из него. Смещение может быть предварительно задано в кодере и декодере. Альтернативно смещение может быть получено на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания блока кодирования, размера, формы и количества подблоков, а также направления разбиения блока кодирования. Альтернативно информация для получения смещения может быть передана посредством битового потока.[392] According to an embodiment of the present invention, the intra prediction mode of at least one of the sub-blocks may be set to be different from the modes of other sub-blocks. For example, the intra prediction mode of the Nth subblock can be obtained by adding an offset to or subtracting from the intra prediction mode of the N-1th subblock. The offset may be predefined in the encoder and decoder. Alternatively, the offset may be derived based on at least one of the size, shape, and intra prediction mode of the coding block, the size, shape, and number of sub-blocks, and the splitting direction of the coding block. Alternatively, the information to obtain the offset may be transmitted via a bitstream.
[393] Альтернативно, когда режим внутреннего предсказания N-1-го подблока имеет режим, не основанный на информации об углах, режим внутреннего предсказания N-го подблока также установлен так, чтобы быть таким же, как режим внутреннего предсказания N-1-го подблока, а когда режим внутреннего предсказания N-1-го подблока имеет режим, основанный на информации об углах, режим внутреннего предсказания, полученный путем добавления смещения к режиму внутреннего предсказания N-1-го подблока или вычитания из него, может быть установлен так, чтобы быть таким же, как режим внутреннего предсказания N-го подблока.[393] Alternatively, when the intra prediction mode of the N-1st subblock has a mode not based on angle information, the intra prediction mode of the Nth subblock is also set to be the same as the intra prediction mode of the N-1st subblock, and when the intra prediction mode of the N-1st subblock has a mode based on angle information, the intra prediction mode obtained by adding an offset to or subtracting from the N-1st subblock intra prediction mode , may be set to be the same as the Nth subblock intra prediction mode.
[394] Альтернативно режим внутреннего предсказания, основанный на информации об углах, может быть применен к некоторым из множества подблоков, и режим внутреннего предсказания, не основанный на информации об углах, может быть применен к другим подблокам. Подблок, к которому применен режим внутреннего предсказания, не основанный на информации об углах, может быть определен с учетом по меньшей мере одного из размера, формы, положения и количества подблоков. Альтернативно, только когда режим внутреннего предсказания, основанный на информации об углах, примененный к любому из множества подблоков, представляет собой предварительно заданное значение, режим внутреннего предсказания, не основанный на информации об углах, может быть применен к другому подблоку.[394] Alternatively, an intra prediction mode based on angle information may be applied to some of the plurality of sub-blocks, and an intra prediction mode not based on angle information may be applied to other sub-blocks. A sub-block to which an intra-prediction mode not based on angle information is applied can be determined in consideration of at least one of the size, shape, position, and number of sub-blocks. Alternatively, only when the angle information-based intra prediction mode applied to any of the plurality of sub-blocks is a predetermined value, the non-angle information-based intra prediction mode can be applied to another sub-block.
[395] Альтернативно режим внутреннего предсказания каждого подблока может быть получен из MPM. Для этого информация об индексах, указывающая любой из MPM, может быть передана для каждого подблока.[395] Alternatively, the intra prediction mode of each subblock can be obtained from the MPM. For this, index information indicating any of the MPMs may be transmitted for each sub-block.
[396] Альтернативно режим внутреннего предсказания каждого подблока может быть получен из предварительно заданных кандидатных режимов внутреннего предсказания. Для этого информация об индексах, указывающая любой из предварительно заданных кандидатных режимов внутреннего предсказания, может быть передана для каждого подблока.[396] Alternatively, the intra prediction mode of each sub-block may be derived from predefined candidate intra prediction modes. For this, index information indicating any of the predefined candidate intra prediction modes may be transmitted for each sub-block.
[397] Альтернативно информация, указывающая то, равным ли образом установлены режимы внутреннего предсказания подблоков, может быть передана посредством битового потока.[397] Alternatively, information indicating whether intra subblock prediction modes are equally set may be transmitted via a bitstream.
[398] Параметры квантования подблоков могут быть определены по отдельности. Соответственно, значение параметра квантования каждого подблока может быть установлено по-разному. Чтобы определить параметр квантования каждого подблока, может быть кодирована информация, указывающая значение разницы от параметра квантования предыдущего подблока. Например, значение разницы между параметром квантования N-го подблока и параметром квантования N-1-го подблока может быть кодировано для N-го подблока.[398] The quantization parameters of the sub-blocks may be individually determined. Accordingly, the value of the quantization parameter of each sub-block may be set differently. To determine the quantization parameter of each sub-block, information indicating the value of the difference from the quantization parameter of the previous sub-block may be encoded. For example, a difference value between the Nth subblock quantization parameter and the N-1st subblock quantization parameter may be encoded for the Nth subblock.
[399] Внутреннее предсказание подблока может быть выполнено с использованием опорного отсчета. В этом случае опорный отсчет может быть получен из восстановленного отсчета соседнего блока, смежного с подблоком. Когда соседний блок, смежный с подблоком, представляет собой другой подблок, включенный в блок кодирования, который является таким же, как у подблока, опорный отсчет подблока может быть получен на основании восстановленного отсчета другого подблока. Например, когда первый подблок расположен слева или сверху от второго подблока, опорный отсчет второго подблока может быть получен из восстановленного отсчета первого подблока. Для этого параллельное внутреннее предсказание может не применяться между подблоками. То есть кодирование/декодирование может быть последовательно выполнено в отношении подблоков, включенных в блок кодирования. Соответственно, после завершения кодирования/декодирования первого подблока может быть выполнено внутреннее предсказание для второго подблока.[399] Intra-subblock prediction may be performed using a reference sample. In this case, the reference sample can be obtained from the reconstructed neighboring block sample adjacent to the sub-block. When an adjacent block adjacent to a subblock is another subblock included in the coding block that is the same as that of the subblock, the subblock reference sample may be obtained based on the reconstructed sample of the other subblock. For example, when the first sub-block is located to the left or above the second sub-block, the reference sample of the second sub-block may be obtained from the reconstructed sample of the first sub-block. For this, parallel intra prediction may not be applied between sub-blocks. That is, encoding/decoding may be sequentially performed on the sub-blocks included in the encoding block. Accordingly, after the encoding/decoding of the first subblock is completed, intra prediction can be performed for the second subblock.
[400] Когда применяется способ внутреннего кодирования с подразбиением, может быть установлено не использовать способ кодирования с внутренним предсказанием с несколькими линиями для выбора любой из множества линий-кандидатов опорных отсчетов. Когда способ кодирования с внутренним предсказанием с несколькими линиями не используется, смежная линия опорных отсчетов, смежная с каждым подблоком, может быть определена как линия опорных отсчетов каждого подблока.[400] When the intra subdivision coding method is applied, it may be set not to use the multi-line intra prediction coding method to select any one of the plurality of candidate reference sample lines. When the multi-line intra prediction coding method is not used, an adjacent reference sample line adjacent to each sub-block may be defined as the reference sample line of each sub-block.
[401] Альтернативно способ кодирования с внутренним предсказанием с несколькими линиями может быть использован даже тогда, когда применяется способ внутреннего кодирования с подразбиением. Для этого информация об индексах для указания линии опорных отсчетов может быть передана для каждого подблока. Альтернативно информация об индексах для указания линии опорных отсчетов может быть передана только для любого одного из множества подблоков, и информация об индексах может также быть применена к остальным подблокам как есть. Альтернативно может быть установлено передавать информацию об индексах для указания линии опорных отсчетов для блока кодирования и совместно использовать информацию об индексах из множества подблоков, включенных в блок кодирования.[401] Alternatively, the multi-line intra prediction coding method can be used even when the subdivision intra coding method is applied. For this, index information for indicating a reference sample line may be transmitted for each sub-block. Alternatively, the index information for indicating the reference sample line may only be transmitted for any one of the plurality of sub-blocks, and the index information may also be applied to the remaining sub-blocks as is. Alternatively, it may be set to transmit index information for indicating a reference sample line for a coding block and share index information from a plurality of sub-blocks included in the coding block.
[402] Альтернативно может быть установлено допускать только подблок, имеющий предварительно заданное положение или предварительно заданный индекс раздела, из подблоков для использования способа кодирования с внутренним предсказанием с несколькими линиями. Например, информация об индексах, указывающая любую из линий-кандидатов опорных отсчетов, может быть передана только для подблока, имеющего индекс раздела, равный 0, из множества подблоков или подблока, который находится в контакте с верхней границей или левой границей блока кодирования. Способ кодирования с внутренним предсказанием с несколькими линиями может не применяться к остальным подблокам. Соответственно, остальные подблоки могут выполнять внутреннее предсказание с использованием смежных линий опорных отсчетов.[402] Alternatively, it may be set to only allow a subblock having a predetermined position or a predetermined partition index of the subblocks to use the multi-line intra prediction coding method. For example, index information indicating any of the candidate reference sample lines may only be transmitted for a sub-block having a partition index of 0 out of a plurality of sub-blocks or a sub-block that is in contact with the top or left border of a coding block. The multi-line intra prediction coding method may not be applied to the rest of the sub-blocks. Accordingly, the remaining sub-blocks may perform intra prediction using adjacent reference sample lines.
[403] Режим кодирования с предсказанием может быть установлен по-разному для каждого подблока. Например, внутреннее предсказание может быть применено к некоторым подблокам, и предсказание, осуществляемое между изображениями, привязка к текущему изображению или комбинированное предсказание может быть применено к другим подблокам.[403] The predictive coding mode may be set differently for each sub-block. For example, intra-prediction may be applied to some sub-blocks, and inter-picture prediction, current-picture anchoring, or combined prediction may be applied to other sub-blocks.
[404] На фиг.21 представлен вид, показывающий пример, в котором режим кодирования с предсказанием устанавливают по-разному для каждого подблока.[404] FIG. 21 is a view showing an example in which the predictive coding mode is set differently for each sub-block.
[405] Режим внутреннего предсказания может быть установлен по-разному для каждого подблока, или режим кодирования с предсказанием может быть установлен по-разному. Например, в примере, показанном на фиг.21, показано, что внутреннее предсказание применяется к подблоку 0 и подблоку 1, и привязка к текущему изображению применяется к подблоку 1 и подблоку 2.[405] The intra prediction mode may be set differently for each sub-block, or the predictive coding mode may be set differently. For example, in the example shown in FIG. 21, it is shown that intra prediction is applied to sub-block 0 and sub-block 1, and the current picture anchor is applied to sub-block 1 and sub-block 2.
[406] Когда используется привязка к текущему изображению, блок предсказания подблока может быть получен из уже декодированного участка текущего изображения или слайса (или группы тайлов). Когда применяется привязка к текущему изображению, вектор движения может быть получен для указания блока предсказания подблока. Вектор движения с привязкой к текущему изображению может называться «вектором блока».[406] When the current picture anchor is used, the sub-block prediction block may be obtained from an already decoded portion of the current picture or slice (or group of tiles). When snapping is applied to the current picture, a motion vector may be obtained to indicate a sub-block prediction block. The motion vector associated with the current image may be referred to as a "block vector".
[407] Вектор движения может быть получен на основании вектора движения соседнего блока, смежного с блоком кодирования или подблоком. Альтернативно информация для определения вектора движения может быть передана посредством битового потока.[407] A motion vector may be obtained based on a motion vector of an adjacent block adjacent to a coding block or subblock. Alternatively, the information for determining the motion vector may be transmitted via a bitstream.
[408] В этом случае максимальное значение вектора движения подблока может быть определено согласно размеру подблока, или блока кодирования, или блока преобразования, к которому принадлежит подблок. Например, вектор движения подблока может быть установлен так, чтобы не отклоняться от границы блока кодирования или блока преобразования, к которому принадлежит подблок. То есть блок предсказания подблока может быть получен из участка, кодированного/декодированного перед подблоком в блоке кодирования, к которому принадлежит подблок.[408] In this case, the maximum value of the motion vector of the subblock may be determined according to the size of the subblock, or the coding block, or the transform block to which the subblock belongs. For example, the motion vector of a subblock may be set so as not to deviate from the boundary of the coding block or transform block to which the subblock belongs. That is, a subblock prediction block can be obtained from a portion encoded/decoded before the subblock in the coding block to which the subblock belongs.
[409] Информация об индексах, указывающая любой из ранее декодированных подблоков в блоке кодирования, может быть кодирована и передана вместо вектора движения. Блок предсказания подблока может быть определен как ранее декодированный подблок, указанный с помощью информации об индексах.[409] Index information indicating any of the previously decoded sub-blocks in a coding block may be encoded and transmitted instead of a motion vector. A subblock prediction block may be defined as a previously decoded subblock indicated by the index information.
[410] В качестве еще одного примера может допускаться отклонение вектора движения подблока от границы блока кодирования или блока преобразования, к которому принадлежит подблок.[410] As another example, the motion vector of the subblock may be allowed to deviate from the boundary of the coding block or transform block to which the subblock belongs.
[411] Когда блок предсказания генерируется в результате выполнения внутреннего предсказания, отсчеты предсказания могут быть обновлены на основании положения каждого из отсчетов предсказания, включенных в блок предсказания. Такой способ обновления может называться способом внутреннего взвешенного предсказания на основе положения отсчетов (или комбинацией предсказания в зависимости от положения (PDPC)).[411] When a prediction block is generated as a result of performing intra prediction, the prediction samples may be updated based on the position of each of the prediction samples included in the prediction block. Such an update method may be referred to as an intra-weighted prediction based on sample position (or a position dependent prediction combination (PDPC)).
[412] То, следует ли использовать PDPC, может быть определено с учетом размера, формы и режима внутреннего предсказания текущего блока, линии опорных отсчетов текущего блока, размера текущего блока и цветовой компоненты. Например, PDPC может быть использована, когда режим внутреннего предсказания текущего блока представляет собой по меньшей мере один из планарного режима, режима DC, режима в вертикальном направлении, режима в горизонтальном направлении, режима, имеющего индексное значение, которое меньше, чем в режиме в вертикальном направлении, и режима, имеющего индексное значение, которое больше, чем в режиме в горизонтальном направлении. Альтернативно PDPC может быть использована только тогда, когда по меньшей мере одна из ширины и высоты текущего блока больше чем 4. Альтернативно PDPC может быть использована только тогда, когда индекс линии опорного изображения текущего блока равен 0. Альтернативно PDPC может быть использована только тогда, когда индекс линии опорного изображения текущего блока равен предварительно заданному значению или больше него. Альтернативно PDPC может быть использована только для компонента яркости. Альтернативно то, следует ли использовать PDPC, может быть определено согласно тому, удовлетворяются ли два или более из условий, перечисленных выше.[412] Whether PDPC should be used may be determined based on the size, shape, and intra prediction mode of the current block, the reference sample line of the current block, the size of the current block, and the color component. For example, PDPC may be used when the intra prediction mode of the current block is at least one of a planar mode, a DC mode, a mode in the vertical direction, a mode in the horizontal direction, a mode having an index value that is smaller than the vertical direction mode, and a mode having an index value that is larger than the horizontal direction mode. Alternatively, PDPC may be used only when at least one of the width and height of the current block is greater than 4. Alternatively, PDPC may be used only when the reference picture line index of the current block is 0. Alternatively, PDPC may be used only when the reference picture line index of the current block is equal to or greater than a predetermined value. Alternatively, PDPC can only be used for the luma component. Alternatively, whether or not PDPC should be used may be determined according to whether two or more of the conditions listed above are satisfied.
[413] Альтернативно то, следует ли использовать PDPC, может быть определено согласно тому, используется ли способ внутреннего кодирования с подразбиением. Например, может быть установлено не использовать PDPC, когда применяется способ внутреннего кодирования с подразбиением к блоку кодирования или блоку преобразования. Альтернативно, когда применяется способ внутреннего кодирования с подразбиением к блоку кодирования или блоку преобразования, PDPC может быть применена к по меньшей мере одному из множества подблоков. В этом случае подблок, к которому применена PDPC, может быть определен на основании по меньшей мере одного из размера, формы, положения, режима внутреннего предсказания и индекса линии опорных отсчетов блока кодирования или подблока. Например, PDPC может быть применена к подблоку, смежному с верхней и/или левой границами блока кодирования, или подблоку, смежному с нижней и/или правой границами блока кодирования. Альтернативно на основании размера или формы подблока может быть определено, что следует применить PDPC ко всем подблокам, включенным в блок кодирования, или что не следует применять PDPC ко всем подблокам, включенным в блок кодирования. В качестве еще одного примера PDPC может быть применена ко всем подблокам в блоке кодирования.[413] Alternatively, whether or not to use PDPC can be determined according to whether an intra subdivision coding method is used. For example, it may be set not to use PDPC when a subdivision intra coding method is applied to a coding block or a transform block. Alternatively, when a subdivision intra coding method is applied to a coding block or a transform block, PDPC may be applied to at least one of the plurality of subblocks. In this case, the sub-block to which PDPC is applied may be determined based on at least one of the size, shape, position, intra prediction mode, and reference sample line index of the coding block or sub-block. For example, PDPC may be applied to a subblock adjacent to the top and/or left coding block boundaries, or a subblock adjacent to the bottom and/or right coding block boundaries. Alternatively, based on the size or shape of the subblock, it may be determined that PDPC should be applied to all subblocks included in the coding block, or that PDPC should not be applied to all subblocks included in the coding block. As another example, PDPC may be applied to all sub-blocks in a coding block.
[414] Альтернативно то, следует ли применять PDPC к каждому подблоку, может быть определено согласно тому, удовлетворяет ли по меньшей мере одно из размера, формы, режима внутреннего предсказания и индекса опорного изображения подблоков, сгенерированных путем разбиения блока кодирования или блока преобразования, предварительно установленному условию. Например, когда по меньшей мере одна из ширины и высоты подблока больше чем 4, PDPC может быть применена к подблоку.[414] Alternatively, whether PDPC should be applied to each subblock may be determined according to whether at least one of the size, shape, intra prediction mode, and reference picture index of the subblocks generated by splitting a coding block or a transform block satisfies a predetermined condition. For example, when at least one of the sub-block width and height is greater than 4, PDPC may be applied to the sub-block.
[415] В качестве еще одного примера информация, указывающая то, применяется ли PDPC, может быть передана посредством битового потока.[415] As another example, information indicating whether PDPC is applied may be transmitted via a bitstream.
[416] Альтернативно участок, к которому применяется PDPC, может быть определен на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания текущего блока и положения отсчета предсказания. Например, когда режим внутреннего предсказания текущего блока имеет индекс, который больше, чем в вертикальном направлении, отсчеты предсказания, по меньшей мере одна из координаты по оси x и координаты по оси y которых больше, чем пороговое значение, не откорректированы, и корректировка может быть выполнена только в отношении отсчетов предсказания, координата по оси x или координата по оси y которых меньше, чем пороговое значение, или равняется ему. Альтернативно, когда режим внутреннего предсказания текущего блока имеет индекс, который меньше, чем в горизонтальном направлении, отсчеты предсказания, по меньшей мере одна из координаты по оси x и координаты по оси y которых больше, чем пороговое значение, не откорректированы, и корректировка может быть выполнена только в отношении отсчетов предсказания, координата по оси x или координата по оси y которых меньше, чем пороговое значение, или равняется ему. В этом случае пороговое значение может быть определено на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания текущего блока.[416] Alternatively, the portion to which PDPC is applied may be determined based on at least one of the size, shape, and intra prediction mode of the current block and the prediction sample position. For example, when the intra prediction mode of the current block has an index that is greater than the vertical direction, prediction samples at least one of the x-coordinate and the y-coordinate of which are greater than the threshold value are not corrected, and correction can only be performed on prediction samples whose x-coordinate or y-coordinate is less than or equal to the threshold value. Alternatively, when the intra prediction mode of the current block has an index that is less than in the horizontal direction, the prediction samples at least one of the x-coordinate and the y-coordinate of which is greater than the threshold value are not corrected, and the correction can be performed only on prediction samples whose x-coordinate or y-coordinate is less than or equal to the threshold value. In this case, the threshold value may be determined based on at least one of the size, shape, and intra prediction mode of the current block.
[417] Когда отсчет предсказания получен посредством отсчета внутреннего предсказания, опорный отсчет, используемый для корректировки отсчета предсказания, может быть определен на основании положения полученного отсчета предсказания. Для удобства объяснения в вариантах осуществления, описанных ниже, опорный отсчет, используемый для корректировки отсчета предсказания, будет называться опорным отсчетом PDPC. Кроме того, отсчет предсказания, полученный посредством внутреннего предсказания, называется первым отсчетом предсказания, и отсчет предсказания, полученный путем корректировки первого отсчета предсказания, называется вторым отсчетом предсказания.[417] When the prediction sample is obtained by the intra prediction sample, the reference sample used to correct the prediction sample may be determined based on the position of the received prediction sample. For convenience of explanation, in the embodiments described below, the reference sample used to correct the prediction sample will be referred to as the PDPC reference sample. In addition, a prediction sample obtained by intra prediction is called a first prediction sample, and a prediction sample obtained by correcting the first prediction sample is called a second prediction sample.
[418] На фиг.22 представлен вид, показывающий вариант осуществления применения PDPC.[418] FIG. 22 is a view showing an embodiment of applying PDPC.
[419] Первый отсчет предсказания может быть откорректирован с использованием по меньшей мере одного опорного отсчета PDPC. Опорный отсчет PDPC может включать по меньшей мере один из опорного отсчета, смежного с верхним левым углом текущего блока, верхнего опорного отсчета, расположенного сверху от текущего блока, и левого опорного отсчета, расположенного слева от текущего блока.[419] The first prediction sample may be corrected using at least one PDPC reference sample. The PDPC reference sample may include at least one of the reference sample adjacent to the upper left corner of the current block, the upper reference sample located above the current block, and the left reference sample located to the left of the current block.
[420] По меньшей мере один из опорных отсчетов, принадлежащих к линии опорных отсчетов текущего блока, может быть установлен как опорный отсчет PDPC. Альтернативно, независимо от линии опорных отсчетов текущего блока, по меньшей мере один из опорных отсчетов, принадлежащих к линии опорных отсчетов, имеющей индекс 0, может быть установлен как опорный отсчет PDPC. Например, хотя первый отсчет предсказания получен с использованием опорного отсчета, включенного в линию опорных отсчетов с индексом 1 или индексом 2, второй отсчет предсказания может быть получен с использованием опорного отсчета, включенного в линию опорных отсчетов с индексом 0.[420] At least one of the reference samples belonging to the reference sample line of the current block may be set as a PDPC reference sample. Alternatively, regardless of the reference sample line of the current block, at least one of the reference samples belonging to the reference sample line having index 0 may be set as the PDPC reference sample. For example, although the first prediction sample is obtained using the reference sample included in the reference sample line with index 1 or index 2, the second prediction sample can be obtained using the reference sample included in the reference sample line with index 0.
[421] Количество или положения опорных отсчетов PDPC, используемых для корректировки первого отсчета предсказания, могут быть определены с учетом по меньшей мере одного из режима внутреннего предсказания текущего блока, размера текущего блока, формы текущего блока и положения первого отсчета предсказания.[421] The number or positions of the PDPC reference samples used to correct the first prediction sample may be determined based on at least one of the intra prediction mode of the current block, the size of the current block, the shape of the current block, and the position of the first prediction sample.
[422] Например, когда режим внутреннего предсказания текущего блока представляет собой планарный режим или режим DC, второй отсчет предсказания может быть получен с использованием верхнего опорного отсчета и левого опорного отсчета. В этом случае верхний опорный отсчет может представлять собой опорный отсчет, который является вертикальным относительно первого отсчета предсказания (например, опорный отсчет одинаковой координаты x), и левый опорный отсчет может представлять собой опорный отсчет, который является горизонтальным относительно первого отсчета предсказания (например, опорный отсчет одинаковой координаты y).[422] For example, when the intra prediction mode of the current block is a planar mode or a DC mode, the second prediction sample may be obtained using the upper reference sample and the left reference sample. In this case, the top reference sample may be a reference sample that is vertical with respect to the first prediction sample (e.g., the same x-coordinate reference sample), and the left reference sample may be a reference sample that is horizontal with respect to the first prediction sample (e.g., the same y-coordinate reference sample).
[423] Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания в горизонтальном направлении, второй отсчет предсказания может быть получен с использованием верхнего опорного отсчета. В этом случае верхний опорный отсчет может представлять собой опорный отсчет, который является вертикальным относительно первого отсчета предсказания.[423] When the intra prediction mode of the current block is the intra prediction mode in the horizontal direction, the second prediction sample may be obtained using the upper reference sample. In this case, the top reference sample may be a reference sample that is vertical with respect to the first prediction sample.
[424] Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания в вертикальном направлении, второй отсчет предсказания может быть получен с использованием левого опорного отсчета. В этом случае левый опорный отсчет может представлять собой опорный отсчет, который является горизонтальным относительно первого отсчета предсказания.[424] When the intra prediction mode of the current block is the intra prediction mode in the vertical direction, the second prediction sample may be obtained using the left reference sample. In this case, the left reference sample may be a reference sample that is horizontal with respect to the first prediction sample.
[425] Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания в диагональном направлении вниз и влево или режим внутреннего предсказания в диагональном направлении вверх и вправо, второй отсчет предсказания может быть получен на основании верхнего левого опорного отсчета, верхнего опорного отсчета и левого опорного отсчета. Верхний левый опорный отсчет может представлять собой опорный отсчет, смежный с верхним левым углом текущего блока (например, опорный отсчет в положении (-1, -1)). Верхний опорный отсчет может представлять собой опорный отсчет, расположенный в диагональном направлении вверх и вправо первого отсчета предсказания, и левый опорный отсчет может представлять собой опорный отсчет, расположенный в диагональном направлении вниз и влево первого отсчета предсказания.[425] When the intra prediction mode of the current block is the diagonal down and left intra prediction mode or the diagonal up and right intra prediction mode, the second prediction sample can be obtained based on the upper left reference sample, the upper reference sample, and the left reference sample. The top left reference point may be the reference point adjacent to the top left corner of the current block (eg, the reference point at position (-1, -1)). The top reference may be a reference diagonally up and to the right of the first prediction sample, and the left reference may be a reference diagonally down and to the left of the first prediction sample.
[426] В итоге, когда положение первого отсчета предсказания представляет собой (x, y), R(-1, -1) может быть установлен как верхний левый опорный отсчет, и R(x+y+1, -1) или R(x, -1) может быть установлен как верхний опорный отсчет.Кроме того, R(-1, x+y+1) или R(-1, y) может быть установлен как левый опорный отсчет.[426] In summary, when the position of the first prediction sample is (x, y), R(-1, -1) may be set as the top left reference, and R(x+y+1, -1) or R(x, -1) may be set as the top reference. In addition, R(-1, x+y+1) or R(-1, y) may be set as the left reference.
[427] В качестве еще одного примера положение левого опорного отсчета или верхнего опорного отсчета может быть определено с учетом по меньшей мере одного из формы текущего блока и того, применяется ли широкоугольный внутренний режим.[427] As another example, the position of the left reference or upper reference may be determined in consideration of at least one of the shape of the current block and whether wide-angle intra mode is applied.
[428] В частности, когда режим внутреннего предсказания текущего блока представляет собой широкоугольный режим внутреннего предсказания, опорный отсчет, разнесенный от опорного отсчета, расположенного в диагональном направлении первого отсчета предсказания, на величину смещения, может быть установлен как опорный отсчет PDPC. Например, верхний опорный отсчет R(x+y+k+1, -1) и левый опорный отсчет R(-1, x+y - k+1) могут быть установлены как опорные отсчеты PDPC.[428] In particular, when the intra prediction mode of the current block is a wide-angle intra prediction mode, a reference sample spaced apart from a reference sample located in the diagonal direction of the first prediction sample by an offset amount can be set as a PDPC reference sample. For example, the top reference R(x+y+k+1, -1) and the left reference R(-1, x+y - k+1) may be set as PDPC references.
[429] В этом случае смещение k может быть определено на основании широкоугольного режима внутреннего предсказания. Уравнения 8 и 9 демонстрируют пример получения смещения на основании широкоугольного режима внутреннего предсказания.[429] In this case, the offset k may be determined based on the wide-angle intra prediction mode. Equations 8 and 9 show an example of obtaining an offset based on the wide-angle intra prediction mode.
[430] [Уравнение 8][430] [Equation 8]
[431] [Уравнение 9][431] [Equation 9]
[432] Второй отсчет предсказания может быть определен на основании операции взвешенного суммирования первого отсчета предсказания и опорных отсчетов PDPC. Например, второй отсчет предсказания может быть получен на основании уравнения 10, показанного ниже.[432] The second prediction sample may be determined based on a weighted sum operation of the first prediction sample and the PDPC reference samples. For example, the second prediction sample can be obtained based on Equation 10 shown below.
[433] [Уравнение 10][433] [Equation 10]
[434] В уравнении 10 RL обозначает левый опорный отсчет, RT обозначает верхний опорный отсчет, и RTL обозначает верхний левый опорный отсчет.Pred(x, y) обозначает отсчет предсказания в положении (x, y). wL обозначает значение взвешивания, присвоенное левому опорному отсчету, wT обозначает значение взвешивания, присвоенное верхнему опорному отсчету, и wTL обозначает значение взвешивания, присвоенное верхнему левому опорному отсчету. Значения взвешивания, присвоенные первому отсчету предсказания, могут быть получены путем вычитания значений взвешивания, присвоенных опорным отсчетам, из максимального значения. Для удобства объяснения значение взвешивания, присвоенное опорному отсчету PDPC, называется значением взвешивания PDPC.[434] In Equation 10, RL denotes the left reference sample, RT denotes the upper reference sample, and RTL denotes the upper left reference sample. Pred(x, y) denotes the prediction sample at position (x, y). wL denotes a weight value assigned to the left reference, wT denotes a weight value assigned to the upper reference, and wTL denotes a weight value assigned to the upper left reference. The weighting values assigned to the first prediction sample can be obtained by subtracting the weighting values assigned to the reference samples from the maximum value. For convenience of explanation, the weighting value assigned to the PDPC reference sample is referred to as the PDPC weighting value.
[435] Значение взвешивания, присвоенное каждому опорному отсчету, может быть определено на основании по меньшей мере одного из режима внутреннего предсказания текущего блока и положения первого отсчета предсказания.[435] The weighting value assigned to each reference sample may be determined based on at least one of the intra prediction mode of the current block and the position of the first prediction sample.
[436] Например, по меньшей мере одно из wL, wT и wTL может иметь пропорциональную или обратно пропорциональную связь с по меньшей мере одним из значения координаты по оси x и значения координаты по оси y отсчета предсказания. Альтернативно по меньшей мере одно из wL, wT и wTL может иметь пропорциональную или обратно пропорциональную связь с по меньшей мере одной из ширины и высоты текущего блока.[436] For example, at least one of wL, wT, and wTL may be proportional or inversely related to at least one of the x-coordinate value and the y-coordinate value of the prediction sample. Alternatively, at least one of wL, wT, and wTL may be proportional or inversely related to at least one of the width and height of the current block.
[437] Когда режим внутреннего предсказания текущего блока представляет собой режим DC, значения взвешивания PDPC могут быть определены так, как показано в уравнении 11.[437] When the intra prediction mode of the current block is the DC mode, the PDPC weighting values may be determined as shown in Equation 11.
[438] [Уравнение 11][438] [Equation 11]
[439] В уравнении 11 x и y обозначают положение первого отсчета предсказания.[439] In Equation 11, x and y denote the position of the first prediction sample.
[440] Переменная shift, используемая в операции битового сдвига, в уравнении 11 может быть получена на основании ширины или высоты текущего блока. Например, переменная shift может быть получена на основании уравнения 12 или 13, показанного ниже.[440] The variable shift used in the bit shift operation in Equation 11 may be obtained based on the width or height of the current block. For example, the shift variable can be obtained based on equation 12 or 13 shown below.
[441] [Уравнение 12][441] [Equation 12]
[442] [Уравнение 13][442] [Equation 13]
) )
[443] Альтернативно переменная shift может быть получена с учетом параметра внутреннего направления текущего блока.[443] Alternatively, the variable shift can be obtained taking into account the parameter of the internal direction of the current block.
[444] Количество параметров или типов параметров, используемых для получения переменной shift, может быть определено по-разному согласно режиму внутреннего предсказания текущего блока. Например, когда режим внутреннего предсказания текущего блока представляет собой планарный режим, режим DC, режим в вертикальном направлении или режим в горизонтальном направлении, переменная shift может быть получена с использованием ширины (width) и высоты (height) текущего блока, как показано в примере уравнения 12 или уравнения 13. Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, имеющий индекс, который больше, чем в режиме внутреннего предсказания в вертикальном направлении, переменная shift может быть получена с использованием высоты и параметра внутреннего направления текущего блока. Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, имеющий индекс, который меньше, чем в горизонтальном режиме внутреннего предсказания, переменная shift может быть получена с использованием ширины и параметра внутреннего направления текущего блока.[444] The number of parameters or parameter types used to obtain the shift variable may be determined differently according to the intra prediction mode of the current block. For example, when the intra prediction mode of the current block is a planar mode, a DC mode, a mode in the vertical direction, or a mode in the horizontal direction, the shift variable can be obtained using the width (width) and height (height) of the current block, as shown in the example of Equation 12 or Equation 13. When the intra prediction mode of the current block is an intra prediction mode having an index that is larger than the intra prediction mode in the vertical direction, the shift variable can be obtained using the height and the inner direction parameter of the current block. When the intra prediction mode of the current block is an intra prediction mode having an index that is smaller than that of the horizontal intra prediction mode, the shift variable can be obtained using the width and the intra direction parameter of the current block.
[445] Когда режим внутреннего предсказания текущего блока представляет собой планарный режим, значение wTL может быть установлено равным 0. wL и wT могут быть получены на основании уравнения 14, показанного ниже.[445] When the intra prediction mode of the current block is a planar mode, wTL may be set to 0. wL and wT may be obtained based on Equation 14 shown below.
[446] [Уравнение 14][446] [Equation 14]
[447] Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания в горизонтальном направлении, wT может быть установлено равным 0, и wTL и wL могут быть установлены равным образом. С другой стороны, когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания в вертикальном направлении, wL может быть установлено равным 0, и wTL и wT могут быть установлены равным образом.[447] When the intra prediction mode of the current block is the intra prediction mode in the horizontal direction, wT may be set to 0, and wTL and wL may be set equally. On the other hand, when the intra prediction mode of the current block is the intra prediction mode in the vertical direction, wL may be set to 0, and wTL and wT may be set in the same way.
[448] Когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, направленный вверх и вправо, имеющий индексное значение, которое больше, чем в режиме внутреннего предсказания в вертикальном направлении, значения взвешивания PDPC могут быть получены так, как показано в уравнении 15.[448] When the intra prediction mode of the current block is an up and right intra prediction mode having an index value that is larger than the vertical intra prediction mode, the PDPC weighting values can be obtained as shown in Equation 15.
[449] [Уравнение 15][449] [Equation 15]
[450] С другой стороны, когда режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, направленный вниз и влево, имеющий индексное значение, которое меньше, чем в режиме внутреннего предсказания в горизонтальном направлении, значения взвешивания PDPC могут быть получены так, как показано в уравнении 16.[450] On the other hand, when the intra prediction mode of the current block is a downward and left intra prediction mode having an index value that is smaller than that of the horizontal intra prediction mode, the PDPC weighting values can be obtained as shown in Equation 16.
[451] [Уравнение 16][451] [Equation 16]
[452] Как показано в варианте осуществления, описанном выше, значения взвешивания PDPC могут быть определены на основании положения x и y отсчета предсказания.[452] As shown in the embodiment described above, the PDPC weighting values may be determined based on the x and y positions of the prediction sample.
[453] В качестве еще одного примера значение взвешивания, присвоенное каждому из опорных отсчетов PDPC, может быть определено элементом подблока. Отсчеты предсказания, включенные в подблок, могут совместно использовать одинаковые значения взвешивания PDPC.[453] As another example, a weighting value assigned to each of the PDPC reference samples may be determined by a subblock element. Prediction samples included in a subblock may share the same PDPC weighting values.
[454] Размер подблока, который является базовым элементом для определения значения взвешивания, может быть предварительно задан в кодере и декодере. Например, значение взвешивания может быть определено для каждого подблока размером 2×2 или 4×4.[454] The size of the sub-block, which is the basic element for determining the weighting value, may be predetermined in the encoder and decoder. For example, a weighting value may be determined for each 2×2 or 4×4 sub-block.
[455] Альтернативно размер, форма или количество подблоков могут быть определены согласно размеру или форме текущего блока. Например, независимо от размер блока кодирования, блок кодирования может быть разбит на четыре подблока. Альтернативно блок кодирования может быть разбит на 4 или 16 подблоков согласно размеру блока кодирования.[455] Alternatively, the size, shape, or number of sub-blocks may be determined according to the size or shape of the current block. For example, regardless of the size of the coding block, the coding block can be divided into four sub-blocks. Alternatively, the coding block may be divided into 4 or 16 sub-blocks according to the size of the coding block.
[456] Альтернативно размер, форма или количество подблоков могут быть определены на основании режима внутреннего предсказания текущего блока. Например, когда режим внутреннего предсказания текущего блока имеет горизонтальное направление, N столбцов (или N строк) установлены как один подблок, тогда как когда режим внутреннего предсказания текущего блока имеет вертикальное направление, N строк (или N столбцов) могут быть установлены как один подблок.[456] Alternatively, the size, shape, or number of subblocks may be determined based on the intra prediction mode of the current block. For example, when the intra prediction mode of the current block has a horizontal direction, N columns (or N rows) can be set as one sub-block, while when the intra prediction mode of the current block has a vertical direction, N rows (or N columns) can be set as one sub-block.
[457] Уравнения 17-19 демонстрируют примеры определения значения взвешивания PDPC для подблока размером 2×2. Уравнение 17 демонстрирует случай, в котором режим внутреннего предсказания текущего блока представляет собой режим DC.[457] Equations 17-19 show examples of determining the PDPC weighting value for a 2×2 subblock. Equation 17 shows the case where the intra prediction mode of the current block is the DC mode.
[458] [Уравнение 17][458] [Equation 17]
[459] В уравнении 17 K может быть определено на основании размера подблока.[459] In Equation 17, K may be determined based on the sub-block size.
[460] Уравнение 18 демонстрирует пример, в котором режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, направленный вверх и вправо, имеющий индексное значение, которое больше, чем в режиме внутреннего предсказания в вертикальном направлении.[460] Equation 18 shows an example in which the intra prediction mode of the current block is an up and right intra prediction mode having an index value that is larger than the intra prediction mode in the vertical direction.
[461] [Уравнение 18][461] [Equation 18]
[462] Уравнение 19 демонстрирует пример, в котором режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, направленный вниз и влево, имеющий индексное значение, которое меньше, чем в режиме внутреннего предсказания в горизонтальном направлении.[462] Equation 19 shows an example in which the intra prediction mode of the current block is the down and left intra prediction mode having an index value that is less than that of the horizontal direction intra prediction mode.
[463] [Уравнение 19][463] [Equation 19]
[464] В уравнениях 17-19 x и y обозначают положение опорного отсчета внутри подблока. Опорный отсчет может представлять собой любой из отсчета, расположенного сверху слева от подблока, отсчета, расположенного в центре подблока, и отсчета, расположенного снизу справа от подблока.[464] In Equations 17-19, x and y denote the position of a reference sample within a sub-block. The reference sample may be any of the sample located at the top left of the sub-block, the sample located at the center of the sub-block, and the sample located at the bottom right of the sub-block.
[465] Уравнения 20-22 демонстрируют примеры определения значения взвешивания PDPC для подблока размером 4×4. Уравнение 20 демонстрирует пример, в котором режим внутреннего предсказания текущего блока представляет собой режим DC.[465] Equations 20-22 show examples of determining a PDPC weighting value for a 4x4 subblock. Equation 20 shows an example in which the intra prediction mode of the current block is the DC mode.
[466] [Уравнение 20][466] [Equation 20]
[467] Уравнение 21 демонстрирует пример, в котором режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, направленный вверх и вправо, имеющий индексное значение, которое больше, чем в режиме внутреннего предсказания в вертикальном направлении.[467] Equation 21 shows an example in which the intra prediction mode of the current block is an up and right intra prediction mode having an index value that is larger than the intra prediction mode in the vertical direction.
[468] [Уравнение 21][468] [Equation 21]
[469] Уравнение 22 демонстрирует пример, в котором режим внутреннего предсказания текущего блока представляет собой режим внутреннего предсказания, направленный вниз и влево, имеющий индексное значение, которое меньше, чем в режиме внутреннего предсказания в горизонтальном направлении.[469] Equation 22 shows an example in which the intra prediction mode of the current block is the down and left intra prediction mode having an index value that is smaller than that of the horizontal direction intra prediction mode.
[470] [Уравнение 22][470] [Equation 22]
[471] В вариантах осуществления, описанных выше, было описано, что значения взвешивания PDPC определены с учетом положений отсчетов предсказания, включенных в первый отсчет предсказания или подблок. Значения взвешивания PDPC могут быть определены путем дополнительного учета формы текущего блока.[471] In the embodiments described above, it has been described that the PDPC weighting values are determined considering the positions of the prediction samples included in the first prediction sample or subblock. The PDPC weighting values can be determined by further considering the shape of the current block.
[472] Например, в случае режима DC способ получения значения взвешивания PDPC может меняться в зависимости от того, имеет ли текущий блок неквадратную форму, ширина которой больше, чем высота, или неквадратную форму, высота которой больше, чем ширина.[472] For example, in the case of the DC mode, the method for obtaining the PDPC weighting value may vary depending on whether the current block has a non-square shape whose width is larger than the height, or a non-square shape whose height is larger than the width.
[473] Уравнение 23 демонстрирует пример получения значения взвешивания PDPC, когда текущий блок имеет неквадратную форму, ширина которой больше, чем высота, и уравнение 24 демонстрирует пример получения значения взвешивания PDPC, когда текущий блок имеет неквадратную форму, высота которой больше, чем ширина.[473] Equation 23 shows an example of obtaining a PDPC weighting value when the current block has a non-square shape whose width is greater than the height, and Equation 24 shows an example of obtaining a PDPC weighting value when the current block has a non-square shape whose height is greater than the width.
[474] [Уравнение 23][474] [Equation 23]
[475] [Уравнение 24][475] [Equation 24]
[476] Когда текущий блок имеет неквадратную форму, текущий блок может быть предсказан с использованием широкоугольного режима внутреннего предсказания. Таким образом, даже когда применяется широкоугольный режим внутреннего предсказания, первый отсчет предсказания может быть обновлен путем применения PDPC.[476] When the current block has a non-square shape, the current block can be predicted using the wide-angle intra prediction mode. Thus, even when the wide-angle intra prediction mode is applied, the first prediction sample can be updated by applying PDPC.
[477] Когда широкоугольное внутреннее предсказание применяется к текущему блоку, значение взвешивания PDPC может быть определено с учетом формы блока кодирования.[477] When wide-angle intra prediction is applied to the current block, the PDPC weighting value may be determined considering the shape of the coding block.
[478] Например, когда текущий блок имеет неквадратную форму, ширина которой больше, чем высота, согласно положению первого отсчета предсказания, может быть случай, в котором верхний опорный отсчет, расположенный сверху справа от первого отсчета предсказания, ближе к первому отсчету предсказания, чем левый опорный отсчет, расположенный снизу слева от первого отсчета предсказания. Соответственно, при корректировке первого отсчета предсказания значение взвешивания, примененное к верхнему опорному отсчету, может быть установлено так, чтобы быть больше, чем значение взвешивания, примененное к левому опорному отсчету.[478] For example, when the current block has a non-square shape, the width of which is greater than the height according to the position of the first prediction sample, there may be a case in which the upper reference sample located at the upper right of the first prediction sample is closer to the first prediction sample than the left reference sample located at the lower left of the first prediction sample. Accordingly, when correcting the first prediction sample, the weighting value applied to the upper reference sample may be set to be larger than the weighting value applied to the left reference sample.
[479] С другой стороны, когда текущий блок имеет неквадратную форму, высота которой больше, чем ширина, согласно положению первого отсчета предсказания, может быть случай, в котором левый опорный отсчет, расположенный снизу слева от первого отсчета предсказания, ближе к первому отсчету предсказания, чем верхний опорный отсчет, расположенный сверху справа от первого отсчета предсказания. Соответственно, при корректировке первого отсчета предсказания значение взвешивания, примененное к левому опорному отсчету, может быть установлено так, чтобы быть больше, чем значение взвешивания, примененное к верхнему опорному отсчету.[479] On the other hand, when the current block has a non-square shape whose height is greater than the width according to the position of the first prediction sample, there may be a case in which the left reference sample located at the lower left of the first prediction sample is closer to the first prediction sample than the upper reference sample located at the upper right of the first prediction sample. Accordingly, when correcting the first prediction sample, the weighting value applied to the left reference sample may be set to be larger than the weighting value applied to the upper reference sample.
[480] Уравнение 25 демонстрирует пример получения значения взвешивания PDPC, когда режим внутреннего предсказания текущего блока представляет собой широкоугольный режим внутреннего предсказания, имеющий индекс, который больше чем 66.[480] Equation 25 shows an example of obtaining a PDPC weighting value when the intra prediction mode of the current block is a wide-angle intra prediction mode having an index greater than 66.
[481] [Уравнение 25][481] [Equation 25]
[482] Уравнение 26 демонстрирует пример получения значения взвешивания PDPC, когда режим внутреннего предсказания текущего блока представляет собой широкоугольный режим внутреннего предсказания, имеющий индекс, который меньше чем 0.[482] Equation 26 shows an example of obtaining a PDPC weighting value when the intra prediction mode of the current block is a wide-angle intra prediction mode having an index that is less than 0.
[483] [Уравнение 26][483] [Equation 26]
[484] Значение взвешивания PDPC может быть определено на основании соотношения текущего блока. Соотношение текущего блока представляет соотношение ширины и высоты текущего блока и может быть определено так, как показано в уравнении 27.[484] The PDPC weighting value may be determined based on the ratio of the current block. The ratio of the current box represents the ratio of the width and height of the current box and can be determined as shown in Equation 27.
[485] [Уравнение 27][485] [Equation 27]
[486] Согласно режиму внутреннего предсказания текущего блока способ получения значения взвешивания PDPC может быть определен различными путями.[486] According to the intra prediction mode of the current block, the method for obtaining the PDPC weighting value may be determined in various ways.
[487] Например, уравнения 28 и 29 демонстрируют пример получения значения взвешивания PDPC, когда режим внутреннего предсказания текущего блока представляет собой режим DC. В частности, уравнение 28 представляет собой пример случая, в котором текущий блок имеет неквадратную форму, ширина которой больше, чем высота, и уравнение 29 представляет собой пример случая, в котором текущий блок имеет неквадратную форму, высота которой больше, чем ширина.[487] For example, equations 28 and 29 show an example of obtaining a PDPC weighting value when the intra prediction mode of the current block is the DC mode. In particular, Equation 28 is an example of a case where the current box has a non-square shape whose width is larger than the height, and Equation 29 is an example of a case where the current box has a non-square shape whose height is larger than the width.
[488] [Уравнение 28][488] [Equation 28]
[489] [Уравнение 29][489] [Equation 29]
[490] Уравнение 30 демонстрирует пример получения значения взвешивания PDPC, когда режим внутреннего предсказания текущего блока представляет собой широкоугольный режим внутреннего предсказания, имеющий индекс, который больше чем 66.[490] Equation 30 shows an example of obtaining a PDPC weighting value when the intra prediction mode of the current block is a wide-angle intra prediction mode having an index greater than 66.
[491] [Уравнение 30][491] [Equation 30]
[492] Уравнение 31 демонстрирует пример получения значения взвешивания PDPC, когда режим внутреннего предсказания текущего блока представляет собой широкоугольный режим внутреннего предсказания, имеющий индекс, который меньше чем 0.[492] Equation 31 shows an example of obtaining a PDPC weighting value when the intra prediction mode of the current block is a wide-angle intra prediction mode having an index that is less than 0.
[493] [Уравнение 31][493] [Equation 31]
[494] Полученное остаточное изображение может быть получено путем вычитания видео предсказания из первоначального видео. В этом случае, когда остаточное видео изменяется на частотную область, субъективное качество видео существенно не снижается, хотя высокочастотные компоненты удалены из частотных компонентов. Соответственно, когда значения высокочастотных компонентов конвертируются в небольшие или значения высокочастотных компонентов установлены равными 0, имеет место эффект увеличения эффективности сжатия без генерирования существенного визуального искажения. Отражая эту характеристику, текущий блок может быть преобразован для разложения остаточного видео на двумерные частотные компоненты. Преобразование может быть выполнено с использованием метода преобразования, такого как дискретное косинусное преобразование (DCT) или дискретное синусное преобразование (DST).[494] The resulting afterimage can be obtained by subtracting the prediction video from the original video. In this case, when the residual video is changed to the frequency domain, the subjective video quality is not significantly reduced, although the high frequency components are removed from the frequency components. Accordingly, when the values of the high frequency components are converted to small or the values of the high frequency components are set to 0, there is an effect of increasing the compression efficiency without generating significant visual distortion. Reflecting this characteristic, the current block can be transformed to decompose the residual video into 2D frequency components. The transformation may be performed using a transformation method such as discrete cosine transform (DCT) or discrete sine transform (DST).
[495] DCT раскладывает (или преобразует) остаточное видео на двумерные частотные компоненты с использованием косинусного преобразования, а DST раскладывает (или преобразует) остаточное видео на двумерные частотные компоненты с использованием синусного преобразования. В результате преобразования остаточного видео частотные компоненты могут быть выражены в виде базового видео. Например, когда преобразование DCT выполнено в отношении блока размером N×N, могут быть получены компоненты базовой схемы в количестве N2. Размер каждого из компонентов базовой схемы, включенных в блок размером N×N, может быть получен посредством преобразования. Согласно методу преобразования, используемому для этого, значение компонента базовой схемы может называться коэффициентом DCT или коэффициентом DST.[495] The DCT decomposes (or transforms) the residual video into 2D frequency components using a cosine transform, and the DST decomposes (or transforms) the residual video into 2D frequency components using a sine transform. As a result of the conversion of the residual video, the frequency components can be expressed as the base video. For example, when a DCT is performed on an N×N block, N2 base circuit components can be obtained. The size of each of the base circuit components included in the N×N block can be obtained by transformation. According to the conversion method used for this, the base circuit component value may be referred to as a DCT coefficient or a DST coefficient.
[496] Метод преобразования DCT в основном используют для преобразования видео, в котором распределяют многие ненулевые низкочастотные компоненты. Метод преобразования DST в основном используют для видео, в которых распределяют многие высокочастотные компоненты.[496] The DCT conversion method is mainly used to convert video in which many non-zero low frequency components are distributed. The DST conversion method is mainly used for videos in which many high frequency components are distributed.
[497] Остаточное видео может быть преобразовано с использованием метода преобразования, отличного от DCT или DST.[497] The residual video may be converted using a conversion method other than DCT or DST.
[498] Далее преобразование остаточного видео в двумерные частотные компоненты будет называться двумерным преобразованием видео. Кроме того, размер компонентов базовой схемы, полученный в результате преобразования, называется коэффициентом преобразования. Например, коэффициент преобразования может означать коэффициент DCT или коэффициент DST. Когда применены как первое преобразование, так и второе преобразование, описанные ниже, коэффициент преобразования может означать размер компонента базовой схемы, сгенерированного в результате второго преобразования.[498] Hereinafter, the transformation of the residual video into two-dimensional frequency components will be called two-dimensional video transformation. In addition, the size of the base circuit components resulting from the transformation is called the transformation factor. For example, the transform coefficient may mean a DCT coefficient or a DST coefficient. When both the first transform and the second transform described below are applied, the transform factor may indicate the size of the base circuit component generated as a result of the second transform.
[499] Метод преобразования может быть определен для каждого блока. Метод преобразования может быть определен на основании по меньшей мере одного из режима кодирования с предсказанием текущего блока, размера текущего блока и формы текущего блока. Например, когда текущий блок кодируется в режиме внутреннего предсказания, а размер текущего блока меньше, чем N×N, преобразование может быть выполнено с использованием метода преобразования DST. С другой стороны, когда приведенные выше условия не удовлетворяются, преобразование может быть выполнено с использованием метода преобразования DCT.[499] A conversion method may be defined for each block. The transform method may be determined based on at least one of the current block predictive coding mode, the current block size, and the current block shape. For example, when the current block is encoded in the intra prediction mode and the size of the current block is smaller than N×N, the transformation may be performed using the DST transformation method. On the other hand, when the above conditions are not satisfied, the conversion can be performed using the DCT conversion method.
[500] Двумерное преобразование видео может не быть выполнено для некоторых блоков остаточного видео. Невыполнение двумерного преобразования видео может называться пропуском преобразования. Когда применен пропуск преобразования, квантование может быть применено к остаточным коэффициентам, которые не были преобразованы.[500] 2D video conversion may not be performed for some blocks of residual video. Failure to perform a 2D video conversion may be referred to as a conversion skip. When a transform skip is applied, quantization can be applied to the residual coefficients that have not been transformed.
[501] После преобразования текущего блока с использованием DCT или DST преобразованный текущий блок может быть преобразован повторно. В этом случае преобразование на основании DCT или DST может быть определено как первое преобразование, а повторное преобразование блока, к которому применено первое преобразование, может быть определено как второе преобразование.[501] After converting the current block using DCT or DST, the converted current block can be converted again. In this case, a transform based on the DCT or DST may be defined as the first transform, and re-transforming the block to which the first transform has been applied can be defined as the second transform.
[502] Первое преобразование может быть выполнено с использованием любой из множества основ-кандидатов преобразования. Например, первое преобразование может быть выполнено с использованием любого из DCT2, DCT8 или DCT7.[502] The first transformation may be performed using any of a plurality of candidate transformation bases. For example, the first conversion may be performed using any of DCT2, DCT8, or DCT7.
[503] Разные основы преобразования могут быть использованы для горизонтального направления и вертикального направления. Информация, указывающая комбинацию основы преобразования в горизонтальном направлении и основы преобразования в вертикальном направлении, может быть передана посредством битового потока.[503] Different transformation bases may be used for the horizontal direction and the vertical direction. Information indicating a combination of a transformation base in the horizontal direction and a transformation base in the vertical direction may be transmitted via a bitstream.
[504] Элементы для выполнения первого преобразования и второго преобразования могут быть разными. Например, первое преобразование может быть выполнено в отношении блока 8×8, а второе преобразование может быть выполнено в отношении подблока размером 4×4 из преобразованного блока 8×8. В этом случае коэффициенты преобразования остаточных участков, в отношении которых не было выполнено второе преобразование, могут быть установлены равными 0.[504] The elements for performing the first transformation and the second transformation may be different. For example, the first transformation may be performed on an 8x8 block, and the second transformation may be performed on a 4x4 subblock of the transformed 8x8 block. In this case, the transformation coefficients of the residual portions on which the second transformation has not been performed may be set to 0.
[505] Альтернативно первое преобразование может быть выполнено в отношении блока 4×4, а второе преобразование может быть выполнено в отношении участка размером 8×8, содержащего преобразованный блок 4×4.[505] Alternatively, the first transformation may be performed on the 4×4 block, and the second transformation may be performed on the 8×8 region containing the transformed 4×4 block.
[506] Информация, указывающая, было ли выполнено второе преобразование, может быть передана посредством битового потока.[506] Information indicating whether the second conversion has been performed may be transmitted via a bitstream.
[507] Альтернативно то, следует ли выполнять второе преобразование, может быть определено на основании того, являются ли одинаковыми основа преобразования в горизонтальном направлении и основа преобразования в вертикальном направлении. Например, второе преобразование может быть выполнено только тогда, когда основа преобразования в горизонтальном направлении и основа преобразования в вертикальном направлении являются одинаковыми. Альтернативно второе преобразование может быть выполнено только тогда, когда основа преобразования в горизонтальном направлении и основа преобразования в вертикальном направлении отличаются друг от друга.[507] Alternatively, whether or not to perform the second transformation can be determined based on whether the transformation basis in the horizontal direction and the transformation basis in the vertical direction are the same. For example, the second transformation can be performed only when the transformation base in the horizontal direction and the transformation base in the vertical direction are the same. Alternatively, the second transformation can be performed only when the transformation base in the horizontal direction and the transformation base in the vertical direction are different from each other.
[508] Альтернативно второе преобразование может быть допущено только тогда, когда преобразование в горизонтальном направлении и преобразование в вертикальном направлении используют предварительно заданную основу преобразования. Например, когда основа преобразования DCT2 используется для преобразования в горизонтальном направлении и преобразования в вертикальном направлении, второе преобразование может быть допущено.[508] Alternatively, the second transformation may be allowed only when the transformation in the horizontal direction and the transformation in the vertical direction use a predetermined transformation basis. For example, when the DCT2 transformation base is used for the transformation in the horizontal direction and the transformation in the vertical direction, the second transformation may be allowed.
[509] Альтернативно то, следует ли выполнять второе преобразование, может быть определено на основании количества ненулевых коэффициентов преобразования текущего блока. Например, может быть установлено не использовать второе преобразование, когда количество ненулевых коэффициентов преобразования текущего блока меньше, чем пороговое значение, или равняется ему, и может быть установлено использовать второе преобразование, когда количество ненулевых коэффициентов преобразования текущего блока больше, чем пороговое значение. Может быть установлено использовать второе преобразование только тогда, когда текущий блок кодирован с помощью внутреннего предсказания.[509] Alternatively, whether the second transform should be performed may be determined based on the number of non-zero transform coefficients of the current block. For example, it may be set not to use the second transform when the number of non-zero transform coefficients of the current block is less than or equal to the threshold, and may be set to use the second transform when the number of non-zero transform coefficients of the current block is greater than the threshold. It may be set to use the second transform only when the current block is encoded with intra prediction.
[510] На основании формы текущего блока, могут быть определены размер или форма подблока, в отношении которого будут выполнять второе преобразование.[510] Based on the shape of the current block, the size or shape of the sub-block on which the second transformation will be performed can be determined.
[511] На фиг.23 и 24 представлены виды, показывающие подблок, в отношении которого будут выполнять второе преобразование.[511] FIGS. 23 and 24 are views showing the sub-block on which the second transformation will be performed.
[512] Когда текущий блок имеет квадратную форму, второе преобразование может быть выполнено в отношении подблока, имеющего размер N×N, сверху слева от текущего блока после выполнения первого преобразования. Например, когда текущий блок представляет собой блок кодирования размером 8×8, второе преобразование может быть выполнено в отношении подблока, имеющего размер 4×4, сверху слева от текущего блока после выполнения первого преобразования в отношении текущего блока (см. фиг.23).[512] When the current block has a square shape, the second transformation may be performed on a sub-block having a size of N×N, from the top left of the current block after the first transformation is performed. For example, when the current block is an 8×8 coding block, a second transformation may be performed on a subblock having a size of 4×4 to the top left of the current block after the first transformation is performed on the current block (see FIG. 23).
[513] Когда текущий блок имеет неквадратную форму, ширина которой в по меньшей мере 4 раза больше, чем высота, второе преобразование может быть выполнено в отношении подблока размером (kN)×4 kN) сверху слева от текущего блока после выполнения первого преобразования. Например, когда текущий блок имеет неквадратную форму размером 16× 4, второе преобразование может быть выполнено в отношении подблока размером 2×8 сверху слева от текущего блока после выполнения первого преобразования в отношении текущего блока (см. фиг.24 (a)).[513] When the current block has a non-square shape, the width of which is at least 4 times greater than the height, the second transformation can be performed on a subblock of size (kN)×4 kN) from the top left of the current block after the first transformation is performed. For example, when the current block is 16×4 non-square, the second transformation may be performed on the 2×8 subblock from the top left of the current block after the first transformation is performed on the current block (see FIG. 24(a)).
[514] Когда текущий блок имеет неквадратную форму, высота которой в по меньшей мере 4 раза больше, чем ширина, второе преобразование может быть выполнено в отношении подблока размером (4 kN)×(kN) сверху слева от текущего блока после выполнения первого преобразования. Например, когда текущий блок имеет неквадратную форму размером 16×4, второе преобразование может быть выполнено в отношении подблока размером 2×8 сверху слева от текущего блока после выполнения первого преобразования в отношении текущего блока (см. фиг.24 (b)).[514] When the current block has a non-square shape, the height of which is at least 4 times greater than the width, the second transformation can be performed on the (4 kN)×(kN) subblock from the top left of the current block after the first transformation is performed. For example, when the current block is 16×4 non-square, the second transformation may be performed on the 2×8 subblock from the top left of the current block after the first transformation is performed on the current block (see FIG. 24(b)).
[515] Декодер может выполнять обратное преобразование второго преобразования (второе обратное преобразование) и может выполнять обратное преобразование первого преобразования (первое обратное преобразование) в отношении результата второго обратного преобразования. В результате выполнения второго обратного преобразования и первого обратного преобразования могут быть получены остаточные сигналы для текущего блока.[515] The decoder may perform an inverse transform of the second transform (second inverse transform), and may perform an inverse transformation of the first transform (first inverse transform) on the result of the second inverse transform. As a result of performing the second inverse transform and the first inverse transform, residual signals for the current block can be obtained.
[516][516]
[517] Информация, указывающая тип преобразования текущего блока, может быть передана посредством битового потока. Информация может представлять собой информацию об индексах tu_mts_idx, указывающую одну из комбинаций типа преобразования для горизонтального направления и типа преобразования для вертикального направления.[517] Information indicating the conversion type of the current block may be transmitted via a bitstream. The information may be tu_mts_idx index information indicating one of the combinations of a transformation type for the horizontal direction and a transformation type for the vertical direction.
[518] Основа преобразования для вертикального направления и основа преобразования для горизонтального направления могут быть определены на основании типов-кандидатов преобразования, указанных с помощью информации об индексах tu_mts_idx. В таблицах 7 и 8 показаны комбинации типов преобразования согласно tu_mts_idx.[518] A transformation basis for the vertical direction and a transformation basis for the horizontal direction may be determined based on the conversion candidate types indicated by the index information tu_mts_idx. Tables 7 and 8 show combinations of conversion types according to tu_mts_idx.
[519] [Таблица 7][519] [Table 7]
[520] [Таблица 8][520] [Table 8]
[521] Тип преобразования может быть определен как любое из следующих преобразований: DCT2, DST7, DCT8 и пропуск. Альтернативно комбинация-кандидат типов преобразования может быть составлена с использованием только основ преобразования, за исключением пропуска преобразования.[521] The type of transformation can be defined as any of the following transformations: DCT2, DST7, DCT8, and skip. Alternatively, a conversion type candidate combination may be composed using only the conversion stems, except for skipping the conversion.
[522] В случае, в котором используется таблица 7, когда tu_mts_idx равняется 0, пропуск преобразования может быть применен в горизонтальном направлении и вертикальном направлении. Когда tu_mts_idx равняется 1, DCT2 может быть применен в горизонтальном направлении и вертикальном направлении. Когда tu_mts_idx равняется 3, DCT8 может быть применен в горизонтальном направлении, и DCT7 может быть применен в вертикальном направлении.[522] In the case where table 7 is used, when tu_mts_idx is equal to 0, a conversion skip may be applied in the horizontal direction and the vertical direction. When tu_mts_idx is 1, DCT2 can be applied in the horizontal direction and the vertical direction. When tu_mts_idx is 3, DCT8 may be applied in the horizontal direction and DCT7 may be applied in the vertical direction.
[523] В случае, в котором используется таблица 8, когда tu_mts_idx равняется 0, DCT2 может быть применен в горизонтальном направлении и вертикальном направлении. Когда tu_mts_idx равняется 1, пропуск преобразования может быть применен в горизонтальном направлении и вертикальном направлении. Когда tu_mts_idx равняется 3, DCT8 может быть применен в горизонтальном направлении, и DCT7 может быть применен в вертикальном направлении.[523] In the case where table 8 is used, when tu_mts_idx is 0, DCT2 can be applied in the horizontal direction and the vertical direction. When tu_mts_idx is equal to 1, a transform skip can be applied in the horizontal direction and the vertical direction. When tu_mts_idx is 3, DCT8 may be applied in the horizontal direction and DCT7 may be applied in the vertical direction.
[524] То, следует ли кодировать информацию об индексах, может быть определено на основании по меньшей мере одного из размера, формы и количества ненулевых коэффициентов текущего блока. Например, когда количество ненулевых коэффициентов равняется пороговому значению или меньше него, информация об индексах не передается, и тип преобразования по умолчанию может быть применен к текущему блоку. В данном случае тип преобразования по умолчанию может представлять собой DST7. Альтернативно режим по умолчанию может меняться согласно размеру, форме или режиму внутреннего предсказания текущего блока.[524] Whether or not the index information should be encoded may be determined based on at least one of the size, shape, and number of non-zero coefficients of the current block. For example, when the number of non-zero coefficients is equal to or less than a threshold value, no index information is transmitted, and a default transform type can be applied to the current block. In this case, the default conversion type may be DST7. Alternatively, the default mode may change according to the size, shape, or intra prediction mode of the current block.
[525] Пороговое значение может быть определено на основании размера или формы текущего блока. Например, когда размер текущего блока меньше чем 32×32 или равняется этому размеру, пороговое значение может быть установлено равным 2, а когда текущий блок больше чем 32×32 (например, когда текущий блок представляет собой блок кодирования размером 32×64 или 64×32), пороговое значение может быть установлено равным 4.[525] The threshold value may be determined based on the size or shape of the current block. For example, when the size of the current block is less than or equal to 32x32, the threshold may be set to 2, and when the current block is greater than 32x32 (for example, when the current block is a 32x64 or 64x32 coding block), the threshold may be set to 4.
[526] Множество таблиц поиска могут быть ранее сохранены в кодере/декодере. Во множестве таблиц поиска по меньшей мере одно из индексного значения, присвоенного комбинациям-кандидатам типов преобразования, типа комбинаций-кандидатов типов преобразования и количества комбинаций-кандидатов типов преобразования может быть отличным.[526] A plurality of lookup tables may be previously stored in the encoder/decoder. In the plurality of lookup tables, at least one of the index value assigned to the conversion type combination candidates, the conversion type combination candidate type, and the number of conversion type combination candidates may be different.
[527] Таблица поиска для текущего блока может быть выбрана на основании по меньшей мере одного из размера текущего блока, формы текущего блока, режима кодирования с предсказанием текущего блока, режима внутреннего предсказания текущего блока, того, применено ли второе преобразование, и того, применен ли пропуск преобразования к соседнему блоку.[527] The lookup table for the current block may be selected based on at least one of the size of the current block, the shape of the current block, the predictive coding mode of the current block, the intra prediction mode of the current block, whether a second transform has been applied, and whether a skip transform has been applied to an adjacent block.
[528] Например, когда размер текущего блока составляет 4×4 или меньше или когда текущий блок кодирован с помощью предсказания, осуществляемого между изображениями, может быть использована таблица поиска по таблице 7, а когда размер текущего блока больше чем 4×4, или когда текущий блок кодирован с помощью внутреннего предсказания, может быть использована таблица поиска по таблице 8.[528] For example, when the size of the current block is 4x4 or less, or when the current block is encoded with inter-picture prediction, a lookup table of table 7 can be used, and when the size of the current block is larger than 4x4, or when the current block is encoded with intra prediction, a lookup table of table 8 can be used.
[529] Альтернативно информация, указывающая любую из множества таблиц поиска, может быть передана посредством битового потока. Декодер может выбирать таблицу поиска для текущего блока на основании информации.[529] Alternatively, information indicative of any of a plurality of lookup tables may be transmitted via a bitstream. The decoder may select a lookup table for the current block based on the information.
[530] В качестве еще одного примера индекс, присвоенный комбинации-кандидату типов преобразования, может быть адаптивно определен на основании по меньшей мере одного из размера текущего блока, формы текущего блока, режима кодирования с предсказанием текущего блока, режима внутреннего предсказания текущего блока, того, применено ли второе преобразование, и того, применен ли пропуск преобразования к соседнему блоку. Например, когда размер текущего блока составляет 4×4, индекс, присвоенный пропуску преобразования, может иметь значение, которое меньше, чем значение индекса, присвоенного пропуску преобразования, когда размер текущего блока больше чем 4×4. В частности, когда размер текущего блока составляет 4×4, индекс 0 может быть присвоен пропуску преобразования, а когда текущий блок больше чем 4×4 и меньше чем 16×16 или равняется этому размеру, индекс, который больше чем 0 (например, индекс 1), может быть присвоен пропуску преобразования. Когда текущий блок больше чем 16×16, максимальное значение (например, 5) может быть присвоено индексу пропуска преобразования.[530] As another example, an index assigned to a candidate combination of transform types can be adaptively determined based on at least one of the size of the current block, the shape of the current block, the predictive coding mode of the current block, the intra prediction mode of the current block, whether a second transform has been applied, and whether a skip transform has been applied to an adjacent block. For example, when the size of the current block is 4×4, the index assigned to the transform skip may have a value that is less than the value of the index assigned to the transform skip when the size of the current block is greater than 4×4. In particular, when the size of the current block is 4x4, index 0 may be assigned to a transformation skip, and when the current block is greater than or equal to 4x4 and less than or equal to 16x16, an index greater than 0 (e.g., index 1) may be assigned to a transformation skip. When the current block is larger than 16×16, a maximum value (eg, 5) may be assigned to the transform skip index.
[531] Альтернативно, когда текущий блок кодирован с помощью предсказания, осуществляемого между изображениями, индекс 0 может быть присвоен пропуску преобразования. Когда текущий блок кодирован с помощью внутреннего предсказания, индекс, который больше чем 0 (например, индекс 1), может быть присвоен пропуску преобразования.[531] Alternatively, when the current block is encoded with inter-picture prediction, index 0 may be assigned to a transform skip. When the current block is encoded with intra prediction, an index that is greater than 0 (eg, index 1) may be assigned to a transform skip.
[532] Альтернативно, когда текущий блок представляет собой блок размером 4×4, кодированный с помощью предсказания, осуществляемого между изображениями, индекс 0 может быть присвоен пропуску преобразования. С другой стороны, когда текущий блок не кодирован с помощью предсказания, осуществляемого между изображениями, или текущий блок больше чем 4×4, индекс со значением, которое больше чем 0 (например, индекс 1), может быть присвоен пропуску преобразования.[532] Alternatively, when the current block is a 4x4 block encoded with inter-picture prediction, index 0 may be assigned to a transform skip. On the other hand, when the current block is not encoded with inter-picture prediction or the current block is larger than 4×4, an index with a value greater than 0 (eg, index 1) may be assigned to a transform skip.
[533] Могут быть определены и использованы комбинации-кандидаты типов преобразования, отличные от комбинаций-кандидатов типов преобразования, перечисленных в таблицах 7 и 8. Например, может быть использована комбинация-кандидат типов преобразования, в которой пропуск преобразования применяется к любому одному из преобразования в горизонтальном направлении и преобразования в вертикальном направлении, и основа преобразования, такая как DCT7, DCT8 или DST2, применяется к другому. В это время то, следует ли использовать пропуск преобразования как тип-кандидат преобразования для горизонтального направления или вертикального направления, может быть определено на основании по меньшей мере одного из размера (например, ширины и/или высоты), формы, режима кодирования с предсказанием и режима внутреннего предсказания текущего блока.[533] Candidate transformation type combinations other than the transformation type combinations listed in Tables 7 and 8 can be defined and used. For example, a transformation type candidate combination can be used in which a transformation skip is applied to any one of a transformation in the horizontal direction and a transformation in the vertical direction, and a transformation basis such as DCT7, DCT8, or DST2 is applied to the other. At this time, whether a transform skip should be used as a transform candidate type for the horizontal direction or the vertical direction may be determined based on at least one of the size (e.g., width and/or height), shape, predictive coding mode, and intra prediction mode of the current block.
[534] Альтернативно информация, указывающая то, доступен ли конкретный тип-кандидат преобразования, может быть передана посредством битового потока. Например, может быть передан флаг, указывающий то, может ли быть использован пропуск преобразования как тип-кандидат преобразования для горизонтального направления и вертикального направления. Согласно флагу может быть определено то, включена ли конкретная комбинация-кандидат типов преобразования во множество комбинаций-кандидатов типов преобразования.[534] Alternatively, information indicating whether a particular conversion candidate type is available may be transmitted via a bitstream. For example, a flag may be passed indicating whether a conversion skip can be used as a conversion candidate type for the horizontal direction and the vertical direction. According to the flag, it can be determined whether a particular conversion type combination candidate is included in the set of conversion type candidate combinations.
[535] Альтернативно то, применяется ли указанный тип-кандидат преобразования к текущему блоку, может быть передано посредством битового потока. Например, может быть передан флаг cu_mts_flag, указывающий то, следует ли применять DCT2 для горизонтального направления и вертикального направления. Когда значение cu_mts_flag равняется 1, DCT2 может быть установлен как основа преобразования для вертикального направления и горизонтального направления. Когда значение cu_mts_flag равняется 0, DCT8 или DST7 может быть установлен как основа преобразования для вертикального направления и горизонтального направления. Альтернативно, когда значение cu_mts_flag равняется 0, может быть передана информация tu_mts_idx, указывающая любую из множества комбинаций-кандидатов типов преобразования.[535] Alternatively, whether the specified transformation candidate type applies to the current block may be transmitted via a bitstream. For example, a cu_mts_flag flag may be transmitted indicating whether DCT2 should be applied for the horizontal direction and the vertical direction. When the value of cu_mts_flag is 1, DCT2 can be set as the basis of the transformation for the vertical direction and the horizontal direction. When the value of cu_mts_flag is 0, DCT8 or DST7 can be set as the conversion base for vertical direction and horizontal direction. Alternatively, when the value of cu_mts_flag is 0, tu_mts_idx information indicating any one of a plurality of candidate conversion type combinations may be transmitted.
[536] Когда текущий блок имеет неквадратную форму, ширина которой больше, чем высота, или неквадратную форму, высота которой больше, чем ширина, кодирование cu_mts_flag может быть пропущено, и значение cu_mts_flag может быть расценено как 0.[536] When the current block has a non-square shape whose width is greater than the height, or a non-square shape whose height is greater than the width, the cu_mts_flag encoding may be omitted, and the value of cu_mts_flag may be regarded as 0.
[537] Количество доступных комбинаций-кандидатов типов преобразования может быть установлено по-разному согласно размеру, форме или режиму внутреннего предсказания текущего блока. Например, когда текущий блок имеет квадратную форму, могут быть использованы три или более комбинаций-кандидатов типов преобразования, а когда текущий блок имеет неквадратную форму, могут быть использованы две комбинации-кандидата типов преобразования. Альтернативно, когда текущий блок имеет квадратную форму, только комбинации-кандидаты типов преобразования, тип преобразования для горизонтального направления которых отличается от типа преобразования для вертикального направления, могут быть использованы из комбинаций-кандидатов типов преобразования.[537] The number of available candidate transform type combinations may be set differently according to the size, shape, or intra prediction mode of the current block. For example, when the current block is square, three or more candidate transformation type combinations may be used, and when the current block is non-square, two candidate transformation type combinations may be used. Alternatively, when the current block has a square shape, only candidate transformation type combinations whose transformation type for the horizontal direction is different from the transformation type for the vertical direction can be used from among the candidate transformation type combinations.
[538] Когда имеются три или более комбинаций-кандидатов типов преобразования, которые может использовать текущий блок, может быть передана информация об индексах tu_mts_idx, указывающая одну из комбинаций-кандидатов типов преобразования. С другой стороны, когда имеются две комбинации-кандидата типов преобразования, которые может использовать текущий блок, может быть передан флаг mts_flag, указывающий любую из комбинаций-кандидатов типов преобразования. В таблице 9 показан процесс кодирования информации для указания комбинаций-кандидатов типов преобразования согласно форме текущего блока.[538] When there are three or more candidate transformation type combinations that the current block can use, tu_mts_idx index information indicating one of the candidate transformation type combinations may be transmitted. On the other hand, when there are two candidate transformation type combinations that the current block can use, an mts_flag flag indicating either of the candidate transformation type combinations may be transmitted. Table 9 shows a process for encoding information for indicating candidate combinations of transformation types according to the shape of the current block.
[539] [Таблица 9][539] [Table 9]
[540] Индексы комбинаций-кандидатов типов преобразования могут быть переставлены (или переупорядочены) согласно форме текущего блока. Например, индексы, присвоенные комбинациям-кандидатам типов преобразования, когда текущий блок имеет квадратную форму, могут отличаться от индексов, присвоенных комбинациям-кандидатам типов преобразования, когда текущий блок имеет неквадратную форму. Например, когда текущий блок имеет квадратную форму, комбинация типов преобразования может быть выбрана на основании таблицы 10, показанной ниже, а когда текущий блок имеет неквадратную форму, комбинация типов преобразования может быть выбрана на основании таблицы 11, показанной ниже.[540] The conversion type candidate combination indices may be permuted (or reordered) according to the shape of the current block. For example, the indices assigned to candidate transformation type combinations when the current block is square may be different from the indices assigned to candidate transformation type combinations when the current block is non-square. For example, when the current block is square, the transform type combination may be selected based on Table 10 shown below, and when the current block is non-square, the transform type combination may be selected based on Table 11 shown below.
[541] [Таблица 10][541] [Table 10]
[542] [Таблица 11][542] [Table 11]
[543] Тип преобразования может быть определен на основании количества ненулевых коэффициентов в горизонтальном направлении или количества ненулевых коэффициентов в вертикальном направлении текущего блока. В данном случае количество ненулевых коэффициентов в горизонтальном направлении указывает количество ненулевых коэффициентов, включенных в блок 1×N (где N представляет собой ширину текущего блока), и количество ненулевых коэффициентов в вертикальном направлении указывает количество ненулевых коэффициентов, включенных в блок N×1 (где N представляет собой высоту текущего блока). Когда максимальное значение ненулевого коэффициента в горизонтальном направлении меньше, чем пороговое значение, или равняется ему, первый тип преобразования может быть применен в горизонтальном направлении, а когда максимальное значение ненулевого коэффициента в горизонтальном направлении больше, чем пороговое значение, второй тип преобразования может быть применен в горизонтальном направлении. Когда максимальное значение ненулевого коэффициента в вертикальном направлении меньше, чем пороговое значение, или равняется ему, первый тип преобразования может быть применен в вертикальном направлении, а когда максимальное значение ненулевого коэффициента в вертикальном направлении больше, чем пороговое значение, второй тип преобразования может быть применен в вертикальном направлении.[543] The transform type may be determined based on the number of non-zero coefficients in the horizontal direction or the number of non-zero coefficients in the vertical direction of the current block. Here, the number of non-zero coefficients in the horizontal direction indicates the number of non-zero coefficients included in the 1×N block (where N is the width of the current block), and the number of non-zero coefficients in the vertical direction indicates the number of non-zero coefficients included in the N×1 block (where N is the height of the current block). When the maximum value of the non-zero coefficient in the horizontal direction is less than or equal to the threshold value, the first transformation type may be applied in the horizontal direction, and when the maximum value of the non-zero coefficient in the horizontal direction is greater than the threshold value, the second transformation type may be applied in the horizontal direction. When the maximum value of the non-zero coefficient in the vertical direction is less than or equal to the threshold value, the first type of transformation may be applied in the vertical direction, and when the maximum value of the non-zero coefficient in the vertical direction is greater than the threshold value, the second type of transformation may be applied in the vertical direction.
[544] На фиг.25 представлен вид для описания примеров определения типа преобразования текущего блока.[544] Fig. 25 is a view for describing examples of determining the conversion type of the current block.
[545] Например, когда текущий блок кодирован с помощью внутреннего предсказания, и максимальное значение ненулевого коэффициента в горизонтальном направлении текущего блока равняется 2 или меньше (см. фиг.25 (a)), тип преобразования в горизонтальном направлении может быть определен как DST7.[545] For example, when the current block is encoded with intra prediction, and the maximum value of the non-zero coefficient in the horizontal direction of the current block is 2 or less (see FIG. 25(a)), the transform type in the horizontal direction can be determined as DST7.
[546] Когда текущий блок кодирован с помощью внутреннего предсказания, и максимальное значение ненулевого коэффициента в вертикальном направлении текущего блока больше чем 2 (см. фиг.25 (b)), DCT2 или DCT8 может быть определен как тип преобразования в вертикальном направлении.[546] When the current block is encoded with intra prediction, and the maximum value of the non-zero coefficient in the vertical direction of the current block is greater than 2 (see FIG. 25(b)), DCT2 or DCT8 may be determined as the transform type in the vertical direction.
[547][547]
[548] Информация, указывающая то, следует ли в явном виде определять тип преобразования текущего блока на основании информации, переданной из битового потока, может быть передана посредством битового потока. Например, информация sps_explicit_intra_mts_flag, указывающая то, допускается ли определение в явном виде типа преобразования для блока, кодированного с помощью внутреннего предсказания, и/или информация sps_explicit_inter_mts_flag, указывающая то, допускается ли определение в явном виде типа преобразования для блока, кодированного с помощью предсказания, осуществляемого между изображениями, могут быть переданы на уровне последовательности.[548] Information indicating whether to explicitly determine the conversion type of the current block based on the information transmitted from the bitstream may be transmitted by the bitstream. For example, sps_explicit_intra_mts_flag information indicating whether explicit definition of a transform type for an intra prediction encoded block and/or sps_explicit_inter_mts_flag information indicating whether explicit definition of a transformation type for an inter-picture encoded block is allowed can be transmitted at the sequence level.
[549] Когда допускается определение в явном виде типа преобразования, тип преобразования текущего блока может быть определен на основании информации об индексах tu_mts_idx, переданной из битового потока. С другой стороны, когда определение в явном виде типа преобразования не допускается, тип преобразования может быть определен на основании по меньшей мере одного из размера текущего блока, формы текущего блока, того, допускается ли преобразование элемента подблока, и положения подблока, содержащего ненулевой коэффициент преобразования. Например, тип преобразования в горизонтальном направлении текущего блока может быть определен на основании ширины текущего блока, и тип преобразования в вертикальном направлении текущего блока может быть определен на основании высоты текущего блока. Например, когда ширина текущего блока меньше чем 4 или больше чем 16, тип преобразования в горизонтальном направлении может быть определен как DCT2. В ином случае тип преобразования в горизонтальном направлении может быть определен как DST7. Когда высота текущего блока меньше чем 4 или больше чем 16, тип преобразования в вертикальном направлении может быть определен как DCT2. В ином случае тип преобразования в вертикальном направлении может быть определен как DST7. В данном случае, чтобы определить тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении, пороговые значения, сравнимые с шириной и высотой, могут быть определены на основании по меньшей мере одного из размера, формы и режима внутреннего предсказания текущего блока.[549] When it is allowed to explicitly define the transformation type, the transformation type of the current block may be determined based on the tu_mts_idx index information transmitted from the bitstream. On the other hand, when explicitly determining the type of transformation is not allowed, the type of transformation can be determined based on at least one of the size of the current block, the shape of the current block, whether the transformation of a sub-block element is allowed, and the position of the sub-block containing a non-zero transformation coefficient. For example, the transformation type in the horizontal direction of the current block may be determined based on the width of the current block, and the transformation type in the vertical direction of the current block may be determined based on the height of the current block. For example, when the width of the current block is less than 4 or greater than 16, the transformation type in the horizontal direction may be determined as DCT2. Otherwise, the conversion type in the horizontal direction can be defined as DST7. When the height of the current block is less than 4 or greater than 16, the transformation type in the vertical direction can be specified as DCT2. Otherwise, the conversion type in the vertical direction can be defined as DST7. Here, in order to determine the transform type in the horizontal direction and the transform type in the vertical direction, threshold values comparable to the width and height may be determined based on at least one of the size, shape, and intra prediction mode of the current block.
[550] Альтернативно, когда текущий блок имеет квадратную форму, высота и ширина которой являются одинаковыми, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении установлены так, чтобы быть одинаковыми, тогда как когда текущий блок имеет неквадратную форму, высота и ширина которой являются разными, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены так, чтобы отличаться друг от друга. Например, когда ширина текущего блока больше, чем высота, тип преобразования в горизонтальном направлении может быть определен как DST7, и тип преобразования в вертикальном направлении может быть определен как DCT2. Когда высота текущего блока больше, чем ширина, тип преобразования в вертикальном направлении может быть определен как DST7, и тип преобразования в горизонтальном направлении может быть определен как DCT2.[550] Alternatively, when the current block has a square shape whose height and width are the same, the transformation type in the horizontal direction and the transformation type in the vertical direction are set to be the same, while when the current block has a non-square shape whose height and width are different, the transformation type in the horizontal direction and the transformation type in the vertical direction can be set to be different from each other. For example, when the width of the current block is larger than the height, the transformation type in the horizontal direction may be determined as DST7, and the transformation type in the vertical direction may be determined as DCT2. When the height of the current block is larger than the width, the transformation type in the vertical direction may be determined as DST7, and the transformation type in the horizontal direction may be determined as DCT2.
[551] Количество и/или тип типов-кандидатов преобразования или количество и/или тип комбинаций-кандидатов типов преобразования могут меняться согласно тому, допускается ли определение в явном виде типа преобразования. Например, когда допускается определение в явном виде типа преобразования, DCT2, DST7 и DCT8 могут быть использованы как типы-кандидаты преобразования. Соответственно, каждый из типа преобразования в горизонтальном направлении и типа преобразования в вертикальном направлении может быть установлен равным DCT2, DST8 или DCT8. Когда определение в явном виде типа преобразования не допускается, только DCT2 и DST7 могут быть использованы как типы-кандидаты преобразования. Соответственно, каждый из типа преобразования в горизонтальном направлении и типа преобразования в вертикальном направлении может быть определен как DCT2 или DST7.[551] The number and/or type of conversion candidate types or the number and/or type of conversion type candidate combinations may vary according to whether explicit definition of the conversion type is allowed. For example, when explicitly specifying a conversion type is allowed, DCT2, DST7, and DCT8 can be used as candidate conversion types. Accordingly, each of the horizontal direction conversion type and the vertical direction conversion type can be set to DCT2, DST8, or DCT8. When an explicit definition of a conversion type is not allowed, only DCT2 and DST7 can be used as candidate conversion types. Accordingly, each of the horizontal direction conversion type and the vertical direction conversion type can be defined as DCT2 or DST7.
[552] Блок кодирования или блок преобразования разбивается на множество подблоков, и преобразование может быть выполнено в отношении каждого из множества подблоков. Например, когда способ кодирования с внутренним предсказанием с подразбиением, описанный выше, применяется к блоку кодирования, блок кодирования разбивается на множество подблоков, и преобразование может быть выполнено в отношении каждого из множества подблоков.[552] A coding block or a transformation block is partitioned into a plurality of sub-blocks, and a transformation may be performed on each of the plurality of sub-blocks. For example, when the subdivision intra prediction coding method described above is applied to a coding block, the coding block is partitioned into a plurality of subblocks, and a transformation can be performed on each of the plurality of subblocks.
[553] Типы преобразования подблоков могут быть одинаковыми. Например, когда определяется тип преобразования для первого подблока из множества подблоков, тип преобразования первого подблока может также быть применен к другим подблокам. Альтернативно определяется тип преобразования для блока кодирования, и тип преобразования блока кодирования может быть определен как тип преобразования подблоков.[553] The sub-block conversion types may be the same. For example, when a transform type is determined for the first sub-block of a plurality of sub-blocks, the first sub-block transform type may also be applied to other sub-blocks. Alternatively, a transform type for a coding block is determined, and a transform type of the coding block may be defined as a sub-block transform type.
[554] В качестве еще одного примера типы преобразования из множества подблоков могут быть определены по отдельности. Тип преобразования каждого подблока может быть определен на основании информации, переданной для каждого подблока. Например, информация об индексах tu_mts_idx может быть передана для каждого подблока. Информация об индексах tu_mts_idx может указывать любую из множества комбинаций типа преобразования для горизонтального направления и типа преобразования для вертикального направления. Согласно значению tu_mts_idx тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть определены как DCT2, DST7 или DCT8. На основании информации об индексах tu_mts_idx может быть определено то, являются ли одинаковыми тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении.[554] As another example, conversion types from a plurality of sub-blocks may be individually determined. The transformation type of each sub-block may be determined based on the information transmitted for each sub-block. For example, index information tu_mts_idx may be transmitted for each sub-block. The index information tu_mts_idx may indicate any of a plurality of combinations of a transform type for the horizontal direction and a transform type for the vertical direction. According to the value of tu_mts_idx, the transformation type in the horizontal direction and the transformation type in the vertical direction can be defined as DCT2, DST7, or DCT8. Based on the index information tu_mts_idx, it can be determined whether the transformation type in the horizontal direction and the transformation type in the vertical direction are the same.
[555] Может быть передана информация, указывающая то, использует ли текущий подблок тип преобразования, который является таким же, как тип преобразования предыдущего подблока. Когда информация указывает, что используется тип преобразования, который является таким же, как у предыдущего подблока, кодирование информации об индексах tu_mts_idx для текущего подблока может быть пропущено, и тип преобразования предыдущего подблока может быть применен к текущему подблоку. С другой стороны, когда информация указывает, что используется тип преобразования, который отличается от того, который у предыдущего подблока, информация об индексах tu_mts_idx для текущего подблока может быть кодирована. В этом случае информация об индексах текущего подблока может указывать любую из оставшихся комбинаций типов преобразования, за исключением комбинации типов преобразования, указанной с помощью информации об индексах предыдущего подблока.[555] Information indicating whether the current sub-block uses a transform type that is the same as the previous sub-block's transform type may be transmitted. When the information indicates that a transform type is used that is the same as that of the previous sub-block, the encoding of the tu_mts_idx index information for the current sub-block may be skipped, and the transform type of the previous sub-block may be applied to the current sub-block. On the other hand, when the information indicates that a transform type is used that is different from that of the previous sub-block, the tu_mts_idx index information for the current sub-block may be encoded. In this case, the index information of the current sub-block may indicate any of the remaining combinations of transformation types except for the combination of transformation types indicated by the index information of the previous sub-block.
[556] Альтернативно может быть установлено не допускать определение в явном виде типа преобразования, когда блок кодирования разбит на множество подблоков. Когда допускается определение в явном виде типа преобразования, тип преобразования может быть определен на основании информации об индексах tu_mts_idx. С другой стороны, когда определение в явном виде типа преобразования не допускается, тип преобразования может быть определен с учетом по меньшей мере одного из размера, формы и положения подблока, содержащего ненулевой коэффициент.[556] Alternatively, it may be set to not allow explicit definition of the transform type when a coding block is split into multiple sub-blocks. When explicit definition of the type of transformation is allowed, the type of transformation may be determined based on information about the indexes tu_mts_idx. On the other hand, when explicit definition of the type of transformation is not allowed, the type of transformation can be determined considering at least one of the size, shape, and position of the sub-block containing the non-zero coefficient.
[557] На фиг.26 представлен вид, показывающий пример определения типа преобразования подблока.[557] FIG. 26 is a view showing an example of determining a sub-block transformation type.
[558] На фиг.26 показан пример, в котором соотношение высоты и ширины подблока составляет 1: 2 или 2: 1.[558] FIG. 26 shows an example in which the height to width ratio of the subblock is 1:2 or 2:1.
[559] Тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть определены на основании ширины и высоты каждого подблока. Например, как показано в примерах на фиг.26 (a) и 26 (b), когда ширина подблока меньше, чем пороговое значение, первый тип преобразования (например, DCT2) может быть использован как тип преобразования в горизонтальном направлении. С другой стороны, когда ширина подблока больше, чем пороговое значение, или равняется ему, второй тип преобразования (например, DST7) может быть использован как тип преобразования в горизонтальном направлении.[559] A transformation type in the horizontal direction and a transformation type in the vertical direction may be determined based on the width and height of each sub-block. For example, as shown in the examples in FIGS. 26(a) and 26(b), when the sub-block width is smaller than the threshold value, the first transform type (eg, DCT2) can be used as the transform type in the horizontal direction. On the other hand, when the sub-block width is greater than or equal to the threshold value, the second transform type (eg, DST7) can be used as the transform type in the horizontal direction.
[560] Кроме того, когда высота подблока меньше, чем пороговое значение, первый тип преобразования (например, DCT2) может быть использован как тип преобразования в вертикальном направлении. С другой стороны, когда ширина подблока больше, чем пороговое значение, или равняется ему, второй тип преобразования (например, DST7) может быть использован как тип преобразования в вертикальном направлении.[560] In addition, when the sub-block height is less than the threshold value, the first transform type (eg, DCT2) can be used as the transform type in the vertical direction. On the other hand, when the sub-block width is greater than or equal to the threshold value, the second transform type (eg, DST7) can be used as the transform type in the vertical direction.
[561] В данном случае пороговое значение может представлять собой натуральное число, такое как 2, 4 или 8. Пороговое значение может быть переменным образом определено на основании по меньшей мере одного из размера, формы, режима внутреннего предсказания и режима кодирования с предсказанием блока кодирования. Альтернативно информация для определения порогового значения может быть передана посредством битового потока.[561] Here, the threshold may be a natural number such as 2, 4, or 8. The threshold may be variably determined based on at least one of the size, shape, intra prediction mode, and coding block predictive coding mode. Alternatively, the information for determining the threshold value may be transmitted via a bit stream.
[562] В примере, описанном выше, хотя случай сравнения ширины и высоты подблока с одним пороговым значением показан как пример, тип преобразования может быть определен путем сравнения ширины и высоты подблока с двумя пороговыми значениями. Например, когда ширина подблока меньше, чем первое пороговое значение, или больше, чем второе пороговое значение, тип преобразования в горизонтальном направлении может быть определен как DCT2. В ином случае тип преобразования в горизонтальном направлении может быть определен как DST7. Кроме того, когда высота подблока меньше, чем первое пороговое значение, или больше, чем второе пороговое значение, тип преобразования в вертикальном направлении может быть определен как DCT2. В ином случае тип преобразования в вертикальном направлении может быть определен как DST7. Второй порог представляет собой натуральное число, которое больше, чем первое пороговое значение, и первое пороговое значение может представлять собой натуральное число, такое как 2, 4 или 8, и второе пороговое значение может представлять собой натуральное число, такое как 8, 16 или 32.[562] In the example described above, although the case of comparing the sub-block width and height with one threshold value is shown as an example, the transform type can be determined by comparing the sub-block width and height with two threshold values. For example, when the sub-block width is smaller than the first threshold or larger than the second threshold, the transform type in the horizontal direction may be determined as DCT2. Otherwise, the conversion type in the horizontal direction can be defined as DST7. Further, when the sub-block height is smaller than the first threshold value or larger than the second threshold value, the transform type in the vertical direction may be determined as DCT2. Otherwise, the conversion type in the vertical direction can be defined as DST7. The second threshold is a natural number that is greater than the first threshold, and the first threshold may be a natural number such as 2, 4, or 8, and the second threshold may be a natural number, such as 8, 16, or 32.
[563] В качестве еще одного примера, когда подблок имеет квадратную форму, высота и ширина которой являются одинаковыми, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены так, чтобы быть одинаковыми, тогда как когда подблок имеет неквадратную форму, высота и ширина которой являются разными, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены так, чтобы отличаться друг от друга. Например, когда ширина подблока больше, чем высота, тип преобразования в горизонтальном направлении может быть определен как DST7, и тип преобразования в вертикальном направлении может быть определен как DCT2. Когда высота подблока больше, чем ширина, тип преобразования в вертикальном направлении может быть определен как DST7, и тип преобразования в горизонтальном направлении может быть определен как DCT2.[563] As another example, when the sub-block has a square shape whose height and width are the same, the transformation type in the horizontal direction and the transformation type in the vertical direction can be set to be the same, while when the sub-block has a non-square shape whose height and width are different, the transformation type in the horizontal direction and the transformation type in the vertical direction can be set to be different from each other. For example, when the width of the sub-block is larger than the height, the transformation type in the horizontal direction may be determined as DST7, and the transformation type in the vertical direction may be determined as DCT2. When the height of the sub-block is larger than the width, the transformation type in the vertical direction may be determined as DST7, and the transformation type in the horizontal direction may be determined as DCT2.
[564] Значения остаточных коэффициентов, включенных в по меньшей мере один из множества подблоков, могут быть установлены равными 0. В данном случае остаточный коэффициент относится к коэффициенту преобразования, сгенерированному посредством преобразования, коэффициенту пропуска преобразования, сгенерированному посредством пропуска преобразования, или квантованному коэффициенту, сгенерированному путем квантования коэффициента преобразования или коэффициента. Например, значения остаточных коэффициентов, включенных в подблок, разнесенный от границы блока кодирования на предварительно определенное расстояние или больше, могут быть установлены равными 0.[564] The values of the residual coefficients included in at least one of the plurality of sub-blocks may be set to 0. Here, the residual coefficient refers to a transform coefficient generated by a transform, a transform skip coefficient generated by a transform skip, or a quantized coefficient generated by quantizing a transform coefficient or coefficient. For example, the values of the residual coefficients included in a subblock spaced from a coding block boundary by a predetermined distance or more may be set to 0.
[565] На фиг.27 представлен вид для описания примера, в котором остаточные коэффициенты подблоков устанавливают равными 0.[565] FIG. 27 is a view for describing an example in which the subblock residual coefficients are set to 0.
[566] В примере, показанном на фиг.27, флаг кодированного блока (CBF) указывает то, имеется ли ненулевой остаточный коэффициент в подблоке. Когда значение CBF равняется 0, это указывает, что ненулевой остаточный коэффициент отсутствует в подблоке, а когда значение CBF равняется 1, это указывает, что имеется ненулевой остаточный коэффициент в подблоке.[566] In the example shown in FIG. 27, the coded block flag (CBF) indicates whether there is a non-zero residual coefficient in the subblock. When the CBF value is 0, it indicates that there is no non-zero residual coefficient in the sub-block, and when the CBF value is 1, it indicates that there is a non-zero residual coefficient in the sub-block.
[567] Когда расстояние от границы блока кодирования до подблока больше, чем пороговое значение, или равняется ему, остаточные коэффициенты, включенные в подблок, могут быть установлены равными 0. В этом случае расстояние от границы блока кодирования до подблока может быть получено на основании первого отсчета, расположенного на границе блока кодирования, и второго отсчета, включенного в подблок. Например, первый отсчет может представлять собой отсчет, расположенный в верхнем левом углу блока кодирования, отсчет, расположенный в нижнем левом углу, отсчет, расположенный слева посередине, отсчет, расположенный в верхнем правом углу, отсчет, расположенный в нижнем правом углу, отсчет, расположенный справа посередине, отсчет, расположенный сверху посередине, и отсчет, расположенный снизу посередине. Второй отсчет может представлять собой отсчет, расположенный в верхнем левом углу подблока, отсчет, расположенный в нижнем левом углу, отсчет, расположенный слева посередине, отсчет, расположенный в верхнем правом углу, отсчет, расположенный в нижнем правом углу, отсчет, расположенный справа посередине, отсчет, расположенный сверху посередине, и отсчет, расположенный снизу посередине.[567] When the distance from the coding block boundary to the subblock is greater than or equal to the threshold value, the residual coefficients included in the subblock may be set to 0. In this case, the distance from the coding block boundary to the subblock may be obtained based on the first sample located on the coding block boundary and the second sample included in the subblock. For example, the first sample may be the sample located in the upper left corner of the coding block, the sample located in the lower left corner, the sample located in the left middle, the sample located in the upper right corner, the sample located in the lower right corner, the sample located in the right middle, the sample located in the upper middle, and the sample located in the lower middle. The second sample may be the sample located in the top left corner of the subblock, the sample located in the lower left corner, the sample located in the left middle, the sample located in the upper right corner, the sample located in the lower right corner, the sample located in the right middle, the sample located in the upper middle, and the sample located in the lower middle.
[568] Пороговое значение может быть определено на основании по меньшей мере одного из размера и формы блока кодирования, количества подблоков, включенных в блок кодирования, и размера подблока. Альтернативно информация для определения порогового значения может быть передана посредством битового потока.[568] The threshold value may be determined based on at least one of the size and shape of the coding block, the number of subblocks included in the coding block, and the size of the subblock. Alternatively, the information for determining the threshold value may be transmitted via a bitstream.
[569] Например, когда разбиение в вертикальном направлении применяется к текущему блоку, остаточные коэффициенты подблоков, расстояние от левой границы блока кодирования которых равняется пороговому значению или больше него, могут быть установлены равными 0. Когда размер блока кодирования равняется 64, и пороговое значение равняется 32, как показано в примере на фиг.27 (a), остаточные коэффициенты подблоков (Sub-CU2 и Sub-CU3), имеющие расстояние, равное 32 или более, от левой границы блока кодирования, могут быть установлены равными 0.[569] For example, when splitting in the vertical direction is applied to the current block, the residual coefficients of the subblocks whose distance from the left border of the coding block is equal to or greater than the threshold value can be set to 0. When the coding block size is 64 and the threshold value is 32, as shown in the example of FIG. left border of the coding block may be set to 0.
[570] Альтернативно, когда разбиение в горизонтальном направлении применяется к текущему блоку, остаточные коэффициенты подблоков, расстояние от верхней границы блока кодирования которых равняется пороговому значению или больше него, могут быть установлены равными 0. Когда размер блока кодирования равняется 64, и пороговое значение равняется 32, как показано в примере на фиг.27 (b), остаточные коэффициенты подблоков (Sub-CU2 и Sub-CU3), имеющие расстояние, равное 32 или более, от верхней границы блока кодирования, могут быть установлены равными 0.[570] Alternatively, when splitting in the horizontal direction is applied to the current block, the residual coefficients of the sub-blocks whose distance from the upper boundary of the coding block is equal to or greater than the threshold value may be set to 0. When the coding block size is 64 and the threshold value is 32, as shown in the example in FIG. from the upper bound of the coding block, may be set to 0.
[571] В отличие от примера, показанного на фигурах, остаточные коэффициенты, включенные в подблоки, расстояние от границы блока кодирования которых меньше, чем пороговое значение, могут быть установлены равными 0.[571] Unlike the example shown in the figures, the residual coefficients included in sub-blocks whose distance from the coding block boundary is less than the threshold value can be set to 0.
[572] Альтернативно остаточные коэффициенты остальных подблоков, за исключением подблока, расположенного в предварительно установленном положении, из множества подблоков могут быть установлены равными 0. Например, когда разбиения в вертикальном направлении применяется к блоку кодирования, остаточные коэффициенты остальных подблоков, за исключением самого левого или самого правого подблока, из множества подблоков могут быть установлены равными 0. Альтернативно, когда разбиение в горизонтальном направлении применяется к блоку кодирования, остаточные коэффициенты остальных подблоков, за исключением подблока, расположенного сверху или снизу, из множества подблоков могут быть установлены равными 0.[572] Alternatively, the residual coefficients of the remaining subblocks, except for the subblock located at the preset position, of the plurality of subblocks may be set to 0. For example, when splitting in the vertical direction is applied to a coding block, the residual coefficients of the remaining subblocks, except for the leftmost or rightmost subblock, of the plurality of subblocks may be set to 0. Alternatively, when partitioning in the horizontal direction is applied to a coding block, the residual coefficients of the remaining subblocks, except for a sub-block located above or below, of the plurality of sub-blocks can be set to 0.
[573] Информация, указывающая то, имеется ли ненулевой коэффициент, например, кодирование CBF, может быть пропущена для подблоков. Когда кодирование CBF пропущено, тогда то, включен ли ненулевой остаточный коэффициент в каждый подблок, может быть определено с учетом расстояния между границей блока кодирования и подблоком или положением подблока. Например, в примере, показанном на фиг.27, значения CBF подблока 0 и подблока 1 (sub-CU0, sub-CU1) могут быть получены как 1, и значения CBF подблока 2 и подблока 3 (sub-CU2, sub-CU3) могут быть получены как 0.[573] Information indicating whether there is a non-zero coefficient, such as CBF encoding, may be omitted for sub-blocks. When CBF encoding is omitted, then whether a non-zero residual coefficient is included in each sub-block may be determined considering the distance between the coding block boundary and the sub-block or sub-block position. For example, in the example shown in FIG. 27, the CBF values of sub-block 0 and sub-block 1 (sub-CU0, sub-CU1) can be obtained as 1, and the CBF values of sub-block 2 and sub-block 3 (sub-CU2, sub-CU3) can be obtained as 0.
[574] Преобразование и/или квантование могут быть выполнены в отношении подблоков, содержащих ненулевой коэффициент, тогда как преобразование и квантование могут быть пропущены для подблоков, которые не содержат ненулевой коэффициент.[574] Transformation and/or quantization may be performed on sub-blocks containing a non-zero coefficient, while transformation and quantization may be omitted for sub-blocks that do not contain a non-zero coefficient.
[575] В качестве еще одного примера может быть кодирована и передана информация, указывающая, что преобразование выполнено только в отношении частичного участка блока кодирования или блока преобразования. Информация может представлять собой cu_sbt_flag 1-битного флага. Когда флаг равняется 1, это указывает, что преобразование выполняется только в отношении некоторого из множества подблоков, сгенерированных путем разбиения блока кодирования или блока преобразования, а когда флаг равняется 0, это указывает, что преобразование выполняется без разбиения блока кодирования или блока преобразования на подблоки.[575] As another example, information indicating that a transformation has been performed on only a partial portion of an encoding block or a transform block may be encoded and transmitted. The information may be cu_sbt_flag of a 1-bit flag. When the flag is 1, it indicates that the transformation is performed on only some of the plurality of subblocks generated by splitting the coding block or transform block, and when the flag is 0, it indicates that the transformation is performed without splitting the coding block or transform block into subblocks.
[576] Метод выполнения преобразования только в отношении частичного участка блока кодирования может быть допущен только тогда, когда способ внутреннего кодирования с подразбиением применяется к блоку кодирования. Соответственно, cu_sbt_flag может быть кодирован и передан только тогда, когда способ внутреннего кодирования с подразбиением применяется к блоку кодирования. Когда значение cu_sbt_flag равняется 1, преобразование выполняется только в отношении некоторых подблоков из множества подблоков, сгенерированных путем разбиения блока кодирования или блока преобразования, и остаточные коэффициенты остальных подблоков могут быть установлены равными 0. Когда значение cu_sbt_flag равняется 1, преобразование может быть выполнено в отношении всех подблоков.[576] A method of performing transformation on only a partial portion of a coding block can be allowed only when the intra subdivision coding method is applied to the coding block. Accordingly, cu_sbt_flag can be encoded and transmitted only when the intra subdivision coding method is applied to a coding block. When the value of cu_sbt_flag is 1, transformation is performed on only some sub-blocks of the plurality of sub-blocks generated by splitting a coding block or a transformation block, and the residual coefficients of the remaining sub-blocks may be set to 0. When the value of cu_sbt_flag is equal to 1, transformation may be performed on all sub-blocks.
[577] Альтернативно, когда способ внутреннего кодирования с подразбиением применяется к блоку кодирования, кодирование cu_sbt_flag может быть пропущено, и значение cu_sbt_flag может быть установлено равным 1.[577] Alternatively, when the subdivision intra-coding method is applied to a coding block, the cu_sbt_flag encoding may be skipped, and the value of cu_sbt_flag may be set to 1.
[578] В качестве еще одного примера, только когда режим кодирования с предсказанием блока кодирования представляет собой предсказание, осуществляемое между изображениями, или привязку к текущему изображению, может быть допущен метод выполнения преобразования только в отношении частичного участка блока кодирования. Когда блок кодирования кодируется с помощью предсказания, осуществляемого между изображениями, или привязки к текущему изображению, может быть кодирована и передана информация, указывающая то, выполнено ли преобразование только в отношении частичного участка блока кодирования. Когда преобразование выполняется только в отношении частичного участка блока кодирования, может быть кодирована и передана информация, указывающая тип разбиения блока кодирования. Информация, указывающая тип разбиения блока кодирования, может включать по меньшей мере одно из информации, указывающей то, разбит ли блок кодирования на четыре подблока, информации, указывающей направление разбиения блока кодирования, и информации, указывающей количество подблоков. Например, когда cu_sbt_flag равняется 1, может быть передан флаг cu_sbt_quadtree_flag, указывающий то, разбит ли блок кодирования на четыре подблока. Когда cu_sbt_quadtree_flag равняется 1, это указывает, что блок кодирования разбит на четыре подблока. Например, блок кодирования может быть разбит на четыре подблока с использованием трех вертикальных линий или трех горизонтальных линий, или блок кодирования может быть разбит на четыре подблока с использованием одной вертикальной линии и одной горизонтальной линии. Когда cu_sbt_quadtree_flag равняется 0, это указывает, что блок кодирования разбит на два подблока. Например, блок кодирования может быть разбит на два подблока с использованием одной вертикальной линии и одной горизонтальной линии.[578] As another example, only when the coding block predictive coding mode is inter-picture prediction or current picture anchoring, a method for performing transformation on only a partial portion of the coding block can be allowed. When a coding block is encoded by inter-picture prediction or by reference to a current picture, information indicating whether a transformation has been performed on only a partial section of the coding block may be encoded and transmitted. When the transformation is performed on only a partial portion of a coding block, information indicating the partition type of the coding block may be encoded and transmitted. The information indicating the partitioning type of the coding block may include at least one of information indicating whether the coding block is divided into four subblocks, information indicating the splitting direction of the coding block, and information indicating the number of subblocks. For example, when cu_sbt_flag is 1, a cu_sbt_quadtree_flag flag may be transmitted indicating whether the coding block is split into four subblocks. When cu_sbt_quadtree_flag is equal to 1, this indicates that the coding block is divided into four sub-blocks. For example, a coding block may be divided into four subblocks using three vertical lines or three horizontal lines, or a coding block may be divided into four subblocks using one vertical line and one horizontal line. When cu_sbt_quadtree_flag is 0, this indicates that the coding block is split into two sub-blocks. For example, a coding block may be split into two sub-blocks using one vertical line and one horizontal line.
[579] Кроме того, флаг, указывающий направление разбиения блока кодирования, может быть передан посредством битового потока. Например, может быть кодирован и передан флаг cu_sbt_horizontal_flag, указывающий то, применяется ли разбиение в горизонтальном направлении к блоку кодирования. Когда значение cu_sbt_horizontal_flag равняется 1, это указывает, что разбиение в горизонтальном направлении применяется к блоку кодирования, а когда значение cu_sbt_horizontal_flag равняется 0, это указывает, что разбиение в вертикальном направлении применяется к блоку кодирования.[579] In addition, a flag indicating the splitting direction of a coding block may be transmitted via a bitstream. For example, a cu_sbt_horizontal_flag flag indicating whether splitting in the horizontal direction is applied to the coding block may be encoded and transmitted. When the value of cu_sbt_horizontal_flag is 1, it indicates that the split in the horizontal direction is applied to the coding block, and when the value of cu_sbt_horizontal_flag is 0, it indicates that the split in the vertical direction is applied to the coding block.
[580] Информация, указывающая положение подблока, в котором отсутствует ненулевой коэффициент, или подблока, в отношении которого не выполняется преобразование, может быть передана посредством битового потока. На основании информации могут быть определены подблок, в отношении которого выполняются преобразование и/или квантование, и подблок, для которого преобразование и/или квантование пропущены.[580] Information indicating the position of a sub-block in which there is no non-zero coefficient, or a sub-block in respect of which no transformation is performed, can be transmitted via a bitstream. Based on the information, a sub-block on which transformation and/or quantization is performed and a sub-block on which transformation and/or quantization is omitted can be determined.
[581] На фиг.28 представлен вид, показывающий пример, в котором положение подблока, в отношении которого были выполнены преобразование и/или квантование, указано на основании информации, переданной посредством битового потока.[581] FIG. 28 is a view showing an example in which the position of a sub-block on which transformation and/or quantization has been performed is indicated based on information transmitted by the bitstream.
[582] Может быть передан флаг sbt_upleft_flag, указывающий то, имеется ли ненулевой коэффициент в конкретном положении или в первом подблоке. Когда значение sbt_upleft_flag равняется 1, это указывает, что преобразование и/или квантование выполняются в отношении подблока, расположенного сверху или слева от блока кодирования, и преобразование и/или квантование не выполняются в отношении подблока, расположенного справа или снизу от блока кодирования. Когда значение sbt_upleft_flag равняется 0, это указывает, что преобразование и/или квантование выполняются в отношении подблока, расположенного сверху или слева от блока кодирования, и преобразование и/или квантование не выполняются в отношении подблока, расположенного справа или снизу от блока кодирования.[582] An sbt_upleft_flag flag may be transmitted indicating whether there is a non-zero coefficient at a particular position or in the first subblock. When the value of sbt_upleft_flag is 1, it indicates that the transformation and/or quantization is performed on the subblock located above or to the left of the coding block, and the transformation and/or quantization is not performed on the subblock located to the right or below the coding block. When the value of sbt_upleft_flag is 0, it indicates that the transformation and/or quantization is performed on the subblock located above or to the left of the coding block, and the transformation and/or quantization is not performed on the subblock located to the right or below the coding block.
[583] Когда блок кодирования разбит на четыре подблока, sbt_upleft_flag может указывать, что преобразование и/или квантование выполняется в отношении N подблоков. Например, когда значение sbt_upleft_flag равняется 1, это указывает, что преобразование и/или квантование выполняются в отношении двух подблоков сверху или слева, а когда значение sbt_upleft_flag равняется 0, это указывает, что преобразование и/или квантование выполняются в отношении двух подблоков справа или снизу.[583] When a coding block is split into four subblocks, sbt_upleft_flag may indicate that transformation and/or quantization is performed on N subblocks. For example, when the value of sbt_upleft_flag is 1, it indicates that transformation and/or quantization is performed on two sub-blocks from the top or left, and when the value of sbt_upleft_flag is 0, it indicates that transformation and/or quantization is performed on two sub-blocks from the right or bottom.
[584] В отличие от примера, показанного на фигуре, значение N может быть установлено равным 1 или 3.[584] Unlike the example shown in the figure, the value of N can be set to 1 or 3.
[585] Остаточные коэффициенты подблока, в отношении которых преобразование и/или квантование не выполняются, могут быть установлены равными 0.[585] Residual subblock coefficients on which no transform and/or quantization is performed may be set to 0.
[586] Тип преобразования подблока может быть определен с учетом направления разбиения блока кодирования и положения подблока. Например, когда блок кодирования разбит в вертикальном направлении, и преобразование выполняется в отношении подблока, расположенного слева, из подблоков, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены так, чтобы отличаться. Например, тип преобразования в горизонтальном направлении может быть установлен равным DCT8, и тип преобразования в вертикальном направлении может быть установлен равным DST7. С другой стороны, когда блок кодирования разбит в вертикальном направлении, и преобразование выполняется в отношении подблока, расположенного справа, из подблоков, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении подблока могут быть установлены равным образом. Например, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены равными DST7.[586] The transformation type of the sub-block may be determined based on the splitting direction of the coding block and the position of the sub-block. For example, when a coding block is split in the vertical direction and a transformation is performed on a sub-block located on the left of the sub-blocks, the transformation type in the horizontal direction and the transformation type in the vertical direction may be set to be different. For example, the transformation type in the horizontal direction may be set to DCT8, and the transformation type in the vertical direction may be set to DST7. On the other hand, when a coding block is split in the vertical direction and a transformation is performed on a subblock located on the right of the subblocks, the transformation type in the horizontal direction and the transformation type in the vertical direction of the subblock can be set equally. For example, the conversion type in the horizontal direction and the conversion type in the vertical direction can be set to DST7.
[587] Альтернативно, когда блок кодирования разбит в горизонтальном направлении, и преобразование выполняется в отношении подблока, расположенного сверху, из подблоков, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены так, чтобы отличаться. Например, тип преобразования в горизонтальном направлении может быть установлен равным DST7, и тип преобразования в вертикальном направлении может быть установлен равным DCT8. С другой стороны, когда блок кодирования разбит в горизонтальном направлении, и преобразование выполняется в отношении подблока, расположенного снизу, из подблоков, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении подблока могут быть установлены равным образом. Например, тип преобразования в горизонтальном направлении и тип преобразования в вертикальном направлении могут быть установлены равными DST7.[587] Alternatively, when a coding block is split in the horizontal direction, and the transformation is performed on the topmost subblock of the subblocks, the transformation type in the horizontal direction and the transformation type in the vertical direction may be set to be different. For example, the transformation type in the horizontal direction may be set to DST7, and the transformation type in the vertical direction may be set to DCT8. On the other hand, when a coding block is split in the horizontal direction and a transformation is performed on a sub-block located at the bottom of the sub-blocks, the transformation type in the horizontal direction and the transformation type in the vertical direction of the sub-block can be set equally. For example, the conversion type in the horizontal direction and the conversion type in the vertical direction can be set to DST7.
[588] Информация, указывающая то, имеется ли ненулевой коэффициент, например, кодирование CBF, может быть пропущена для подблоков. Когда кодирование CBF пропущено, тогда то, включен ли ненулевой остаточный коэффициент в каждый подблок, может быть определено с учетом положения блока, в отношении которого выполняется преобразование. Например, когда значение sbt_upleft_flag равняется 0, значения CBF подблоков, расположенных слева или сверху, могут быть получены как 0, и значение CBF подблоков, расположенных справа или снизу, может быть получено как 1. Альтернативно, когда значение sbt_upleft_flag равняется 1, значение CBF подблоков, расположенных слева или сверху, может быть получено как 1, и значение CBF подблоков, расположенных справа или снизу, может быть получено как 0.[588] Information indicating whether there is a non-zero coefficient, such as CBF encoding, may be omitted for subblocks. When CBF encoding is omitted, then whether a non-zero residual coefficient is included in each sub-block may be determined based on the position of the block on which the transformation is performed. For example, when the sbt_upleft_flag value is 0, the CBF values of the left or top subblocks can be obtained as 0, and the CBF value of the right or bottom subblocks can be obtained as 1. Alternatively, when the sbt_upleft_flag value is 1, the CBF value of the left or top subblocks can be obtained as 1, and the CBF value of the right or bottom subblocks can be obtained as received as 0.
[589] Восстановленный отсчет подблока, в отношении которого выполняется преобразование, может быть получен из суммы отсчета предсказания и остаточного отсчета. С другой стороны, в подблоке, в отношении которого пропущено преобразование, отсчет предсказания может быть установлен как восстановленный отсчет.Квантование предназначено для уменьшения энергии блока, и процесс квантования включает процесс разделения коэффициента преобразования на конкретное постоянное значение. Постоянное значение может быть получено с помощью параметра квантования, и параметр квантования может быть определен как значение от 1 до 63.[589] The restored count of the sub-block on which the transformation is performed can be obtained from the sum of the prediction count and the residual count. On the other hand, in a sub-block for which a transformation is skipped, the prediction count may be set as a recovered count. A constant value can be obtained with a quantization parameter, and the quantization parameter can be defined as a value from 1 to 63.
[590] Когда кодер выполняет преобразование и квантование, декодер может получать остаточный блок путем обратного квантования и обратного преобразования. Декодер может получать восстановленный блок для текущего блока путем добавления блока предсказания и остаточного блока.[590] When the encoder performs transform and quantization, the decoder may obtain a residual block by inverse quantization and inverse transform. The decoder may obtain a reconstructed block for the current block by adding a prediction block and a residual block.
[591][591]
[592] Когда получают восстановленный блок текущего блока, потеря информации, происходящая в процессе квантования и кодирования, может быть уменьшена посредством фильтрования в контуре. Фильтр в контуре может содержать по меньшей мере один из деблочного фильтра, фильтр адаптивного к отсчету смещения (SAO) и адаптивный контурный фильтр (ALF). Далее восстановленный блок перед применением фильтра в контуре называется первым восстановленным блоком, а восстановленный блок после применения фильтра в контуре называется вторым восстановленным блоком.[592] When a reconstructed block of the current block is obtained, the loss of information occurring in the quantization and encoding process can be reduced by loop filtering. An in-loop filter may comprise at least one of a de-blocking filter, a sample-adaptive offset (SAO) filter, and an adaptive loop filter (ALF). Further, the reconstructed block before applying the filter in the loop is called the first reconstructed block, and the reconstructed block after applying the filter in the loop is called the second reconstructed block.
[593] Второй восстановленный блок может быть получен путем применения по меньшей мере одного из деблочного фильтра, SAO и ALF к первому восстановленному блоку. В этом случае SAO или ALF могут быть применены после применения деблочного фильтра.[593] The second recovered block may be obtained by applying at least one of the deblocking filter, SAO, and ALF to the first recovered block. In this case, SAO or ALF can be applied after the deblocking filter has been applied.
[594] Деблочный фильтр предназначен для уменьшения ухудшения качества видео (блочного артефакта) на границе блока, которое происходит при выполнении квантования в отношении отдельных блоков. Для применения деблочного фильтра может быть определен качественный показатель блока (BS) между первым восстановленным блоком и соседним восстановленным блоком.[594] The de-block filter is designed to reduce video degradation (block artifact) at a block boundary that occurs when quantization is performed on individual blocks. To apply a deblocking filter, a block quality score (BS) between the first reconstructed block and an adjacent reconstructed block can be determined.
[595] На фиг.29 представлена блок-схема, изображающая процесс определения качественного показателя блока.[595] FIG. 29 is a flowchart showing a block quality determination process.
[596] В примере, показанном на фиг.29, P обозначает первый восстановленный блок, а Q обозначает соседний восстановленный блок. В данном случае соседний восстановленный блок может представлять собой блок, смежный с левой стороной или верхней стороной текущего блока.[596] In the example shown in FIG. 29, P denotes the first reconstructed block, and Q denotes an adjacent reconstructed block. In this case, the adjacent reconstructed block may be a block adjacent to the left side or top side of the current block.
[597] В примере, показанном на фиг.29, показано, что качественный показатель блока определен с учетом режимов кодирования с предсказанием P и Q, того, включен ли ненулевой коэффициент преобразования, того, выполнено ли предсказание, осуществляемое между изображениями, с использованием того же опорного изображения, и того, является ли значение разницы векторов движения большей, чем пороговое значение, или равной ему.[597] In the example shown in FIG. 29, the block quality score is determined considering the P and Q predictive coding modes, whether a non-zero transform coefficient is included, whether inter-picture prediction is performed using the same reference picture, and whether the motion vector difference value is greater than or equal to a threshold value.
[598] То, следует ли применять деблочный фильтр, можно определить на основании качественного показателя блока. Например, когда качественный показатель блока равен 0, фильтрование можно не выполнять.[598] Whether a deblocking filter should be applied can be determined based on the block quality. For example, when the block quality score is 0, filtering may not be performed.
[599] SAO предназначен для уменьшения явления в виде колец (артефакта в виде колец), которое происходит при выполнении квантования в частотной области. SAO может быть выполнено путем добавления или вычитания смещения, определенного с учетом схемы первого восстановленного видео. Способ определения смещения включает смещение по краю (EO) или смещение по полосам (BO). EO обозначает способ определения смещения текущего отсчета согласно схеме окружающих пикселей. BO обозначает способ применения обычного смещения к набору пикселей, имеющих похожие значения яркости на участке. В частности, яркость пикселей может быть разбита на 32 равные секции, и пиксели, имеющие похожие значения яркости, могут быть установлены как один набор. Например, четыре смежные полосы из 32 полос могут быть установлены как одна группа, и одинаковое значение смещения может быть применено к отсчетам, принадлежащим к четырем полосам.[599] SAO is designed to reduce the ring phenomenon (ring artifact) that occurs when quantization is performed in the frequency domain. SAO may be performed by adding or subtracting an offset determined from the schema of the first reconstructed video. The method for determining the offset includes edge offset (EO) or band offset (BO). EO denotes a method for determining the current sample offset according to the surrounding pixel pattern. BO refers to the way in which a conventional offset is applied to a set of pixels that have similar brightness values in a region. In particular, the brightness of pixels can be divided into 32 equal sections, and pixels having similar brightness values can be set as one set. For example, four adjacent bands of 32 bands can be set as one group, and the same offset value can be applied to the samples belonging to the four bands.
[600] ALF представляет собой способ генерирования второго восстановленного видео путем применения фильтра, имеющего предварительно заданный размер/форму, к первому восстановленному видео или восстановленному видео, к которому был применен деблочный фильтр. В уравнении 32 показан пример применения ALF.[600] ALF is a method for generating a second reconstructed video by applying a filter having a predetermined size/shape to a first reconstructed video or a reconstructed video to which a deblocking filter has been applied. Equation 32 shows an example of ALF application.
[601] [Уравнение 32][601] [Equation 32]
[602] Любой из предварительно заданных фильтров-кандидатов может быть выбран элементом изображения, элементом кодового дерева, блоком кодирования, блоком предсказания или блоком преобразования. Каждый из фильтров-кандидатов может отличаться либо по размеру, либо по форме.[602] Any of the predefined candidate filters may be selected by an image element, a code tree element, a coding block, a prediction block, or a transformation block. Each of the candidate filters may differ in either size or shape.
[603] На фиг.30 представлен вид, показывающий предварительно заданные фильтры-кандидаты.[603] FIG. 30 is a view showing predefined candidate filters.
[604] Как показано в примере на фиг.30, может быть выбрана по меньшей мере одна из ромбовидных форм 5×5, 7×7 и 9×9.[604] As shown in the example of FIG. 30, at least one of 5×5, 7×7, and 9×9 diamond shapes can be selected.
[605] Только ромбовидная форма размером 5×5 может быть использована для компонента цветности.[605] Only a 5x5 diamond shape can be used for the chrominance component.
[606][606]
[607] Применение вариантов осуществления, описанных выше, сфокусированных на процессе декодирования или процессе кодирования, к процессу кодирования или процессу декодирования включено в объем настоящего изобретения. Изменение вариантов осуществления, описанных в предварительно определенном порядке, в порядке, отличном от описанного порядка, также включено в объем настоящего изобретения.[607] The application of the embodiments described above focused on a decoding process or an encoding process to an encoding process or a decoding process is included within the scope of the present invention. Changing the embodiments described in a predetermined order in an order other than the order described is also included within the scope of the present invention.
[608] Хотя приведенные выше варианты осуществления были описаны на основании ряда этапов или блок-схем, это не ограничивает порядок выполнения во времени настоящего изобретения, и они могут быть выполнены одновременно или в другом порядке при необходимости. Кроме того, каждый из компонентов (например, элементов, модулей или т.п.), составляющих структурную схему в вариантах осуществления, описанных выше, может быть реализован в виде аппаратного устройства или программного обеспечения, или множество компонентов могут быть скомбинированы для реализации в виде одного аппаратного устройства или программного обеспечения. Варианты осуществления, описанные выше, могут быть реализованы в форме программных команд, которые могут быть исполнены посредством различных компьютерных компонентов и записаны в машиночитаемом носителе данных. Машиночитаемый носитель данных может содержать программные команды, файлы данных, структуры данных и т.п. независимо или в комбинации. Машиночитаемый носитель данных включает, например, магнитные носители, такие как жесткий диск, гибкий диск и магнитную ленту, оптические носители данных, такие как CD-ROM и DVD, магнитно-оптические носители, такие как гибкий оптический диск, и аппаратные устройства, специально выполненные с возможностью хранения и исполнения программных команд, такие как ROM, RAM, флеш-память и т.п. Аппаратные устройства, описанные выше, могут быть выполнены с возможностью работы с использованием одного или более программных модулей для выполнения процесса согласно настоящему изобретению, и наоборот.[608] Although the above embodiments have been described based on a number of steps or flowcharts, this does not limit the order of execution in time of the present invention, and they can be performed simultaneously or in a different order if necessary. In addition, each of the components (e.g., elements, modules, or the like) constituting the block diagram in the embodiments described above may be implemented as a hardware device or software, or multiple components may be combined to be implemented as a single hardware device or software. The embodiments described above may be implemented in the form of program instructions that may be executed by various computer components and stored in a computer-readable storage medium. The computer-readable storage medium may contain program instructions, data files, data structures, and the like. independently or in combination. A computer-readable storage medium includes, for example, magnetic media such as hard disk, floppy disk and magnetic tape, optical storage media such as CD-ROM and DVD, magneto-optical storage media such as floppy optical disk, and hardware devices specifically configured to store and execute program instructions such as ROM, RAM, flash memory, and the like. The hardware devices described above may be configured to operate using one or more software modules to perform the process of the present invention, and vice versa.
[609] Настоящее изобретение может быть применено к электронному устройству, которое кодирует и декодирует видео.[609] The present invention can be applied to an electronic device that encodes and decodes video.
Claims (24)
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2018-0121713 | 2018-10-12 | ||
KR10-2018-0121757 | 2018-10-12 | ||
KR10-2019-0006611 | 2019-01-18 |
Related Child Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
RU2023117248A Division RU2811980C2 (en) | 2018-10-12 | 2019-10-11 | Method and device for encoding/decoding image signals |
RU2023117247A Division RU2820118C2 (en) | 2018-10-12 | 2019-10-11 | Method and device for encoding/decoding image signals |
RU2023117246A Division RU2811985C2 (en) | 2018-10-12 | 2019-10-11 | Method and device for encoding/decoding image signals |
Publications (2)
Publication Number | Publication Date |
---|---|
RU2021111110A RU2021111110A (en) | 2022-11-14 |
RU2800133C2 true RU2800133C2 (en) | 2023-07-18 |
Family
ID=
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
RU2584498C2 (en) * | 2011-11-04 | 2016-05-20 | Квэлкомм Инкорпорейтед | Intra-mode video encoding |
WO2017176030A1 (en) * | 2016-04-06 | 2017-10-12 | 주식회사 케이티 | Method and apparatus for processing video signal |
RU2649787C1 (en) * | 2012-07-06 | 2018-04-04 | Нтт Докомо, Инк. | Video predictive encoding device, video predictive encoding method, video predictive encoding program, video predictive decoding device, video predictive decoding method and video predictive decoding program |
EP3311571A1 (en) * | 2015-06-18 | 2018-04-25 | Qualcomm Incorporated | Intra prediction and intra mode coding |
EP3379829A1 (en) * | 2015-11-19 | 2018-09-26 | Electronics and Telecommunications Research Institute | Method and apparatus for encoding/decoding in-screen prediction mode |
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
RU2584498C2 (en) * | 2011-11-04 | 2016-05-20 | Квэлкомм Инкорпорейтед | Intra-mode video encoding |
RU2649787C1 (en) * | 2012-07-06 | 2018-04-04 | Нтт Докомо, Инк. | Video predictive encoding device, video predictive encoding method, video predictive encoding program, video predictive decoding device, video predictive decoding method and video predictive decoding program |
EP3311571A1 (en) * | 2015-06-18 | 2018-04-25 | Qualcomm Incorporated | Intra prediction and intra mode coding |
EP3379829A1 (en) * | 2015-11-19 | 2018-09-26 | Electronics and Telecommunications Research Institute | Method and apparatus for encoding/decoding in-screen prediction mode |
WO2017176030A1 (en) * | 2016-04-06 | 2017-10-12 | 주식회사 케이티 | Method and apparatus for processing video signal |
Non-Patent Citations (1)
Title |
---|
C.-W. Hsu и др., "Description of SDR video coding technology proposal by MediaTek", JVET-J0018, апрель 2018 г.. K. CHOI и др., "CE6: AMT with reduced transform types (Test1.5)", JVET-K0171, июль 2018 г.. * |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111149359B (en) | Method and apparatus for encoding/decoding image and recording medium storing bit stream | |
US11252403B2 (en) | Method for encoding/decoding image signal and device for same | |
CN112219397B (en) | Method for encoding/decoding video signal and apparatus therefor | |
KR102617439B1 (en) | Method for encoding/decoidng video signal and apparatus therefor | |
KR20240049540A (en) | Method and apparatus for encoding/decoding image and recording medium for storing bitstream | |
KR20200093468A (en) | Method for encoding/decoding video signal and apparatus therefor | |
JP2022505874A (en) | Video signal coding / decoding method and equipment for the above method | |
JP7459069B2 (en) | Video signal encoding/decoding method and device | |
KR20180014675A (en) | Method and apparatus for encoding/decoding image and recording medium for storing bitstream | |
CA3118429C (en) | Image signal encoding/decoding method and apparatus therefor | |
CN113225560A (en) | Video encoding/decoding method, video encoding/decoding apparatus, and storage medium | |
KR20210030889A (en) | Method for encoding/decoding a video signal and device therefor | |
KR20200039591A (en) | Method and apparatus for encoding/decoding image and recording medium for storing bitstream | |
KR20210022510A (en) | Method for encoding/decoidng video signal and apparatus therefor | |
CN113841399A (en) | Image encoding/decoding method and apparatus | |
RU2800133C2 (en) | Method and device for coding/decoding image signals | |
CN116134820A (en) | Method and device for encoding and decoding video data based on patch | |
RU2811985C2 (en) | Method and device for encoding/decoding image signals | |
RU2820118C2 (en) | Method and device for encoding/decoding image signals | |
RU2824448C1 (en) | Method and device for encoding/decoding image signals | |
RU2811980C2 (en) | Method and device for encoding/decoding image signals | |
RU2799588C2 (en) | Method and device for coding/decoding image signals | |
RU2812857C2 (en) | Method and device for encoding/decoding image signals | |
RU2813667C2 (en) | Method and device for encoding and decoding video signals | |
RU2819286C2 (en) | Method and device for encoding/decoding image signals |