- Blog home
- >
- Engineering
- >
- El posprocesamiento en los sistemas de reconocimiento automático del habla
Tags: Aprendizaje automático, inteligencia artificial
Los sistemas de reconocimiento automático del habla (ASR, por sus siglas en inglés) proporcionan transcripciones de texto. Normalmente, se trata de una secuencia de palabras. Cisco utiliza sistemas ASR para proporcionar subtítulos en tiempo real en las reuniones de Webex. Uno de los problemas que surgen es que puede resultar difícil leer los subtítulos sin puntuación ni mayúsculas. La capacidad de entender el significado del texto puede cambiar en función de la puntuación. Imagine la siguiente secuencia de palabras con dos opciones de puntuación:
“gracias su donación acaba de ayudar a alguien a conseguir un trabajo”.
Opción A: “¡Gracias! Su donación acaba de ayudar a alguien a conseguir un trabajo”.
Opción B: “¡Gracias! Su donación acaba de ayudar a alguien. ¡A conseguir trabajo!”.
Los signos de puntuación marcan una gran diferencia.
Repasaremos varias consideraciones a la hora de desarrollar un sistema de posprocesamiento:
Algunos enfoques clásicos basados en n-gramas [1] tienen una calidad relativamente buena. Sin embargo, tienen sus inconvenientes. Aunque los modelos de n-gramas tienen una inferencia rápida, incluso los modelos de 3-gramas pueden ocupar varios gigabytes de espacio en disco según el vocabulario del idioma. Otro inconveniente es el manejo de las palabras no incluidas en el vocabulario. Si una palabra no se presenta en los datos de entrenamiento, el modelo no puede procesarla de forma habitual y la precisión puede degradarse.
Los enfoques modernos utilizan técnicas eficaces pero intensivas desde el punto de vista computacional, como la RNN bidireccional [3] o las arquitecturas de redes neuronales basadas en la atención y la transformación [2]. Estos modelos tienen un nivel alto de precisión [2], pero pueden no ser adecuados para los casos de uso de la transmisión en directo, ya que requieren la totalidad de la secuencia de entrada para ejecutar la inferencia. Por ejemplo, cuando se tiene solo un token de entrada nuevo para una RNN bidireccional, es necesario actualizar los estados ocultos de todos los tokens que el modelo vio anteriormente (figura 1).
.
Algunos enfoques intentan resolver la puntuación y el uso de mayúsculas desarrollando dos modelos diferentes [3][6], y otros combinan ambos en un único modelo, ya que las salidas se correlacionan mucho [4][2]. Las palabras que siguen inmediatamente a la puntuación demuestran bien esta correlación: las palabras que siguen a los puntos suelen ir en mayúscula y las que siguen a las comas suelen ir en minúscula. Hay enfoques que sugieren una arquitectura con múltiples salidas [4]: una por tarea, respectivamente. Estos muestran que esta arquitectura supera a las arquitecturas de puntuación y uso de mayúsculas por separado.
Dadas las consideraciones anteriores, optamos por utilizar una única red neuronal basada en GRU con dos salidas para la puntuación y el uso de mayúsculas.
Para tratar las palabras no incluidas en el vocabulario, utilizamos una técnica similar a SentencePiece [6] que divide las palabras desconocidas en tokens más pequeños o, en casos extremos, en caracteres. A continuación, describimos los detalles y las consideraciones.
La intuición y los experimentos demuestran que es imprescindible contar con el contexto futuro al desarrollar un modelo de puntuación, ya que es más difícil determinar los signos de puntuación en una posición actual sin conocer las siguientes palabras. Para utilizar la información sobre los próximos tokens y no tener que actualizar todos los estados ocultos para todos los tokens en la dirección hacia atrás, decidimos truncar la dirección hacia atrás en una ventana fija. En la dirección hacia delante, es solo una RNN normal. En la dirección hacia atrás, solo consideramos una ventana fija en cada token y ejecutamos la RNN sobre esta ventana (figura 2). Usando esta ventana, podemos lograr una inferencia en tiempo constante para un nuevo token de entrada (debemos calcular un estado oculto en la dirección hacia adelante y n+1 en la dirección hacia atrás).
.
Ahora para cada token, tenemos estados ocultos para las direcciones hacia adelante y hacia atrás, respectivamente. Llamemos a este nivel TruncBiRNN o TruncBiGRU (ya que utilizamos GRU). Estos estados ocultos se pueden calcular en tiempo constante, lo que no depende de la longitud de la entrada. El funcionamiento en tiempo constante es fundamental para que el modelo pueda seguir el ritmo de los subtítulos en tiempo real.
La arquitectura consta de una capa de incrustación, una capa TruncBiGRU y una capa de GRU unidireccional, y un nivel totalmente conectado. Para la salida, utilizamos dos capas softmax para la puntuación y el uso de mayúsculas, respectivamente (figura 3).
Para cada palabra, el modelo predice su uso de mayúscula y el signo de puntuación después de la palabra. Para sincronizar mejor estas dos salidas y predecir el uso de mayúsculas, también debemos conocer la incrustación del token anterior (para restaurar el signo de puntuación del paso anterior). Junto con una función de pérdida personalizada (consulte la siguiente sección), esto nos permite evitar los casos en los que se produce una palabra en minúscula al principio de una oración.
Para la predicción de la puntuación, también es útil obtener la predicción del uso de mayúsculas de la siguiente palabra. Por eso, concatenamos las incrustaciones actual y siguiente.
Una capa de salida para la puntuación predice la distribución de todos los signos de puntuación. Para nuestro modelo, es un conjunto:
punto: un punto en medio de una oración que no implica necesariamente que la siguiente palabra deba ir en mayúscula (“a. m”., “D.C.”, etc.)
coma
signo de interrogación
puntos suspensivos
dos puntos
guion
punto final: un punto al final de una oración
Para el uso de mayúsculas, tenemos cuatro clases:
minúsculas
mayúsculas: todas las letras se escriben en mayúsculas (“IEEE”, “NASA”, etc.)
mayúsculas
mix_case: para palabras como “iPhone”
mayúscula inicial: palabras que comienzan una oración
Las clases adicionales, “mayúscula inicial” y “punto final”, pueden parecer redundantes a primera vista, pero ayudan a aumentar la coherencia de las respuestas relacionadas con el uso de mayúsculas y la puntuación. El “punto final” implica que la siguiente respuesta de asignación de mayúsculas no puede ser “minúscula”, mientras que “mayúscula inicial” significa que el signo de puntuación anterior es un “punto final” o un signo de interrogación. Estas clases desempeñan un papel importante en la función de pérdida.
Función de pérdida:
Tenemos que optimizar tanto el uso de mayúsculas como la puntuación. Para lograrlo, utilizamos una función de pérdida de suma de logaritmos con un coeficiente:
Sin embargo, como ya se ha dicho, las salidas de una red neuronal pueden no estar perfectamente correlacionadas. Por ejemplo, el puntuador puede predecir un “punto final” para la palabra actual, pero el asignador de mayúsculas no predice una “mayúscula inicial” para el siguiente token. Este tipo de error, aunque poco frecuente, puede ser muy llamativo. Para solucionarlo, utilizamos un término de penalización adicional en la función de pérdida que penaliza este tipo de error:
El primer término corresponde a la probabilidad de tener “mayúscula inicial” después de un elemento que no es un “punto final”, y el segundo a la probabilidad de no tener “mayúscula inicial” después de un “punto final” Esta penalización se suma sobre los tokens en los que se produce este error.
Además, pasamos dos tensores consecutivos de la capa anterior a las capas softmax. Con esto, podemos reducir eficientemente los términos de penalización.
Por último, tenemos la función de pérdida:
Para el entrenamiento, utilizamos transcripciones de texto de un conjunto de reuniones internas de Webex y datos de texto de Wikipedia.
En primer lugar, los datos de entrenamiento se limpian y se dividen en oraciones. Durante el entrenamiento, cada muestra se genera a partir de oraciones consecutivas y se trunca con una longitud aleatoria a partir de una distribución fija. Esto permite que el modelo vea las frases recortadas durante el entrenamiento, lo que permite al modelo lidiar con los resultados intermedios durante la inferencia. A continuación, entrenamos el modelo con unos 300 megabytes de texto de Wikipedia y luego lo ajustamos con las transcripciones de las reuniones de Webex.
El entrenamiento previo en Wikipedia ayuda a mejorar todas las clases de puntuación, pero es particularmente útil en las clases de uso de mayúsculas. Sospechamos que esto se debe al gran número de nombres propios del corpus de Wikipedia.
Aplicamos la misma preparación de datos a nuestros conjuntos de evaluación concatenando oraciones y truncándolas a longitudes aleatorias. Esto nos permite medir la precisión para lo que probablemente veríamos en los estados intermedios de la transcripción.
Utilizando técnicas relativamente sencillas con algunas personalizaciones de la arquitectura, como la GRU truncada y una penalización adicional en una función de pérdida, hemos desarrollado un modelo que puede ejecutarse en línea. La experiencia de lectura de los subtítulos en directo mejora notablemente con los signos de puntuación y el uso de mayúsculas en tiempo real.
Referencias
[1] A. Gravano, M. Jansche y M. Bacchiani, “Restoring punctuation and capitalization in transcribed speech,” en ICASSP 2009, 2009, pp. 4741–4744. [2] Monica Sunkara, Srikanth Ronanki, Kalpit Dixit, Sravan Bodapati, Katrin Kirchhoff, “Robust Prediction of Punctuation and Truecasing for Medical ASR” [3] Tilk, Ottokar y Alumäe, Tanel. (2016). Bidirectional Recurrent Neural Network with Attention Mechanism for Punctuation Restoration. 3047-3051. 10.21437/Interspeech.2016-1517. [4] Vardaan Pahuja, Anirban Laha, Shachar Mirkin, Vikas Raykar, Lili Kotlerman, Guy Lev “Joint Learning of Correlated Sequence Labelling Tasks Using Bidirectional Recurrent Neural Networks” [5] Wang, Peilu & Qian, Yao y Soong, Frank y He, Lei y Zhao, Hai. (2015). Part-of-Speech Tagging with Bidirectional Long Short-Term Memory Recurrent Neural Network. [6] Lita, Lucian y Ittycheriah, Abe y Roukos, Salim y Kambhatla, Nanda. (2003). tRuEcasIng. 10.3115/1075096.1075116. [7] https://github.com/google/sentencepieceVisite nuestra página de inicio o póngase en contacto con nosotros directamente para obtener ayuda.
Haga clic aquí para obtener más información sobre las ofertas de Webex y para inscribirse en una cuenta gratuita.