7.12. Cómo tratar con telecine y entrelazado con DVDs NTSC

Introducción.  Le sugiero que visite esta página si no entiende mucho lo que está escrito en este documento: http://www.divx.com/support/guides/guide.php?gid=10 Esta URL enlaza a una descripción de lo que es telecine inteligible y razonablemente comprensible.

Por razones técnicas pertinentes a las limitaciones de reciente hardware de televisión, todos los videos que están pensados para ser reproducidos en una televisión NTSC deben tener 59.94 campos por segundo. Las películas hechas-para-TV y los espectáculos son grabados directamente a 24 o 23.976 marcos por segundo. Cuando una película para cine DVD es masterizada, el video es entonces convertido para la televisión usando un proceso llamado telecine.

En un DVD, el video nunca se almacena como 59.94 campos por segundo. Para video que es originalmente a 59.94, cada par de campos es combinado para formar un marco de imagen, resultando en 29.97 marcos por segundo. Los reproductores de DVD por hardware entonces leen un indicador embebido en el flujo de video para determinar si son las líneas pares o las impares las que deben formar el primer campo.

Normalmente, 23.976 marcos de imagen por segundo se mantienen así cuando son codificados en un DVD, y el reproductor de DVD debe realizar el telecine sobre la marcha. Algunas veces, sin embargo, el video es pasado por el proceso de telecine antes de ser almacenado en el DVD; incluso aunque tenga originalmente 23.976 marcos de imagen por segundo, se hace que tenga 59.94 campos por segundo, y es almacenado en disco como 29.97 marcos de imagen por segundo.

Cuando se observan como marcos individuales formados por 59.94 campos por segundo de video, telecine o viceversa, el entrelazado es claramente visible en cuanto hay movimiento, porque un campo (digamos, las líneas numeradas pares) representa un momento en el tiempo 1/59.94 de un segundo después de otro. Al reproducir video entrelazado en un ordenador se ve mal porque el monitor tiene una resolución mayor y porque el video es mostrado marco-tras-marco en lugar de campo-tras-campo.

Notas:

7.12.1. Cómo decir el tipo de video que tiene

7.12.1.1. Progresivo

Video progresivo fue grabado originalmente a 23.976 fps, y almacenado en el DVD sin alteración.

Cuando reproduce un DVD progresivo en MPlayer, MPlayer mostrará la siguiente línea tan pronto como comience la película:

 demux_mpg: 24fps progressive NTSC content detected, switching framerate.

Desde este punto de vista, demux_mpg nunca debe decir que encuentra "contenido a 30fps NTSC."

Cuando vea video progresivo, nunca debe ver ningún entrelazado. Tenga cuidado, sin embargo, porque algunas veces hay un poco de telecine mezclado, donde no se lo espera. He encontrado DVDs de espectáculos de TV que tienen un segundo de telecine en cada cambio de escena, o en lugares aleatorios incluso. Una vez vi un DVD que tenía el primer campo progresivo, y el segundo campo era telecine. Si quiere realmente saberlo, puede escanear la película entera:

mplayer dvd://1 -nosound -vo null -benchmark

Usando -benchmark hace que MPlayer reproduzca la película tan rápido como pueda; tenga en cuenta, dependiendo de su hardware, puede tardar bastante. Cada vez que demux_mpg informa de un cambio de tasa de bits, la línea inmediatamente por encima le dirá el tiempo en el que el cambio ha ocurrido.

Algunas veces el video progresivo es referido como "soft-telecine" porque está pensado para ser procesado en telecine por el reproductor de DVD.

7.12.1.2. Telecine

Video con telecine fue grabado originalmente a 23.976 fps, pero fue pasado por proceso de telecine antes de ser escrito en el DVD.

MPlayer no (nunca) informa de cambios en la tasa de bits cuando reproduce video con telecine.

Al ver video con telecine, verá artefactos de entrelazado, que parecen "parpadear": repetidamente aparecen y desaparecen. Puede verlo de cerca con

  1. mplayer dvd://1 -speed 0.1
  2. Busque una parte con movimiento.

  3. Localice un patrón de búsqueda-entrelazada y búsqueda-progresiva en marcos de imagen. Si el patrón que ve es PPPII,PPPII,PPPII,... entonces el video es con telecine. Si ve algún otro patrón, entonces el video puede que esté con telecine usando algún método no estándar y MEncoder no puede convertirlo sin pérdidas en progresivo. Si no ve ningún patrón, entonces lo más seguro es que sea entrelazado.

