Suavizado de n-gramas

De testwiki
Revisión del 21:26 7 ago 2024 de imported>Wassap927 (growthexperiments-addlink-summary-summary:2|0|0)
(difs.) ← Revisión anterior | Revisión actual (difs.) | Revisión siguiente → (difs.)
Ir a la navegación Ir a la búsqueda

Un problema bastante frecuente en procesamiento del lenguaje natural es el cálculo de la verosimilitud (probabilidad) de una secuencia de palabras, por ejemplo para puntuar diversas hipótesis alternativas y seleccionar la más probable.

Supongamos que un sistema de reconocimiento de voz identifica una frase y sugiere, debido a su parecido fonético, dos posibles textos alternativos:

  • Texto A: "sax and violins on TV"
  • Texto B: "sex and violence on TV"

A primera vista parece que el texto B es más probable que el A, sin embargo, un sistema automático carece de tal sentido común y deberá basarse en un modelo de lenguaje determinado para evaluar cuál de las dos secuencias de palabras tiene mayor puntuación. Para el cálculo de la probabilidad de la observación (la frase en cuestión) se emplea habitualmente un modelo de k-gramas y es bastante frecuente que determinados k-gramas tengan probabilidad 0, es decir, que no aparecen en el texto.

Con las técnicas de suavizado intentamos evitar las probabilidades cero producidas por k-gramas no vistos.

Son varios los algoritmos de suavizado que se conocen. A continuación se describen algunos de los más utilizados.

Aproximación o descuento de Laplace

El descuento de Laplace asume que todos los k-gramas se han visto al menos una vez. Por tanto, para evitar probabilidades cero para trigramas no vistos el cálculo quedaría así:

p^(v|v1,v2)=1+n(v1v2v)vV1+n(v1v2v)

El problema fundamental de esta solución es que da demasiado porcentaje de la masa total de probabilidad a los k-gramas no vistos.

Algoritmos de interpolación lineal

Deleted interpolation

En general:

p(w|h)=λN(hw)whw+(1λ)β(w|h^)

  • h es la historia detallada (w1w2w)
  • β es la probabilidad más robusta
  • h^ es la historia simplificada (w2w)


Para el caso concreto de trigramas:

p(v|v1v2)=λ3(v1,v2)n(v1v2v)Vn(v1v2v)+(1λ3(v1,v2))p^(v|v2)

p^(v|v2)=λ2(v2)n(v2v)Vn(v2v)+(1λ2(v2))p^(v)

p^(v)=λ1n(v)N+(1λ)1|V|

|V| es el tamaño del vocabulario.

Interpolación aproximada

p^(v|v1v2)=N(v1v2)121+N(v1v2)12N(v1v2v)VN(v1v2v)+(1N(v1v2)121+N(v1v2)12)p^(v1v2)

p^(v|v2)=N(v2)121+N(v2)12N(v2v)VN(v2v)+(1N(v2)121+N(v2)12)p^(v)

Técnicas de back-off

Si N(hw)>0

p(w|h)=λN(hw)wN(hw)

Si N(hw)=0

(1λ)β(w|h^)w:N(hw)=0β(w|h^)


La diferencia fundamental entre los modelos de backoff y de interpolación es que en el caso de probabilidades no nulas, los modelos de interpolación usan información de k-gramas de orden inferior mientras que mediante técnicas de backoff no ocurre así.

Otras técnicas de suavizado

Referencias

Véase también

Enlaces externos

Plantilla:Control de autoridades