Lema de Arden

El Lema de Arden, en lenguajes formales, indica una solución particular a la ecuación con expresiones regulares: x = r x + s {\displaystyle x=rx+s} (en donde r {\displaystyle r} y s {\displaystyle s} son expresiones regulares conocidas, y x {\displaystyle x} es desconocida).

Esta solución provee un Algoritmo sistemático y metódico para la conversión de Autómata finito a Expresión regular.

Enunciado

Sea λ {\displaystyle \lambda } la cadena vacía, r {\displaystyle r} y s {\displaystyle s} son expresiones regulares conocidas, y x {\displaystyle x} desconocida. Entonces la ecuación

x = r x + s {\displaystyle x=rx+s}

Tiene una solución única si λ L ( r ) {\displaystyle \lambda \notin L(r)} . Y esta solución es:

x = r s {\displaystyle x=r^{*}s}

Pero si λ L ( r ) {\displaystyle \lambda \in L(r)} , la ecuación tiene infinitas soluciones:

x = r ( s + t ) {\displaystyle x=r^{*}(s+t)}

En donde t {\displaystyle t} es cualquier expresión regular.

Demostración

Sea x = r s {\displaystyle x=r^{*}s} la hipótesis. Se demostrará que x = r x + s {\displaystyle x=rx+s}

x = r s = ( r ) s = ( r r + λ ) s = r r s + λ s = r r s + s = r ( r s ) + s = r x + s {\displaystyle x=r^{*}s=(r^{*})s=(rr^{*}+\lambda )s=rr^{*}s+\lambda s=rr^{*}s+s=r(r^{*}s)+s=rx+s}

Generalizaciones

Así mismo, si la ecuación es:

x = x r + s {\displaystyle x=xr+s}

La solución, si λ L ( r ) {\displaystyle \lambda \notin L(r)} es: x = s r {\displaystyle x=sr^{*}}

Aplicaciones

Conversión de AFD a expresión regular

Para convertir un Autómata finito determinista (e incluso uno No Determinista, y hasta uno con transiciones nulas) a una Expresión regular, se debe definir un sistema de ecuaciones, este sistema, tendrá tantas incógnitas como estados haya en el autómata que se desea convertir, si el autómata tiene ciclos de longitud 1 (es decir, arcos que van de un estado q {\displaystyle q} , al mismo estado q {\displaystyle q} ), se debe usar el lema de Arden para resolver el sistema de ecuaciones. Cuando todas las incógnitas han sido encontradas, se obtendrá la expresión regular que describe al lenguaje aceptado por el autómata.

Para construir las ecuaciones, se plantean las siguientes incógnitas:

X i {\displaystyle X_{i}} es una incógnita que representa una expresión regular que define todas aquellas cadenas que van del estado q i {\displaystyle q_{i}} a algún estado final del autómata.

Entonces, por cada estado q i {\displaystyle q_{i}} en el autómata, se formará la ecuación:

X i = σ j X j {\displaystyle X_{i}=\sum {\sigma _{j}X_{j}}}

Donde σ j Σ {\displaystyle \sigma _{j}\in \Sigma } representa la letra que une mediante un arco al estado q i {\displaystyle q_{i}} con el estado q j {\displaystyle q_{j}} .

Debe agregarse la cadena nula si el estado q i {\displaystyle q_{i}} es final.

Control de autoridades
  • Proyectos Wikimedia
  • Wd Datos: Q670618
  • Wd Datos: Q670618