Algunas veces el video telecine es referido como "hard-telecine".

7.12.1.3. Entrelazado

El video entrelazado fue originalmente grabado a 59.94 campos por segundo, y almacenado en el DVD como 29.97 marcos por segundo. El entreñazado es el resultado de combinar pares de campos en marcos, porque en cada marco de imagen, cada campo ocupa 1/59.94 segundos.

Como en el video en telecine, MPlayer nunca debe informar de ningún cambio en la tasa de bits mientras reproduce contenido entrelazado.

Cuando ve video entrelazado de cerca con -speed 0.1, puede ver que cada marco simple es entrelazado.

7.12.1.4. Mezcla progresiva y telecine

Todo video "mezcla progresivo y telecine" originalmente es a 23.976 marcos por segundo, pero algunas partes de él terminan siendo en telecine.

Cuando MPlayer reproduce esta categoria, (a menudo de forma repetida) cambia entre "30fps NTSC" y "24fps progresivo NTSC". Consulte la parte de abajo de la salida de MPlayer para ver estos mensajes.

Deberá consultar las secciones de "30fps NTSC" para asegurarse de que es telecine, y no simplemente entrelazado.

7.12.1.5. Mezcla de progresivo y entrelazado

En el contenido "mezcla de progresivo y entrelazado", el video progresivo y entrelazado se colocan juntos.

Esta categoría es similar a "mezcla progresivo y telecine", hasta que examine las secciones de 30fps y vea que no tiene el patrón de telecine.

7.12.2. Cómo codificar cada categoría

Como dije antes al principio, las líneas de ejemplo de MEncoder de más abajo no son para ser usadas; solo son para demostrar los parámetros mínimos para codificar en cada categoría.

7.12.2.1. Progresivo

El video progresivo no requiere un filtrado especial para codificarlo. El único parámetro que seguramente necesita usar es -ofps 23.976. Si no lo hace, MEncoder intentará codificar a 29.97 fps y marcos duplicados.

mencoder dvd://1 -nosound -ovc lavc -ofps 23.976

7.12.2.2. Telecine

Telecine puede ser invertido para obtener el contenido 23.976 original, usando un proceso llamado telecine-inverso. MPlayer contiene dos filtros para conseguir esto: detc y ivtc. Puede leer la página de manual para ver las diferencias, pero para DVDs nunca he tenido problemas con ivtc. Note que siempre deberá hacer telecine-inverso antes de cualquier reescalado; a menos que realmente sepa lo que está haciendo, telecine-inverso antes de recortar también [1]. De nuevo, necesitará -ofps 23.976 también.

mencoder dvd://1 -nosound -vf ivtc=1 -ovc lavc -ofps 23.976

7.12.2.3. Entrelazado

Para la mayor parte de los casos prácticos no es posible obtener un video progresivo completo de un contenido entrelazado. La única manera de hacerlo sin perder la mitad de la resolución vertical es doblar la tasa de imágenes por segundo e intentar "adivinar" como se obtienen las correspondientes líneas para cada campo (esto ocasiona problemas - vea el método 3).

  1. Codifique el video en formato entrelazado. Normalmente, el entrelazado permite al codificador comprimir bien, pero libavcodec tiene dos parámetros específicos para jugar con video entrelazado un poco mejor: ildct y ilme. Además, es altamente recomendable usar mbd=2 [2] porque codifica los macrobloques como no entrelazados en lugares donde no hay movimiento. Note que -ofps NO es necesario aquí.

    mencoder dvd://1 -nosound -ovc lavc -lavcopts ildct:ilme:mbd=2

  2. Use un filtro de desentrelazado antes de codificar. Hay varios filtros disponibles para elegir, cada uno con sus ventajas y sus desventajas. Consulte mplayer -pphelp para ver qué hay disponible (grep "deint"), y busque en las listas de correo MPlayer para encontrar discusiones acerca de varios filtros. De nuevo, la tasa de bits por segundo no cambia, nada de -ofps. Además, el desentrelazado debe hacerse después del recortado [1] y antes del escalado.

    mencoder dvd://1 -nosound -vf pp=lb -ovc lavc

  3. Desafortunadamente, esta opción tiene fallos con MEncoder; funcionará bien con MEncoder G2, pero todavía no está disponible. Puede experimentar cuelgues del sistema. De todos modos, el propósito de -vf tfields es crear una tasa de bits completa por campo, que haga que la tasa completa sea de 59.94. La ventaja de esta aproximación es que no hay pérdida de datos; sin embargo, como cada marco viene solo con un campo, las líneas que faltan tienen que se interpoladas de alguna manera. No hay buenos métodos para generar estos datos que faltan, y el resultado será un poco similar al que se obtiene cuando se usan algunos filtros de desentrelazado. La generación de las líneas que faltan crean otros problemas, símplemente porque se dobla la cantidad de datos. Por eso, tasas de bits más altas para la codificación son requeridas para mantener la calidad, y se usa más potencia de CPU para la codificación y la decodificación. tfields tiene varias opciones distintas para crear las líneas que faltan en cada marco. Si usa este método, refiérase al manual, y elija la opción que mejor se ajuste para su material. Note que cuando use tfields tiene que especificar -fps y -ofps para doblar la tasa de bits de su fuente original.

    mencoder dvd://1 -nosound -vf tfields=2 -ovc lavc -fps 59.94 -ofps 59.94

  4. Si planea subescalar dramáticamente, puede codificar solo uno de los dos campos. Por supuesto, perderá la mitad de la resolución vertical, pero si planea subescalar a al menos 1/2 del original, la pérdida no importa mucho. El resultado será un archivo progresivo de 29.97 marcos por segundo. El procedimiento es usar -vf field, entonces recortar [1] y escalar apropiadamente. Recuerde que tiene que ajustar la escala para compensar la resolución vertical que está siendo perdida.

    mencoder dvd://1 -nosound -vf field=0 -ovc lavc

