ES2968163T3 - Derivación de vector de movimiento restringido para imágenes de referencia a largo plazo en codificación de video - Google Patents
Derivación de vector de movimiento restringido para imágenes de referencia a largo plazo en codificación de video Download PDFInfo
- Publication number
- ES2968163T3 ES2968163T3 ES20760226T ES20760226T ES2968163T3 ES 2968163 T3 ES2968163 T3 ES 2968163T3 ES 20760226 T ES20760226 T ES 20760226T ES 20760226 T ES20760226 T ES 20760226T ES 2968163 T3 ES2968163 T3 ES 2968163T3
- Authority
- ES
- Spain
- Prior art keywords
- block
- reference image
- intermodal
- motion vector
- long
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 230000033001 locomotion Effects 0.000 title claims abstract description 144
- 239000013598 vector Substances 0.000 title claims abstract description 91
- 230000007774 longterm Effects 0.000 title claims abstract description 64
- 238000009795 derivation Methods 0.000 title claims description 29
- 238000000034 method Methods 0.000 claims abstract description 49
- 230000002123 temporal effect Effects 0.000 claims description 39
- 230000002457 bidirectional effect Effects 0.000 claims description 33
- 230000008569 process Effects 0.000 claims description 27
- 230000004927 fusion Effects 0.000 claims description 21
- 230000003287 optical effect Effects 0.000 claims description 5
- 238000004590 computer program Methods 0.000 claims description 3
- 230000009977 dual effect Effects 0.000 description 12
- 238000005192 partition Methods 0.000 description 8
- 238000012986 modification Methods 0.000 description 7
- 230000004048 modification Effects 0.000 description 7
- 230000008859 change Effects 0.000 description 6
- 238000012545 processing Methods 0.000 description 6
- PXFBZOLANLWPMH-UHFFFAOYSA-N 16-Epiaffinine Natural products C1C(C2=CC=CC=C2N2)=C2C(=O)CC2C(=CC)CN(C)C1C2CO PXFBZOLANLWPMH-UHFFFAOYSA-N 0.000 description 5
- 230000002146 bilateral effect Effects 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 238000006073 displacement reaction Methods 0.000 description 5
- 238000012935 Averaging Methods 0.000 description 4
- 230000003044 adaptive effect Effects 0.000 description 4
- 238000013139 quantization Methods 0.000 description 4
- 238000004891 communication Methods 0.000 description 3
- 238000001914 filtration Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 208000037170 Delayed Emergence from Anesthesia Diseases 0.000 description 2
- 238000013459 approach Methods 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 238000013500 data storage Methods 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 238000002156 mixing Methods 0.000 description 2
- 238000000638 solvent extraction Methods 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 241000023320 Luma <angiosperm> Species 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000015556 catabolic process Effects 0.000 description 1
- 238000006731 degradation reaction Methods 0.000 description 1
- 238000011156 evaluation Methods 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- OSWPMRLSEDHDFF-UHFFFAOYSA-N methyl salicylate Chemical compound COC(=O)C1=CC=CC=C1O OSWPMRLSEDHDFF-UHFFFAOYSA-N 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 230000011664 signaling Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000001052 transient effect Effects 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/103—Selection of coding mode or of prediction mode
- H04N19/105—Selection of the reference unit for prediction within a chosen coding or prediction mode, e.g. adaptive choice of position and number of pixels used for prediction
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/58—Motion compensation with long-term prediction, i.e. the reference frame for a current frame not being the temporally closest one
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/157—Assigned coding mode, i.e. the coding mode being predefined or preselected to be further used for selection of another element or parameter
- H04N19/159—Prediction type, e.g. intra-frame, inter-frame or bidirectional frame prediction
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/176—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/513—Processing of motion vectors
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/577—Motion compensation with bidirectional frame interpolation, i.e. using B-pictures
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/96—Tree coding, e.g. quad-tree coding
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Un método para restringir las operaciones de ciertas herramientas de codificación intermodo en la derivación de candidatos de vector de movimiento para bloques codificados intermodo empleados en estándares de codificación de vídeo, tales como la ahora actual Codificación de Vídeo Versátil (VVC), se realiza en una computadora. dispositivo. El dispositivo informático determina si una o más de las imágenes de referencia asociadas con un bloque codificado entre modos implicado en una operación de una herramienta de codificación entre modos son imágenes de referencia a largo plazo, y restringe el funcionamiento de la herramienta de codificación entre modos en el bloque codificado entre modos basado en la determinación. (Traducción automática con Google Translate, sin valor legal)
Description
DESCRIPCIÓN
Derivación de vector de movimiento restringido para imágenes de referencia a largo plazo en codificación de videoCampo
La presente descripción se refiere en general a codificación y compresión de vídeo. Más específicamente, esta descripción se refiere a sistemas y métodos para realizar codificación de vídeo utilizando restricciones en la derivación de vector de movimiento para imágenes de referencia a largo plazo.
Antecedentes
Esta sección proporciona información general relacionada con la presente descripción. La información contenida en esta sección no debería interpretarse necesariamente como técnica anterior.
Se puede utilizar cualquiera de las diversas técnicas de codificación de vídeo para comprimir datos de vídeo. La codificación de vídeo se puede realizar según uno o más estándares de codificación de vídeo. Algunos estándares de codificación de video ilustrativos incluyen codificación de video versátil (VVC), codificación de modelo de prueba de exploración conjunta (JEM), codificación de video de alta eficiencia (H.265/HEVC), codificación de video avanzada (H.264/AVC) y codificación de grupo de expertos en imágenes en movimiento (MPEG).
La codificación de vídeo generalmente utiliza métodos predictivos (por ejemplo, inter predicción, intra predicción o similares) que aprovechan la redundancia inherente a las imágenes o secuencias de vídeo. Uno de los objetivos de las técnicas de codificación de vídeo es comprimir los datos de vídeo en un formato que utilice una tasa de bits más baja, evitando o minimizando al mismo tiempo las degradaciones de la calidad del vídeo.
Los métodos predictivos utilizados en la codificación de vídeo normalmente incluyen realizar predicción espacial (intra fotograma) y/o predicción temporal (inter fotograma) para reducir o eliminar la redundancia inherente a los datos de vídeo, y normalmente están asociados con la codificación de vídeo basada en bloques.
En la codificación de vídeo basada en bloques, la señal de vídeo de entrada se procesa bloque por bloque. Para cada bloque (también conocido como unidad de codificación (CU)), se puede realizar predicción espacial y/o predicción temporal.
La predicción espacial (también conocida como "intra predicción") utiliza píxeles de las muestras de bloques contiguos ya codificados (que se denominan muestras de referencia) en la misma imagen/segmento de vídeo para predecir el bloque actual. La predicción espacial reduce la redundancia espacial inherente a la señal de vídeo. La predicción temporal (también conocida como "inter predicción" o "predicción con compensación de movimiento") utiliza píxeles reconstruidos a partir de imágenes de vídeo ya codificadas para predecir el bloque actual. La predicción temporal reduce la redundancia temporal inherente a la señal de vídeo. La señal de predicción temporal para una CU determinada normalmente se señala mediante uno o más vectores de movimiento (MV) que indican la cantidad y la dirección del movimiento entre la CU actual y su referencia temporal. También, cuando se soportan múltiples imágenes de referencia, se envía adicionalmente un índice de imagen de referencia, que se utiliza para identificar de qué imagen de referencia en el almacenamiento de imágenes de referencia proviene la señal de predicción temporal.
Después de la predicción espacial y/o temporal, el bloque de decisión de modo en el codificador elige el mejor modo de predicción, por ejemplo basándose en el método de optimización de distorsión de velocidad. A continuación, el bloque de predicción se resta del bloque actual; y el residuo de predicción se desconecta utilizando transformada y se cuantiza. Los coeficientes residuales cuantizados se cuantizan y transforman inversamente para formar el residuo reconstruido, que, a continuación, se vuelve a añadir al bloque de predicción para formar la señal reconstruida del bloque.
Después de las predicciones espaciales y/o temporales, se puede aplicar un filtrado en bucle adicional, tal como un filtro de desbloqueo, un desplazamiento adaptativo de muestra (SAO) y un filtro en bucle adaptativo (ALF) en la CU reconstruida antes de colocarla en el almacén de imágenes de referencia y se utiliza para codificar futuros bloques de vídeo. Para formar el flujo de bits de vídeo de salida, el modo de codificación (inter o intra), la información del modo de predicción, la información de movimiento y los coeficientes residuales cuantizados se envían todos a la unidad de codificación de entropía para ser comprimidos y empaquetados aún más para formar el flujo de bits. Durante el proceso de decodificación, el flujo de bits de vídeo es la primera entropía decodificada en una unidad de decodificación de entropía. El modo de codificación y la información de predicción se envían, bien a la unidad de predicción espacial (cuando está intracodificada), o bien a la unidad de predicción temporal (cuando está inter codificada) para formar el bloque de predicción. Los coeficientes de transformada residual se envían a la unidad de cuantización inversa y a la unidad de transformada inversa para reconstruir el bloque residual. A continuación, se añaden juntos el bloque de predicción y el bloque residual. El bloque reconstruido puede pasar además a través de un filtrado en bucle antes de almacenarse en el almacén de imágenes de referencia. El vídeo reconstruido en el almacén de imágenes de referencia se envía, a continuación, para controlar un dispositivo de presentación y se utiliza para predecir futuros bloques de vídeo.
En los estándares de codificación de vídeo, tales como HEVC y VVC, el concepto de conjunto de imágenes de referencia (RPS) define cómo se gestionan las imágenes previamente decodificadas en un búfer de imágenes decodificadas (DPB) con el fin de utilizarlas como referencia, es decir, predicción de datos de muestra y predicción de vector de movimiento. En general, el concepto de RPS para la gestión de imágenes de referencia es señalar el estado del DPB en cada segmento (también conocido como "mosaico" en el VVC actual).
Las imágenes en el DPB se pueden marcar como "utilizadas como referencia a corto plazo", "utilizadas como referencia a largo plazo" o "no utilizadas como referencia". Una vez que una imagen se ha marcado como "no utilizada como referencia", ya no se puede utilizar para la predicción y, cuando ya no es necesaria para la salida, se puede eliminar del DPB.
En general, la imagen de referencia a largo plazo suele estar más alejada de la imagen actual en comparación con la imagen de referencia a corto plazo en términos de orden de visualización (es decir, recuento de orden de imágenes o denominado POC). Esta distinción entre imágenes de referencia a largo plazo e imágenes de referencia a corto plazo puede afectar a algunos procesos de decodificación, tal como el escalado del vector de movimiento en la predicción MV temporal y espacial o la predicción ponderada implícita.
En estándares de codificación de vídeo, tales como HEVC y WC, al derivar candidatos de vector de movimiento espacial y/o temporal, se imponen ciertas restricciones al proceso de escalado que forma parte de la derivación de los candidatos de vector de movimiento espacial y/o temporal, basándose en si ciertas imágenes de referencia implicadas en el proceso son imágenes de referencia a largo plazo o no son imágenes de referencia a largo plazo. Sin embargo, de conformidad con las especificaciones de códec de vídeo tales como la estandarización VVC actual, no se han impuesto restricciones similares a las herramientas de codificación de vídeo entre modos más nuevas adoptadas en dichas especificaciones de códec de vídeo para la derivación de candidatos de vector de movimiento para bloques codificados intermodales.
Un documento que no es de patente "Descripción general de la sintaxis de alto nivel de HEVC y la gestión de imágenes de referencia" las imágenes propuestas en el DPB se pueden marcar como "utilizadas como referencia a corto plazo", "utilizadas como referencia a largo plazo" o "no utilizadas como referencia”. Un documento de patente 2018/278949A1 ha propuesto alguna herramienta de codificación, por ejemplo, DMVD, BIO y similares, y la aplicación de una o más restricciones a la información de movimiento, tal como un MV derivado por DMVD, y/o una diferencia de MV entre un MV inicial y un MV derivado por DMVD.
Compendio
Esta sección proporciona un resumen general de la descripción y no es una descripción integral de su alcance completo ni de todas sus características.
Según un primer aspecto de la presente descripción, un método de decodificación de vídeo se realiza en un dispositivo informático que tiene uno o más procesadores y una memoria que almacena una pluralidad de programas para ser ejecutados por uno o más procesadores. El método incluye la determinación de si una o más de las imágenes de referencia asociadas con un bloque codificado intermodal implicado en una operación de una herramienta de codificación intermodal son imágenes de referencia a largo plazo; y la restricción de la operación de una herramienta de codificación intermodal en el bloque codificado intermodal basándose en la determinación, en donde en el caso de que la herramienta de codificación intermodal comprenda flujo óptico bidireccional, BDOF, y el bloque codificado intermodal sea un bloque de predicción bidireccional, que restringe la operación de la herramienta de codificación intermodal en el bloque codificado intermodal basándose en la determinación comprende; la prohibición del desempeño del BDOF al determinar que una imagen de referencia del bloque de predicción bidireccional es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque de predicción bidireccional no es una imagen de referencia a largo plazo.
Según un segundo aspecto de la presente solicitud, un dispositivo informático incluye uno o más procesadores, una memoria y una pluralidad de programas almacenados en la memoria. Los programas, cuando son ejecutados por uno o más procesadores, hacen que el dispositivo informático realice operaciones como se ha descrito anteriormente.
Según un tercer aspecto de la presente solicitud, un medio de almacenamiento no transitorio legible por ordenador almacena una pluralidad de programas para su ejecución por un dispositivo informático que tiene uno o más procesadores. Los programas, cuando son ejecutados por uno o más procesadores, hacen que el dispositivo informático realice operaciones como se ha descrito anteriormente.
Breve descripción de los dibujos
De aquí en adelante, se describirán conjuntos de realizaciones ilustrativas, no limitativas de la presente descripción junto con los dibujos adjuntos. Los expertos en la técnica relevante pueden implementar variaciones de estructura, método o funcionalidad basándose en los ejemplos presentados en la presente memoria, y todas dichas variaciones están contenidas dentro del alcance de la presente descripción. En los casos donde no haya conflicto, las enseñanzas de diferentes realizaciones pueden, aunque no es necesario, combinarse entre sí.
La fig. 1 es un diagrama de bloques que expone un codificador de vídeo híbrido basado en bloques ilustrativo que puede utilizarse junto con muchos estándares de codificación de vídeo.
La fig. 2 es un diagrama de bloques que expone un decodificador de vídeo ilustrativo que puede utilizarse junto con muchos estándares de codificación de vídeo.
La fig. 3 es una ilustración de particiones de bloques en una estructura de árbol de tipos múltiples que puede utilizarse junto con muchos estándares de codificación de vídeo.
La fig. 4 es una ilustración del proceso de flujo óptico bidireccional (BDOF).
La fig. 5 es una ilustración de la correspondencia bilateral utilizada en el refinamiento del vector de movimiento del lado del decodificador (DMVR).
La fig. 6 es una ilustración de puntos de búsqueda utilizados en el modo de fusión con diferencias de vector de movimiento (MMVD).
La fig. 7A es una ilustración de los bloques contiguos espaciales utilizados en el modo de predicción de vector de movimiento temporal basada en subbloques (SbTMVP).
La fig. 7B es una ilustración de la derivación, en modo SbTMVP, de información de movimiento a nivel subCU aplicando el cambio de movimiento identificado a partir de los bloques contiguos espaciales.
Descripción detallada
La invención está definida por las reivindicaciones adjuntas.
Los términos utilizados en la presente descripción están dirigidos a ilustrar ejemplos particulares, en lugar de limitar la presente descripción. Las formas singulares "un/una", "uno" y "el/la" tal como se utilizan en la presente descripción, así como las reivindicaciones adjuntas, también se refieren a formas plurales, a menos que el contexto contenga definitivamente otros significados. Debería apreciarse que el término "y/o", tal como se utiliza en la presente memoria, se refiere a cualquiera o todas las combinaciones posibles de uno o más elementos enumerados asociados.
Se comprenderá que, aunque los términos "primero", "segundo", "tercero", etc. pueden utilizarse en la presente memoria para describir diversa información, la información no debería estar limitada por estos términos. Estos términos sólo se utilizan para distinguir una categoría de información de otra. Por ejemplo, sin desviarse del alcance de la presente descripción, la primera información puede denominarse segunda información; y de manera similar, la segunda información también puede denominarse primera información. Tal como se utiliza en la presente memoria, se puede comprender que el término "si" significa "cuando", "sobre" o "en respuesta a", dependiendo del contexto. La referencia a lo largo de esta memoria descriptiva a "una realización", "otra realización" o similares en singular o plural significa que una o más características, estructuras o distintivos particulares descritos en relación con una realización están incluidas en al menos una realización de la presente descripción. Así, las apariciones de las frases "en una realización", "en otra realización" o similares en singular o plural en varios lugares a lo largo de esta memoria descriptiva no necesariamente se refieren todas a la misma realización. Además, las características, estructuras o distintivos particulares en una o más realizaciones se pueden combinar de cualquier manera adecuada.
Conceptualmente, muchos estándares de codificación de vídeo son similares, incluyendo los mencionados anteriormente en la sección Antecedentes. Por ejemplo, prácticamente todos los estándares de codificación de video utilizan procesamiento basado en bloques y comparten diagramas de bloques de codificación de video similares para lograr la compresión de video.
La fig. 1 muestra un diagrama de bloques de un codificador 100 de vídeo híbrido basado en bloques ilustrativo que puede utilizarse junto con muchos estándares de codificación de vídeo. En el codificador 100, un fotograma de vídeo se divide en una pluralidad de bloques de vídeo para su procesamiento. Para cada bloque de vídeo determinado, se forma una predicción basada, bien en un enfoque de inter predicción, o bien en un enfoque de intra predicción. En la inter predicción, se forman uno o más predictores a través de la estimación y compensación del movimiento, basándose en píxeles de fotogramas reconstruidos previamente. En la intra predicción, los predictores se forman basándose en los píxeles reconstruidos en un fotograma actual. A través de la decisión de modo, se puede elegir el mejor predictor para predecir un bloque actual.
Un residuo de predicción, que representa la diferencia entre un bloque de vídeo actual y su predictor, se envía a un circuito 102 de transformada. A continuación, se envían coeficientes de transformada desde el circuito 102 de transformada a un circuito 104 de cuantización para la reducción de entropía. A continuación, los coeficientes cuantizados se alimentan en un circuito 106 de codificación de entropía para generar un flujo de bits de vídeo comprimido. Como se muestra en la fig. 1, la información 110 relacionada con la predicción procedente de un circuito de inter predicción y/o un circuito de intra predicción 112, tal como información de partición de bloque de vídeo, vectores de movimiento, índice de imagen de referencia y modo de intra predicción, también se alimenta a través del circuito 106 de codificación de entropía y guardado en un flujo de bits 114 de vídeo comprimido.
En el codificador 100, también se necesitan circuitos relacionados con el decodificador con el fin de reconstruir píxeles con fines de predicción. En primer lugar, se reconstruye un residuo de predicción a través de una cuantización 116 inversa y un circuito 118 de transformada inversa. Este residuo de predicción reconstruido se combina con un predictor 120 de bloques para generar píxeles reconstruidos sin filtrar para un bloque de vídeo actual.
Para mejorar la eficiencia de la codificación y la calidad visual, se suele utilizar un filtro en bucle. Por ejemplo, un filtro de desbloqueo está disponible en AVC, HEVC, así como la versión actual de WC. En HEVC, se define un filtro en bucle adicional llamado SAO (desplazamiento adaptativo de muestra) para mejorar aún más la eficiencia de la codificación. En la versión ahora actual del estándar VVC, se está investigando activamente otro filtro en bucle llamado ALF (filtro de bucle adaptativo), y tiene muchas posibilidades de incluirse en el estándar final.
Estas operaciones de filtro en bucle son opcionales. Realizar estas operaciones ayuda a mejorar la eficiencia de codificación y la calidad visual. También pueden desactivarse como una decisión tomada por el codificador 100 para ahorrar complejidad computacional.
Debería observarse que la intra predicción se basa normalmente en píxeles reconstruidos sin filtrar, mientras que la inter predicción se basa en píxeles reconstruidos filtrados si el codificador 100 activa estas opciones de filtro.
La fig. 2 es un diagrama de bloques que expone un decodificador 200 de vídeo ilustrativo que puede utilizarse junto con muchos estándares de codificación de vídeo. Este decodificador 200 es similar a la sección relacionada con la reconstrucción que reside en el codificador 100 de la fig. 1. En el decodificador 200 (fig. 2), primero se decodifica un flujo de bits 201 de vídeo entrante a través de una decodificación 202 de entropía para derivar niveles de coeficientes cuantizados e información relacionada con la predicción. Los niveles de coeficientes cuantizados se procesan, a continuación, a través de una cuantización 204 inversa y una transformada 206 inversa para obtener un residuo de predicción reconstruido. Un mecanismo predictor de bloques, implementado en un selector 212 de modo intra/inter, está configurado para realizar, bien una predicción intra 208, o bien una compensación 210 de movimiento, basándose en información de predicción decodificada. Se obtiene un conjunto de píxeles reconstruidos sin filtrar sumando el residuo de predicción reconstruido de la transformada 206 inversa y una salida predictiva generada por el mecanismo predictor de bloques, utilizando un Summer 214. En situaciones donde se activa un filtro en bucle, se realiza una operación de filtrado en estos píxeles reconstruidos para derivar el vídeo reconstruido final. El vídeo reconstruido en el almacén de imágenes de referencia se envía, a continuación, para accionar un dispositivo de visualización, así como se utiliza para predecir futuros bloques de vídeo.
En estándares de codificación de vídeo, tal como HEVC, los bloques se pueden dividir basándose en árboles cuádruples. En los estándares de codificación de vídeo más nuevos, tales como el VVC ahora actual, se emplean más métodos de partición y una unidad de codificación en árbol (CTU) se puede dividir en CU para adaptarse a las diferentes características locales basadas en árboles cuádruples, árboles binarios o árboles ternarios. La separación de CU, unidad de predicción (PU) y unidad de transformada (TU) no existe en la mayoría de los modos de codificación en el VVC ahora actual, y cada CU siempre se utiliza como unidad básica tanto para la predicción como para la transformada sin más particiones. Sin embargo, en algunos modos de codificación específicos, tales como el modo de codificación intra subpartición, cada CU puede contener todavía múltiples TU. En la estructura en árbol de múltiples tipos, una CTU se divide en primer lugar mediante una estructura cuádruple en árbol. A continuación, cada nodo de hoja de árbol cuádruple se puede dividir aún más mediante una estructura en árbol binario y ternario.
La fig. 3 muestra los cinco tipos de división empleados en el VVC ahora actual, a saber, partición 301 cuaternaria, partición 302 binaria horizontal, partición 303 binaria vertical, partición 304 ternaria horizontal y partición 305 ternaria vertical.
En los estándares de codificación de vídeo, tales como HEVC y el VVC ahora actual, las imágenes previamente decodificadas se gestionan en un búfer de imágenes decodificadas (DPB) con el fin de poder utilizarlas como referencia bajo el concepto de conjunto de imágenes de referencia (RPS). Las imágenes en el DPB se pueden marcar como "utilizadas como referencia a corto plazo", "utilizadas como referencia a largo plazo" o "no utilizadas como referencia".
Cuando la imagen de referencia del bloque contiguo es diferente de la imagen de referencia objetivo dada para el bloque actual, los vectores de movimiento escalados del bloque contiguo espacial pueden utilizarse como predictor del vector de movimiento para el bloque actual. En el proceso de escalado para los candidatos de movimiento espacial, el factor de escalado se calcula basándose en la distancia del recuento de orden de imagen (POC) entre la imagen actual y la imagen de referencia objetivo, y la distancia POC entre la imagen actual y la imagen de referencia para el bloque contiguo.
En los estándares de codificación de vídeo, tales como HEVC y VVC ahora actual, se imponen ciertas restricciones al proceso de escalado de los candidatos de movimiento espacial, basándose en si ciertas imágenes de referencia implicadas en el proceso son imágenes de referencia a largo plazo o no. Cuando una de las dos imágenes de referencia es una imagen de referencia a largo plazo y la otra no es una imagen de referencia a largo plazo, el MV del bloque contiguo se considera inválido. Cuando ambas imágenes de referencia son imágenes de referencia a largo plazo, los MV del bloque contiguo espacial se utilizan directamente como MVP para el bloque actual y se prohíbe el procesamiento de escala porque la distancia POC entre las dos imágenes de referencia a largo plazo suele ser mayor y así, los MV escalados pueden no ser fiables.
De manera similar, en el proceso de escalado para los candidatos de movimiento temporal, el factor de escalado se calcula basándose en la distancia POC entre la imagen actual y la imagen de referencia objetivo, y la distancia POC entre la imagen colocada y la imagen de referencia para el bloque contiguo temporal (también conocido como bloque colocado).
En los estándares de codificación de vídeo, tales como HEVC y el VVC ahora actual, también se imponen ciertas restricciones al proceso de escalado de los candidatos de movimiento temporal, basándose en si ciertas imágenes de referencia implicadas en el proceso son imágenes de referencia a largo plazo o no. Cuando una de las dos imágenes de referencia es una imagen de referencia a largo plazo y la otra no es una imagen de referencia a largo plazo, el MV del bloque contiguo se considera inválido. Cuando ambas imágenes de referencia son imágenes de referencia de largo plazo, los MV del bloque contiguo temporal se utilizan directamente como MVP para el bloque actual y se prohíbe el procesamiento de escalado porque la distancia POC entre las dos imágenes de referencia de largo plazo generalmente es mayor y así, los MV escalados pueden no ser fiables.
En los estándares de codificación de vídeo más nuevos, tal como el VVC ahora actual, se han introducido nuevas herramientas de codificación intermodal y algunos ejemplos de las nuevas herramientas de codificación intermodal son: flujo óptico bidireccional (BDOF), refinamiento de vector de movimiento del lado del decodificador (DMVR), modo de fusión con MVD (MMVD), MVD simétrico (SMVD), predicción dual con promedio ponderado (BWA), derivación de candidatos de fusión promedio por pares y predicción de vector de movimiento temporal basada en subbloques (SbTMVP).
La predicción dual convencional en codificación de vídeo es una combinación simple de dos bloques de predicción temporal obtenidos a partir de imágenes de referencia que ya están reconstruidas. Sin embargo, debido a la limitación de la compensación de movimiento basada en bloques, es posible que queden pequeños movimientos que se puedan observar entre las muestras de dos bloques de predicción, lo que reduce la eficiencia de la predicción con compensación de movimiento. Para resolver este problema, se aplica BDOF en el VVC ahora actual para reducir los impactos de dicho movimiento para cada muestra dentro de un bloque.
La fig. 4 es una ilustración del proceso BDOF. El BDOF es un refinamiento del movimiento por muestra que se realiza además de las predicciones con compensación de movimiento basadas en bloques cuando se utiliza la predicción dual. El refinamiento del movimiento de cada subbloque de 4x4 se calcula minimizando la diferencia entre las muestras de predicción de la lista de imágenes de referencia 0 (L0) y de la lista de imágenes de referencia 1 (L1) después de aplicar el BDOF dentro de una ventana de 6x6 alrededor del subbloque. Basándose en el refinamiento del movimiento así derivado, las muestras de predicción dual finales de la CU se calculan interpolando las muestras de predicción L0/L1 a lo largo de la trayectoria de movimiento basándose en el modelo de flujo óptico.
El DMVR es una técnica de predicción dual para fusionar bloques con dos MV inicialmente señalados que se puede refinar aún más utilizando la predicción de coincidencia bilateral.
La fig. 5 es una ilustración de la coincidencia bilateral utilizada en DMVR. La coincidencia bilateral se utiliza para derivar información de movimiento de la CU actual encontrando la coincidencia más cercana entre dos bloques a lo largo de la trayectoria de movimiento de la CU actual en dos imágenes de referencia diferentes. La función de coste utilizada en el proceso de coincidencia es la suma de diferencia absoluta (SAD) submuestreada por filas. Una vez realizado el proceso de coincidencia, los MV refinados se utilizan para la compensación de movimiento en la etapa de predicción, el cálculo de la intensidad de los límites en el filtro de desbloqueo, la predicción del vector de movimiento temporal para imágenes posteriores y la predicción del vector de movimiento espacial entre CTU para las CU posteriores. Bajo el supuesto de una trayectoria de movimiento continuo, los vectores de movimiento MV0 y MV1 que apuntan a los dos bloques de referencia serán proporcionales a las distancias temporales, es decir, TD0 y TD1, entre la imagen actual y las dos imágenes de referencia. Como caso especial, cuando la imagen actual está temporalmente entre las dos imágenes de referencia y la distancia temporal desde la imagen actual a las dos imágenes de referencia es la misma, la coincidencia bilateral se convierte en MV bidireccional basada en espejo. El VVC ahora actual ha introducido MMVD además del modo de fusión existente. En el modo de fusión existente, la información de movimiento derivada implícitamente se utiliza directamente para la generación de muestras de predicción de la CU actual. En el modo MMVD, después de seleccionar un candidato de fusión, la información de los MVD señalados lo refina aún más.
Un indicador MMVD se señala justo después de enviar un indicador de omisión y un indicador de fusión para especificar si se utiliza el modo MMVD para una CU. La información del modo MMVD incluye un indicador de candidato de fusión, un índice de distancia para especificar la magnitud del movimiento y un índice de dirección para indicar la dirección del movimiento.
En el modo MMVD, sólo se permite seleccionar uno de los dos primeros candidatos en la lista de fusión como MV inicial, y se señala el indicador de candidato de fusión para especificar cuál de los dos primeros candidatos se utiliza. La fig. 6 es una ilustración de los puntos de búsqueda utilizados en MMVD. Se añade un desplazamiento, bien al componente horizontal, o bien al componente vertical del MV inicial para derivar los puntos de búsqueda. El índice de distancia especifica información sobre la magnitud del movimiento e indica un desplazamiento predefinido desde el punto inicial, y el índice de dirección representa la dirección del desplazamiento relativo al punto inicial a través de una asignación predefinida desde índices de dirección hasta señales de desplazamiento.
El significado del signo de desplazamiento asignado podría variar según la información de los MV iniciales. Cuando el MV inicial es un MV de predicción única o un MV de predicción dual con su o sus imágenes de referencia apuntando al mismo lado de la imagen actual (es decir, los POC de hasta dos imágenes de referencia son más grandes que el POC de imagen actual, o ambos son más pequeños que el POC de imagen actual), el signo de desplazamiento asignado especifica el signo del desplazamiento de MV añadido al MV inicial. Cuando el MV inicial es un MV de predicción dual con sus dos vectores de movimiento apuntando a diferentes lados de la imagen actual (es decir, el POC de una imagen de referencia es mayor que el POC de imagen actual y el POC de otra imagen de referencia es más pequeño que el POC de imagen actual), el signo de desplazamiento asignado especifica el signo del desplazamiento de MV añadido al vector de movimiento L0 del MV inicial y el signo opuesto del desplazamiento de MV añadido al vector de movimiento L1 del MV inicial.
A continuación, ambos componentes de desplazamiento de MV se derivan de las distancias y señales de MMVD señalizadas, y los MVD finales se derivan además de los componentes de desplazamiento de MV.
El VVC ahora actual también ha introducido el modo SMVD. Con el modo SMVD, la información de movimiento que incluye índices de imágenes de referencia tanto de L0 como de L1 y MVD de L1 no se señala sino que se deriva. En el codificador, la estimación del movimiento SMVD comienza con la evaluación de MV inicial. El conjunto de candidatos de MV iniciales se compone del MV obtenido de la búsqueda de predicción única, el MV obtenido de la búsqueda de predicción dual y los MV de la lista AMVP. El candidato MV inicial con el menor coste de distorsión de velocidad se elige como MV inicial para la búsqueda de movimiento SMVD.
El VVC ahora actual también ha introducido BWA. En HEVC, la señal de predicción dual se genera promediando dos señales de predicción obtenidas a partir de dos imágenes de referencia y/o utilizando dos vectores de movimiento. En el VVC ahora actual, con BWA, el modo de predicción dual se extiende más allá del simple promedio para permitir el promedio ponderado de las dos señales de predicción.
En el VVC ahora actual, se permiten cinco pesos en el BWA. Para cada CU predicha dual, el peso se determina de dos maneras. Para una CU que no es de fusión, el índice de peso se señala después de la diferencia del vector de movimiento, mientras que para una CU de fusión, el índice de peso se infiere de los bloques contiguos basándose en el índice candidato de fusión. La predicción dual de promedio ponderado solamente se aplica a las CU con 256 o más muestras de luma (es decir, el ancho de la CU multiplicado por la altura de la CU es mayor o igual a 256). Para imágenes sin utilizar predicción hacia atrás, se utilizan los cinco pesos. Para imágenes que utilizan predicción hacia atrás, sólo se utiliza un subconjunto predefinido de tres pesos de los cinco.
El VVC ahora actual también ha introducido la derivación de candidatos de fusión promedio por pares. En la derivación de candidatos de fusión promedio por pares, los candidatos promedio por pares se generan promediando pares predefinidos de candidatos en la lista de candidatos de fusión existente. Los vectores de movimiento promediados se calculan por separado para cada lista de referencia. Cuando ambos vectores de movimiento están disponibles en una lista, estos dos vectores de movimiento se promedian incluso cuando apuntan a imágenes de referencia diferentes; cuando sólo hay un vector de movimiento disponible, este vector de movimiento se utiliza directamente; y cuando no hay ningún vector de movimiento disponible, la lista se mantiene inválida. Cuando la lista de fusión no está completa después de añadir los candidatos de fusión promedio por pares, se insertan cero MVP al final hasta que se encuentre el número máximo de candidatos de fusión.
La base de código de software de referencia actual para el VVC ahora actual, conocido como modelo de prueba VVC (VTM), también ha introducido el modo SbTMVP. De manera similar a la predicción del vector de movimiento temporal (TMVP) en HEVC, SbTMVP utiliza el campo de movimiento en la imagen colocada para mejorar la predicción del vector de movimiento y el modo de fusión para las CU en la imagen actual. La misma imagen colocada utilizada por TMVP se utiliza para SbTMVP. El SbTMVP se diferencia de TMVP en los dos aspectos principales siguientes: primero, el TMVP predice el movimiento a nivel de CU, pero el SbTMVP predice el movimiento a nivel sub-CU, y segundo, mientras que el TMVP recupera los vectores de movimiento temporal del bloque colocado en la imagen colocada (el bloque colocado es el bloque inferior derecho o central en relación con la CU actual), el SbTMVP aplica un cambio de movimiento antes de recuperar la información de movimiento temporal de la imagen colocada, donde el cambio de movimiento se obtiene del vector de movimiento de uno de los bloques espaciales contiguos de la CU actual.
La fig. 7A y la fig. 7B ilustran la operación del modo SbTMVP. El SbTMVP predice los vectores de movimiento de las subCU dentro de la CU actual en dos etapas. La fig. 7A ilustra la primera etapa, donde los contiguos espaciales se examinan en el orden de A1, B1, B0 y A0. Tan pronto como se identifica el primer bloque contiguo espacial que tiene un vector de movimiento que utiliza la imagen colocada como imagen de referencia, se selecciona este vector de movimiento para que sea el cambio de movimiento que se ha de aplicar. Cuando no se identifica dicho movimiento entre los contiguos espaciales, a continuación, el cambio de movimiento se establece a (0, 0). La fig. 7B ilustra la segunda etapa, donde se aplica el cambio de movimiento identificado en la primera etapa (es decir, se añade a las coordenadas del bloque actual) para obtener información de movimiento de nivel sub-CU (vectores de movimiento e índices de referencia) de la imagen colocada. La ilustración empleada en la fig. 7B muestra un ejemplo donde el cambio de movimiento se establece para bloquear el movimiento de A1. A continuación, para cada subCU, la información de movimiento de su bloque correspondiente (la cuadrícula de movimiento más pequeña que cubre la muestra central) en la imagen colocada se utiliza para derivar la información de movimiento para la subCU. Una vez identificada la información de movimiento de la sub-CU colocada, se convierte a los vectores de movimiento e índices de referencia de la sub-CU actual de manera similar al proceso TMVP de HEVC, donde se aplica la escala de movimiento temporal para alinear las imágenes de referencia de los vectores de movimiento temporal a las de la CU actual.
En la tercera versión de VTM (VTM3), se utiliza una lista de fusión basada en subbloques combinados que contiene tanto candidatos de SbTMVP como candidatos de fusión afines para la señalización del modo de fusión basado en subbloques. El modo SbTMVP se habilita o deshabilita mediante un indicador de conjunto de parámetros de secuencia (SPS). Cuando el modo SbTMVP está habilitado, el predictor SbTMVP se añade como la primera entrada de la lista de candidatos de fusión basados en subbloques, y seguido de los candidatos de fusión afines. El tamaño de la lista de fusión basada en subbloques se señala en SPS y el tamaño máximo permitido de la lista de fusión basada en subbloques se fija en 5 en VTM3. El tamaño de la subCU utilizado en SbTMVP se fija en 8x8 y, al igual que en el modo de fusión afín, el modo SbTMVP sólo se aplica a las CU cuyo ancho y alto sean mayores o iguales a 8. La lógica de codificación del candidato de fusión de SbTMVP adicional es el mismo que para los otros candidatos de fusión, es decir, para cada CU en el segmento P o B, se realiza una verificación de RD adicional para decidir si se utiliza el candidato SbTMVP.
El VVC ahora actual ha introducido las nuevas herramientas de codificación intermodal, sin embargo, las restricciones relacionadas con la imagen de referencia a largo plazo, que están presentes en HEVC y el VVC ahora actual para el proceso de escalado para la derivación de candidatos de movimiento espacial y temporal, no están bien definidos en algunas de las nuevas herramientas. En esta descripción, proponemos varias restricciones relacionadas con las imágenes de referencia a largo plazo en las nuevas herramientas de codificación intermodal. Según la presente descripción, durante la operación de una herramienta de codificación intermodal en un bloque codificado intermodal, se realizará una determinación con respecto a si una o más de las imágenes de referencia asociadas con un bloque codificado intermodal están implicadas en la operación de la herramienta de codificación intermodal son imágenes de referencia a largo plazo, y, a continuación, basándose en la determinación, se impondrán restricciones a la operación de la herramienta de codificación intermodal en el bloque codificado intermodal.
Según una realización de la presente descripción, la herramienta de codificación intermodal comprende una generación de candidatos de fusión promedio por pares.
En un ejemplo, cuando un candidato de fusión promediado implicado en la generación de candidatos de fusión promedio por pares se genera a partir de un par predefinido de candidatos que comprende una imagen de referencia que es una imagen de referencia a largo plazo y otra imagen de referencia que no es una imagen de referencia a largo plazo, el candidato de fusión promediado se considera inválido.
En el mismo ejemplo, durante la generación de un candidato de fusión promediado a partir de un par predefinido de candidatos que comprenden dos imágenes de referencia que son ambas imágenes de referencia a largo plazo, se prohíbe el proceso de escalado.
Según otra realización de la presente descripción, la herramienta de codificación intermodal comprende BDOF y el bloque codificado intermodal es un bloque de predicción bidireccional.
En un ejemplo, cuando se determina que una imagen de referencia del bloque de predicción bidireccional implicado en la operación de BDOF es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque de predicción bidireccional implicada en la operación de BDOF no es una imagen de referencia a largo plazo, se prohíbe la realización de BDOF.
Según otra realización de la presente descripción, la herramienta de codificación intermodal comprende DMVR y el bloque codificado intermodal es un bloque de predicción bidireccional.
En un ejemplo, cuando se determina que una imagen de referencia del bloque de predicción bidireccional implicado en la operación de DMVR es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque de predicción bidireccional implicado en la operación de DMVR no es una imagen de referencia a largo plazo, se prohíbe la realización de DMVR.
En otro ejemplo, cuando se determina que una imagen de referencia del bloque de predicción bidireccional implicado en la operación de DMVR es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque de predicción bidireccional implicado en la operación de DMVR no es una imagen de referencia a largo plazo, el alcance del rendimiento de DMVR se limita al rendimiento de DMVR de píxeles enteros.
Según otra realización de la presente descripción, la herramienta de codificación intermodal comprende la derivación de candidatos MMVD.
En un ejemplo, cuando se determina que un candidato a vector de movimiento implicado en la derivación de candidatos MMVD tiene su vector de movimiento apuntando a una imagen de referencia que es una imagen de referencia a largo plazo, se prohíbe el uso del candidato a vector de movimiento como un vector de movimiento base (también conocido como vector de movimiento inicial).
En un segundo ejemplo, cuando una imagen de referencia del bloque codificado intermodal implicado en la derivación de candidatos MMVD es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque codificado intermodal implicado en la derivación de candidatos MMVD no es una imagen de referencia a largo plazo, y además, cuando el vector de movimiento base es un vector de movimiento bidireccional, a continuación, para el vector de movimiento que está apuntando a la imagen de referencia a largo plazo y que también está contenido en el vector de movimiento base bidireccional, se prohíbe la modificación de un vector de movimiento mediante la diferencia de vector de movimiento señalizada (MVD).
En el mismo segundo ejemplo, el proceso de modificación de MVD propuesto será el que se muestra en el bloque inmediatamente posterior a este párrafo, donde las partes resaltadas del texto muestran la modificación propuesta del proceso de modificación de MVD existente en el VVC ahora actual.
En un tercer ejemplo, cuando al menos una imagen de referencia del bloque codificado intermodal implicado en la derivación de candidatos MMVD es una imagen de referencia a largo plazo, y además cuando el vector de movimiento base es un vector de movimiento bidireccional, a continuación, se prohíbe el proceso de escalado en la derivación del candidato MMVD final.
Según una o más realizaciones de la presente descripción, la herramienta de codificación intermodal comprende la derivación de candidatos SMVD.
En un ejemplo, cuando se determina que un candidato a vector de movimiento tiene su vector de movimiento apuntando a una imagen de referencia que es una imagen de referencia a largo plazo, se prohíbe el uso del candidato a vector de movimiento como vector de movimiento base.
En algunos ejemplos, cuando al menos una imagen de referencia del bloque codificado intermodal implicado en la derivación de candidatos SMVD es una imagen de referencia a largo plazo, y además cuando el vector de movimiento base es un vector de movimiento bidireccional, a continuación, para un vector de movimiento que está apuntando a la imagen de referencia a largo plazo y que también está contenido en el vector de movimiento base bidireccional, se prohíbe la modificación de dicho vector de movimiento mediante MVD señalizado. En otros ejemplos, cuando una imagen de referencia del bloque codificado intermodal implicado en la derivación de candidatos SMVD es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque codificado intermodal implicado en la derivación de candidatos SMVD no es una imagen de referencia a largo plazo, y además, cuando el vector de movimiento base es un vector de movimiento bidireccional, a continuación, para el vector de movimiento que está apuntando a la imagen de referencia a largo plazo y que también está contenido en el vector de movimiento base bidireccional, se prohíbe la modificación del vector de movimiento mediante el MVD señalizado. Según otra realización de la presente descripción, la herramienta de codificación intermodal comprende una predicción dual con promedio ponderado y el bloque codificado intermodal es un bloque de predicción bidireccional. En un ejemplo, cuando se determina que al menos una imagen de referencia del bloque de predicción bidireccional implicado en la predicción bidireccional con promedio ponderado es una imagen de referencia a largo plazo, se prohíbe el uso de ponderación inigualable.
Según otra realización de la presente descripción, la herramienta de codificación intermodal comprende la derivación de candidatos a vectores de movimiento y el bloque codificado intermodal es un bloque codificado SbTMVP.
En un ejemplo, la misma restricción para la derivación de candidatos a vector de movimiento en un bloque codificado con TMVP convencional se utiliza en la derivación de candidatos a vector de movimiento en un bloque codificado con SbTMVP.
En un refinamiento del ejemplo anterior, la restricción para la derivación de candidatos a vector de movimiento a utilizar tanto en bloques codificados TMVP convencionales como en bloques codificados SbTMVP comprende, por un lado, la consideración de un vector de movimiento del bloque contiguo temporal como inválido si, dentro de las dos imágenes de referencia que comprenden la imagen de referencia objetivo y la imagen de referencia para el bloque contiguo, una imagen de referencia es una imagen de referencia a largo plazo y la otra imagen de referencia no es una imagen de referencia a largo plazo, y por otro lado, cuando tanto la imagen de referencia objetivo como la imagen de referencia para el bloque contiguo son imágenes de referencia a largo plazo, la prohibición de la operación del proceso de escalado en el vector de movimiento del bloque contiguo temporal y utiliza el vector de movimiento del bloque contiguo temporal directamente como predicción del vector de movimiento para el bloque actual.
Según otra realización de la presente descripción, la herramienta de codificación intermodal comprende el uso de un modelo de movimiento afín en la derivación de candidatos a vectores de movimiento.
En un ejemplo, cuando se determina que la imagen de referencia implicada en el uso del modelo de movimiento afín es una imagen de referencia a largo plazo, se prohíbe el uso del modelo de movimiento afín en la derivación de candidatos a vectores de movimiento.
En uno o más ejemplos, las funciones descritas pueden implementarse en hardware, software, firmware o cualquier combinación de los mismos. Si se implementan en software, las funciones pueden almacenarse o transmitirse, como una o más instrucciones o código, en un medio legible por ordenador y ejecutarse mediante una unidad de procesamiento basada en hardware. Los medios legibles por ordenador pueden incluir medios de almacenamiento legibles por ordenador, que corresponden a un medio tangible tal como medios de almacenamiento de datos, o medios de comunicación que incluyen cualquier medio que facilite la transferencia de un programa informático de un lugar a otro, por ejemplo, según un protocolo de comunicación. De esta manera, los medios legibles por ordenador generalmente pueden corresponder a (1) medios de almacenamiento tangibles legibles por ordenador que no son transitorios o (2) un medio de comunicación tal como una señal u onda portadora. Los medios de almacenamiento de datos pueden ser cualquier medio disponible al que puedan acceder uno o más ordenadores o uno o más procesadores para recuperar instrucciones, códigos y/o estructuras de datos para la implementación de las implementaciones descritas en la presente solicitud. Un producto de programa informático puede incluir un medio legible por ordenador.
Además, los métodos anteriores se pueden implementar utilizando un aparato que incluye uno o más circuitos, que incluyen circuitos integrados de aplicación específica (ASIC), procesadores de señales digitales (DSP), dispositivos de procesamiento de señales digitales (DSPD), dispositivos lógicos programables (PLD), matrices de puertas programables en campo (FPGA), controladores, microcontroladores, microprocesadores u otros componentes electrónicos. El aparato puede utilizar los circuitos en combinación con otros componentes de hardware o software para realizar los métodos descritos anteriormente. Cada módulo, submódulo, unidad o subunidad dado a conocer anteriormente puede implementarse al menos parcialmente utilizando los uno o más circuitos.
Se apreciará que la presente invención no se limita a los ejemplos exactos descritos anteriormente e ilustrados en los dibujos adjuntos, y que se pueden realizar diversas modificaciones y cambios sin desviarse del alcance de la misma. Se pretende que el alcance de la invención sólo esté limitado por las reivindicaciones adjuntas.
Claims (7)
- REIVINDICACIONES1 Un método para decodificación de vídeo, que comprende:la determinación de si una o más de las imágenes de referencia asociadas con un bloque codificado intermodal implicado en una operación de una herramienta de codificación intermodal son imágenes de referencia a largo plazo; yla restricción de la operación de una herramienta de codificación intermodal en el bloque codificado intermodal basándose en la determinación,en donde en el caso de que la herramienta de codificación intermodal comprenda flujo óptico bidireccional, BDOF, y el bloque codificado intermodal sea un bloque de predicción bidireccional, la restricción de la operación de la herramienta de codificación intermodal en el bloque codificado intermodal basado en la determinación comprende: la prohibición del desempeño del BDOF al determinar que una imagen de referencia del bloque de predicción bidireccional es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque de predicción bidireccional no es una imagen de referencia a largo plazo.
- 2. - El método de la reivindicación 1, en donde en el caso de que la herramienta de codificación intermodal comprenda el refinamiento del vector de movimiento del lado del decodificador, DMVR, y el bloque codificado intermodal sea un bloque de predicción bidireccional, lo que restringe la operación de la herramienta de codificación intermodal en el bloque codificado intermodal basado en la determinación comprende:la prohibición del desempeño del DMVR al determinar que una imagen de referencia del bloque de predicción bidireccional es una imagen de referencia a largo plazo y la otra imagen de referencia del bloque de predicción bidireccional no es una imagen de referencia a largo plazo.
- 3. - El método de la reivindicación 1, en donde en el caso de que la herramienta de codificación intermodal comprenda el proceso de derivación para un modo de fusión con candidatos a diferentes vectores de movimiento, MMVD, y el bloque codificado intermodal sea un bloque de predicción bidireccional, la restricción de la operación de la herramienta de codificación intermodal en el bloque codificado intermodal basado en la determinación comprende: cuando al menos una imagen de referencia del bloque codificado intermodal es una imagen de referencia a largo plazo, y además cuando el vector de movimiento base es un vector de movimiento bidireccional, la prohibición del proceso de escalado en la derivación de un candidato MMVD final.
- 4. - El método de la reivindicación 1, en donde en el caso de que la herramienta de codificación intermodal comprenda una predicción de vector de movimiento temporal basada en subbloques, SbTMVP, y el bloque codificado intermodal sea un bloque codificado SbTMVP,La restricción de la operación de la herramienta de codificación intermodal en el bloque codificado intermodal basándose en la determinación comprende:el uso de la misma restricción para el proceso de derivación para candidatos a vector de movimiento en un bloque codificado de predicción de vector de movimiento temporal convencional, TMVP, en el proceso de derivación para candidatos a vector de movimiento en un bloque codificado SbTMVP,en donde la misma restricción para el proceso de derivación de candidatos a vector de movimiento a utilizar tanto en los bloques codificados de TMVP convencionales como en los bloques codificados de SbTMVP comprende:la consideración de un vector de movimiento de un bloque contiguo temporal como inválido si, dentro de las dos imágenes de referencia que comprenden una imagen de referencia objetivo y una imagen de referencia para el bloque contiguo temporal, una imagen de referencia es una imagen de referencia a largo plazo y la otra imagen de referencia no es una imagen de referencia a largo plazo; ocuando tanto una imagen de referencia objetivo como una imagen de referencia para un bloque contiguo temporal son imágenes de referencia a largo plazo, la prohibición de la operación del proceso de escalado en el vector de movimiento del bloque contiguo temporal y el uso del vector de movimiento del bloque contiguo temporal directamente como la predicción del vector de movimiento para el bloque actual.
- 5. - Un dispositivo informático que comprende:uno o más procesadores;un almacenamiento no transitorio acoplado al uno o más procesadores; yuna pluralidad de programas almacenados en el almacenamiento no transitorio que, cuando son ejecutados por el uno o más procesadores, hacen que el dispositivo informático realice el método para decodificación de vídeo de cualquiera de las reivindicaciones 1-4.
- 6. - Un medio de almacenamiento no transitorio legible por ordenador que almacena una pluralidad de programas para su ejecución por un dispositivo informático que tiene uno o más procesadores, en donde la pluralidad de programas, cuando son ejecutados por uno o más procesadores, hacen que el dispositivo informático realice el método para decodificación de vídeo de cualquiera de las reivindicaciones 1 -4.
- 7. - Un producto de programa informático, que comprende un medio legible por ordenador que almacena instrucciones, en donde, cuando las instrucciones son ejecutadas por un procesador, las instrucciones hacen que el procesador realice el método para decodificación de vídeo de cualquiera de las reivindicaciones 1-4.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201962808271P | 2019-02-20 | 2019-02-20 | |
PCT/US2020/018918 WO2020172341A1 (en) | 2019-02-20 | 2020-02-19 | Constrained motion vector derivation for long-term reference pictures in video coding |
Publications (1)
Publication Number | Publication Date |
---|---|
ES2968163T3 true ES2968163T3 (es) | 2024-05-08 |
Family
ID=72144437
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
ES20760226T Active ES2968163T3 (es) | 2019-02-20 | 2020-02-19 | Derivación de vector de movimiento restringido para imágenes de referencia a largo plazo en codificación de video |
Country Status (13)
Country | Link |
---|---|
US (1) | US20210377520A1 (es) |
EP (2) | EP4262208A3 (es) |
JP (3) | JP7218449B2 (es) |
KR (3) | KR20240137710A (es) |
CN (6) | CN117041556B (es) |
DK (1) | DK3912357T3 (es) |
ES (1) | ES2968163T3 (es) |
FI (1) | FI3912357T3 (es) |
HU (1) | HUE064569T2 (es) |
MX (1) | MX2021010062A (es) |
PL (1) | PL3912357T3 (es) |
PT (1) | PT3912357T (es) |
WO (1) | WO2020172341A1 (es) |
Families Citing this family (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CA3132582A1 (en) * | 2019-03-07 | 2020-09-10 | Digitalinsights Inc. | Image encoding/decoding method and apparatus |
EP3939303A1 (en) * | 2019-03-11 | 2022-01-19 | VID SCALE, Inc. | Symmetric merge mode motion vector coding |
CA3143556A1 (en) * | 2019-06-14 | 2020-12-17 | Lg Electronics Inc. | Method and device for image coding using motion vector differences |
KR102622468B1 (ko) | 2019-06-14 | 2024-01-09 | 엘지전자 주식회사 | 인터 예측 기반 영상 코딩 방법 및 장치 |
CN114080813A (zh) * | 2019-06-14 | 2022-02-22 | Lg 电子株式会社 | 使用运动矢量的图像编译的方法和装置 |
KR102640262B1 (ko) | 2019-06-24 | 2024-02-23 | 엘지전자 주식회사 | 움직임 벡터 차분들을 이용한 영상 코딩 방법 및 장치 |
KR102640263B1 (ko) | 2019-06-24 | 2024-02-23 | 엘지전자 주식회사 | 움직임 벡터를 이용한 영상 코딩 방법 및 장치 |
CA3145240C (en) | 2019-06-24 | 2024-06-11 | Lg Electronics Inc. | Inter prediction-based image coding method and apparatus |
EP3984227A4 (en) * | 2019-07-27 | 2022-08-17 | Beijing Bytedance Network Technology Co., Ltd. | TOOL USE RESTRICTIONS BASED ON TYPES OF REFERENCE IMAGES |
CN110545424B (zh) * | 2019-08-21 | 2021-05-11 | 浙江大华技术股份有限公司 | 基于mmvd模式的帧间预测方法、视频编码方法及相关装置、设备 |
WO2023055199A1 (ko) * | 2021-09-30 | 2023-04-06 | 한국전자통신연구원 | 영상 부호화/복호화를 위한 방법, 장치 및 기록 매체 |
EP4440110A1 (en) * | 2022-01-04 | 2024-10-02 | Hyundai Motor Company | Method and device for video coding using improved merge with motion vector difference |
WO2024155108A1 (ko) * | 2023-01-19 | 2024-07-25 | 인텔렉추얼디스커버리 주식회사 | 인터 예측 기반의 영상 부호화/복호화 방법 및 장치, 그리고 비트스트림을 저장한 기록 매체 |
Family Cites Families (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2003090473A1 (fr) * | 2002-04-19 | 2003-10-30 | Matsushita Electric Industrial Co., Ltd. | Procede de calcul de vecteurs de mouvement |
ES2644005T3 (es) * | 2002-04-19 | 2017-11-27 | Panasonic Intellectual Property Corporation Of America | Procedimiento de cálculo de vectores de movimiento |
KR100491530B1 (ko) * | 2002-05-03 | 2005-05-27 | 엘지전자 주식회사 | 모션 벡터 결정 방법 |
US8170116B2 (en) * | 2006-03-27 | 2012-05-01 | Nokia Corporation | Reference picture marking in scalable video encoding and decoding |
US20100091845A1 (en) * | 2006-03-30 | 2010-04-15 | Byeong Moon Jeon | Method and apparatus for decoding/encoding a video signal |
KR101379188B1 (ko) * | 2010-05-17 | 2014-04-18 | 에스케이 텔레콤주식회사 | 인트라 블록 및 인터 블록이 혼합된 코딩블록을 이용하는 영상 부호화/복호화 장치 및 그 방법 |
KR101954007B1 (ko) * | 2011-06-30 | 2019-03-04 | 소니 주식회사 | 화상 처리 장치 및 방법 |
CN107257481B (zh) * | 2011-10-27 | 2019-12-10 | 太阳专利托管公司 | 编码方法、解码方法、编码装置、解码装置 |
MX2013012223A (es) * | 2011-10-28 | 2013-11-01 | Panasonic Corp | Metodo de codificacion de imagen, metodo de decodificacion de imagen, aparato de codificacion de imagen y aparato de decodificacion de imagen. |
EP2953367A1 (en) * | 2011-11-08 | 2015-12-09 | Samsung Electronics Co., Ltd | Method and apparatus for motion vector determination in video encoding or decoding |
US9503720B2 (en) * | 2012-03-16 | 2016-11-22 | Qualcomm Incorporated | Motion vector coding and bi-prediction in HEVC and its extensions |
US20130343459A1 (en) * | 2012-06-22 | 2013-12-26 | Nokia Corporation | Method and apparatus for video coding |
RU2624578C2 (ru) * | 2012-07-02 | 2017-07-04 | Самсунг Электроникс Ко., Лтд. | Способ и устройство для прогнозирования вектора движения для кодирования видео или декодирования видео |
WO2014165555A1 (en) | 2013-04-02 | 2014-10-09 | Vid Scale, Inc. | Enhanced temporal motion vector prediction for scalable video coding |
EP2978221A4 (en) * | 2013-04-05 | 2016-11-16 | Samsung Electronics Co Ltd | METHOD AND DEVICE FOR MULTI-LAYER VIDEO DECODING AND MULTI-LAYER VIDEO ENCODING METHOD AND DEVICE |
US9509999B2 (en) * | 2013-06-11 | 2016-11-29 | Qualcomm Incorporated | Inter-layer prediction types in multi-layer video coding |
CN105493505B (zh) * | 2014-06-19 | 2019-08-06 | 微软技术许可有限责任公司 | 统一的帧内块复制和帧间预测模式 |
US10412387B2 (en) * | 2014-08-22 | 2019-09-10 | Qualcomm Incorporated | Unified intra-block copy and inter-prediction |
US9918105B2 (en) * | 2014-10-07 | 2018-03-13 | Qualcomm Incorporated | Intra BC and inter unification |
WO2016200043A1 (ko) * | 2015-06-10 | 2016-12-15 | 엘지전자 주식회사 | 비디오 코딩 시스템에서 가상 참조 픽처 기반 인터 예측 방법 및 장치 |
CN108293131B (zh) * | 2015-11-20 | 2021-08-31 | 联发科技股份有限公司 | 基于优先级运动矢量预测子推导的方法及装置 |
US10555002B2 (en) * | 2016-01-21 | 2020-02-04 | Intel Corporation | Long term reference picture coding |
KR102435500B1 (ko) * | 2016-10-06 | 2022-08-23 | 세종대학교산학협력단 | 비디오 신호의 복호화 방법 및 이의 장치 |
US20180199057A1 (en) * | 2017-01-12 | 2018-07-12 | Mediatek Inc. | Method and Apparatus of Candidate Skipping for Predictor Refinement in Video Coding |
US10595035B2 (en) * | 2017-03-22 | 2020-03-17 | Qualcomm Incorporated | Constraining motion vector information derived by decoder-side motion vector derivation |
WO2020085800A1 (ko) * | 2018-10-23 | 2020-04-30 | 주식회사 윌러스표준기술연구소 | 서브블록 기반의 모션 보상을 이용한 비디오 신호 처리 방법 및 장치 |
CN111448797B (zh) * | 2018-11-16 | 2022-09-30 | 北京字节跳动网络技术有限公司 | 用于帧间预测插值的参考尺寸 |
WO2020145656A1 (ko) * | 2019-01-09 | 2020-07-16 | 엘지전자 주식회사 | Tmvp 후보의 가용 여부를 시그널링하는 방법 및 장치 |
US10752213B2 (en) * | 2019-01-09 | 2020-08-25 | Capital One Services, Llc | Detecting an event and automatically obtaining video data |
US11025936B2 (en) * | 2019-01-25 | 2021-06-01 | Tencent America LLC | Method and apparatus for video coding |
JP7263529B2 (ja) * | 2019-02-14 | 2023-04-24 | 北京字節跳動網絡技術有限公司 | デコーダ側精緻化ツールのサイズ選択アプリケーション |
-
2020
- 2020-02-19 KR KR1020247030193A patent/KR20240137710A/ko active Application Filing
- 2020-02-19 FI FIEP20760226.9T patent/FI3912357T3/fi active
- 2020-02-19 MX MX2021010062A patent/MX2021010062A/es unknown
- 2020-02-19 PL PL20760226.9T patent/PL3912357T3/pl unknown
- 2020-02-19 CN CN202311061801.4A patent/CN117041556B/zh active Active
- 2020-02-19 EP EP23195885.1A patent/EP4262208A3/en active Pending
- 2020-02-19 HU HUE20760226A patent/HUE064569T2/hu unknown
- 2020-02-19 JP JP2021548645A patent/JP7218449B2/ja active Active
- 2020-02-19 CN CN202311040861.8A patent/CN116915982B/zh active Active
- 2020-02-19 ES ES20760226T patent/ES2968163T3/es active Active
- 2020-02-19 KR KR1020237002587A patent/KR102706608B1/ko active IP Right Grant
- 2020-02-19 CN CN202210001852.7A patent/CN114339237B/zh active Active
- 2020-02-19 EP EP20760226.9A patent/EP3912357B1/en active Active
- 2020-02-19 CN CN202311176081.6A patent/CN117119181B/zh active Active
- 2020-02-19 CN CN202080013526.7A patent/CN113424539A/zh active Pending
- 2020-02-19 CN CN202311109728.3A patent/CN116915983B/zh active Active
- 2020-02-19 PT PT207602269T patent/PT3912357T/pt unknown
- 2020-02-19 KR KR1020217026525A patent/KR102492738B1/ko active IP Right Grant
- 2020-02-19 WO PCT/US2020/018918 patent/WO2020172341A1/en unknown
- 2020-02-19 DK DK20760226.9T patent/DK3912357T3/da active
-
2021
- 2021-08-13 US US17/402,466 patent/US20210377520A1/en active Pending
-
2023
- 2023-01-25 JP JP2023009229A patent/JP7447322B2/ja active Active
-
2024
- 2024-02-28 JP JP2024028537A patent/JP2024069266A/ja active Pending
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
ES2968163T3 (es) | Derivación de vector de movimiento restringido para imágenes de referencia a largo plazo en codificación de video | |
ES2981908T3 (es) | Métodos y dispositivos para aplicar de forma selectiva el flujo óptico bidireccional y el refinamiento del vector de movimiento en el decodificador para la codificación de video | |
JP6689499B2 (ja) | 画像予測方法および関連装置 | |
TWI720532B (zh) | 在視訊編解碼系統中視訊處理的方法以及裝置 | |
ES2951321T3 (es) | Procedimiento y aparato para codificar información de movimiento, y procedimiento y aparato para decodificar la misma | |
WO2017148345A1 (en) | Method and apparatus of video coding with affine motion compensation | |
ES2982369T3 (es) | Resiliencia de errores y procesamiento en paralelo para derivación de vector de movimiento de lado de decodificador | |
TW202127890A (zh) | 視訊編解碼方法及裝置 | |
TW202019179A (zh) | 視訊編解碼系統的運動向量湊整統一的方法以及裝置 | |
CN112840645A (zh) | 视频编码系统中组合多个预测子用于块预测的方法及装置 | |
WO2019242686A1 (en) | Method and apparatus of motion vector buffer management for video coding system | |
BR112016014080B1 (pt) | Método de codificação de múltiplas hipóteses direta de um bloco de imagem, método de decodificação de múltiplas hipóteses direta de um bloco de imagem, aparelho de codificação de duas hipóteses direta de um bloco de imagem, e aparelho de decodificação de duas hipóteses direta de um bloco de imagem | |
CN117321992A (zh) | 自适应运动候选列表 | |
WO2024037638A1 (en) | Method, apparatus, and medium for video processing | |
TW202349958A (zh) | 視頻編解碼的方法和裝置 | |
TW202345594A (zh) | 視訊編解碼方法和裝置 |