7.12.2.4. Mezcla de progresivo y telecine

Para mezclar video progresivo y telecine en un video completamente progresivo, las partes en telecine tienen que pasar por el proceso de telecine-inverso. Hay dos filtros que realizan esto nativamente, pero una solución mejor casi siempre es usar dos filtros conjuntamente (lea más adelante para más detalles).

  • Actualmente el método más fiable para tratar este tipo de video es, en lugar de hacer telecine-inverso con las partes en telecine, pasar a telecine las partes que no lo son y luego hacer telecine-inverso del video completo. ¿Suena confuso? softpulldown es un filtro que hadce que el video se haga completamente en telecine. Si se sigue softpulldown con alguno de entre detc o ivtc, el resultado final será completamente progresivo. El recortado y el escalado debe hacerse después de las operaciones de telecine-inverso, y -ofps 23.976 es necesario.

    mencoder dvd://1 -nosound -vf softpulldown,ivtc=1 -ovc lavc -ofps 23.976

  • -vf pullup está diseñado para hacer telecine-inverso con material en telecine mientras que deja el video progresivo como datos aislados. Pullup no funciona muy bien con el MEncoder actual, realmente está hecho para ser usado con MEncoder G2 (cuando esté listo). Funciona bien sin -ofps, pero -ofps se necesita para prevenir salida con saltos. Con -ofps, algunas veces falla. Los problemas vienen de mantener la sincronización entre el audio y el video: elimina marcos antes de enviarlos a la cadena de filtros, en lugar de después. Como resultado, pullup algunas veces pierde los datos que necesita.

    Si MEncoder descarta demasiados marcos de imagen en una fila, se carga los buffers pullup y causa el fallo del programa.

    Incluso si MEncoder solo descarta un marco, pullup sigue sin verse bien, y puede resultar en una secuencia incorrecta de marcos de imagen. Incluso si no causa un fallo del sistema, pullup es capaz de hacer decisión de correcciones sobre como reensamblar los marcos progresivos, y hacer coincidir campos juntos de manera incorrecta o descargar algunos campos para compensar.

  • Recientemente he usado -vf filmdint yo mismo, pero esto es lo que dice D Richard Felker III:

    Está bien, pero IMO (en mi opinión) intenta densentrelazar en lugar de hacer inversión del telecine demasiado a menudo (muy similar a los reproductores de sobremesa de DVD y TVs progresivas) que causan parpadeos que afean y otros artefactos. Si está haciendo uso de esto, necesita por lo menos perder algún tiempo haciendo un ajuste fino de las opciones y viendo la salida para asegurarse de que no está haciendolo mal.

7.12.2.5. Mezcla de progresivo y entrelazado

Hay dos opciones para tratar esta categoría, cada una con sus compromisos. Debe decidir si se quiere basar en la duración o localización de cada tipo.

  • Trátelo como progresivo. Las partes entrelazadas parecen entrelazadas, y algunos campos entrelazados son descartados, resultando en un poco dispares y con saltos. Puede usar un filtro de postprocesado si quiere, pero degradará ligeramente las partes progresivas.

    Definitivamente esta opción no debe ser usada si quiere eventualmente mostrar el video en un dispositivo entrelazado (con una tarjeta de TV, por ejemplo). Si tiene marcos entrelazados en un video de 23.976 marcos por segundo, deben ponerse en telecine junto con los marcos progresivos. La mitad de los "marcos" entrelazados serán mostrados en duración de tres campos (3/59.94 segundos), resultando en un efecto de parpadeo "con salto atrás en el tiempo" lo que hace que se vea bastante mal. Si quiere intentarlo, debe usar un filtro de desentrelazado como lb o l5.

    También puede ser una mala idea para una pantalla progresiva. Descartará pares de campos consecutivos entrelazados, resultando en una discontinuidad que puede ser más visible que con el segundo método, el cual muestra algunos marcos progresivos dos veces. El video entrelazado a 29.97 marcos por segundo ya se ve realmente con saltitos porque debe ser mostrado a 59.94 campos por segundo, lo que hace que los marcos duplicados no estén durante mucho tiempo en pantalla.

    En cualquier caso, es mejor considerar su contenido y cómo quiere mostrarlo. Si su video es 90% progresivo y no tiene intención de mostrarlo en una TV, debería usar una aproximación progresiva. Si es solo la mitad progresivo, probablemente querrá codificarlo como está si todo está entrelazado.

  • Trátelo como entrelazado. Algunas características de las partes progresivas serán tratadas por duplicado, resultando en una imagen a saltos. De nuevo, los filtros de desentrelazado pueden degradar ligeramente las partes progresivas.

7.12.3. Notas a pie de página

  1. Acerca del recortado:  Los datos de video de los DVDs son almacenados en un formato llamado YUV 4:2:0. En video YUV, la luminancia ("brillo") y la crominancia ("color") se almacenan por separado. Debido a que el ojo humano es menos sensible al color que al brillo, en una imagen YUV 4:2:0 hay solo un pixel de crominancia por cada cuatro de luminancia (dos por lado) teniendo el pixel de crominancia común. Debe recortar YUV progresivo 4:2:0 a resoluciones pares, e incluso usar desplazamientos pares. Por ejemplo, crop=716:380:2:26 es CORRECTO pero crop=716:380:3:26 no lo es.

    Cuando esté tratando con YUV 4:2:0 entrelazado, la situación es un poco más complicada. En lugar de cada cuatro pixels de luminancia en el marco compartiendo uno de crominancia, cada cuatro de luminancia en cada campo comparten un pixel de crominancia. Cuando los campos son entrelazados para formar un marco, cada scanline es un pixel de alta. Ahora, en lugar de cada cuatro pixels de luminancia en un cuadrado, hay dos pixels lado-a-lado, y los otros dos pixels están lado-a-lado dos scanlines más abajo. Los dos pixels de luminancia en la scanline intermedia son del otro campo, y por eso comparten un pixel distinto de crominancia con dos pixels de luminancia dos scanlines más allá. Toda esta confusión hace necesario tener dimensiones y desplazamientos de recorte vertical en múltiplos de cuatro. El horizontal puede quedarse igual.

    Para video en telecine, recomiendo que se recorte después de hacer la inversión del telecine. Una vez que el video es progresivo solo necesita recortar con números pares. Si realmente quiere ganar algo de velocidad más que lo que el primer recortado puede ofrecer, debe recortar verticalmente en múltiplos de cuatro o bien usar el filtro de telecine-inverso con los datos apropiados.

    Para video entrelazado (no telecine), siempre debe recortar verticalmente por múltiplos de cuatro a menos que use -vf field antes de recortar.

  2. Acerca de los parámetros de codificado y la calidad:  Solo porque yo recomiendo mbd=2 aquí no significa que deba ser usado siempre. Junto con trell, mbd=2 es una de las dos opciones de libavcodec que pueden incrementar la calidad, y siempre debe usar al menos estos dos a menos que la pérdida de velocidad sea prohibitiva (e.g. codificación en tiempo real). Hay muchas otras opciones para libavcodec que incrementan la calidad de la codificación (e incrementa la velocidad de la codificación) pero eso queda más allá del objeto de este documento.