Práctica de JFLAP
Práctica de JFLAP
Práctica de JFLAP
Autores: Araceli Sanchis de Miguel Agapito Ledezma Espino Jose A. Iglesias Martnez Beatriz Garca Jimnez Juan Manuel Alonso Weber
* Algunos ejercicios estn basados en enunciados del siguiente libro: Susan H. Rodger and Thomas W. Finley. JFLAP: An Interactive Formal Languages and Automata Package. Jones & Bartlett Publishers, Sudbury, MA (2006).
JFLAP (del ingls, Java Formal Language and Automata Package) es un software que permite experimentar de forma grfica con los conceptos relativos a la teora de autmatas y lenguajes formales. Permite disear, evaluar y realizar distintas transformaciones y comprobaciones sobre autmatas finitos, gramticas, autmatas a pila, mquinas de Turing, y otros elementos adicionales que no forman parte del contenido de este curso. Para la realizacin de estas prcticas se requiere la descargar de la herramienta libre JFLAP de su sitio web (http://www.jflap.org/). Adems es necesario consultar el tutorial on-line de la herramienta (http://www.jflap.org/tutorial/), o el siguiente libro gua: Susan H. Rodger and Thomas W. Finley. JFLAP: An Interactive Formal Languages and Automata Package. Jones & Bartlett Publishers, Sudbury, MA (2006).
NOTA IMPORTANTE: Para los ejercicios de limpieza y bien formacin de gramticas, se debe tener en cuenta la siguiente correspondencia entre la nomenclatura y orden de pasos de la explicacin terica y ejercicios, y el proceso utilizado en la herramienta JFLAP, acorde a la siguiente tabla. Algoritmo
Reglas innecesarias Smbolos inaccesibles Reglas superfluas
JFLAP
Unit production removal Useless production removal (2 parte) Useless production removal (1 parte) Useless production removal (1 parte)
Explicacin terica
Eliminacin de Reglas innecesarias Eliminacin de smbolos inaccesibles Eliminacin de reglas superfluas Eliminacin de smbolos no generativos
Diferencia
No hay
Comentarios
-----
No hay ----No hay ----En clase se proporciona un algoritmo distinto. Poner el presunto smbolo no generativo como axioma: si se obtiene lenguaje vaco, entonces es no generativo No hay No hay ----El smbolo no generativo, si est en la parte derecha de una regla de gramtica G2, G3 puede eliminarse tratando esta regla como superflua. -----
Smbolos no generativos
production removal
Unit production removal
1. Dada una gramtica para generar nmeros naturales: G = ({0,1,2,3,4,5,6,7,8,9,0}, {N, C}, N, P) P = { N ::= CN | C, C ::= 0|1|2|3|4|5|6|7|8|9 } Comprobad con el derivador mltiple por fuerza bruta (opcin Input Multiple Brute Force Parse) qu secuencias son palabras del lenguaje L(G) y determinar el motivo. Anotad las observaciones que realicis en cada caso, con el derivador por fuerza bruta simple (opcin Input Brute Force Parse). Palabras de prueba 0 00 001 123 1234 12345 9212 43.34
2. Crear una gramtica G que genere nmeros reales, con . para separar la parte entera y la fraccionaria. Comprobad qu secuencias de las siguientes son palabras del lenguaje L(G) y determinar el motivo. Anotad las observaciones que realicis en cada caso. Palabras de prueba 0 00 00.1 3445 1.23 9.21.2 9..1 9,1
3. Obtencin de Lenguajes. Escribe las siguientes gramticas en el editor de JFLAP, y para cada una de ellas haz: a) una lista de 5 palabras que son aceptadas, b) una lista de 5 palabras que son rechazadas, c) da una descripcin del lenguaje que representan, d) indica el tipo de gramtica en la jerarqua de Chomsky. 1) 2) 3)
4. Gramticas ambiguas. Considerar la siguiente gramtica ambigua y la palabra ababab. S -> abS S -> Sab S -> aSb S -> SS S -> Ejecuta el derivador de fuerza bruta de JFLAP para esta palabra. Proporciona dos rboles de derivacin diferentes para esta palabra y anota el orden de producciones empleado. El algoritmo de JFLAP ejecuta siempre las producciones en el orden en el que estn escritas en el editor, por lo que para que el rbol cambie, hay que cambiar el orden de las producciones en el editor. 5. Eficiencia del Derivador por Fuerza Bruta. El algoritmo que emplea el Derivador por Fuerza Bruta consiste en generar un rbol de bsqueda en el que cada nodo es una Forma Sentencial (la inicial es el axioma) y cada rama es la aplicacin de alguna de las producciones. El mtodo busca generar una sucesin de Formas Sentenciales que conduzcan a la palabra buscada. La bsqueda suele ser exhaustiva y para problemas de tamao relativamente pequeo generan rboles de tamao considerable, con el consiguiente gasto en tiempo de procesamiento. Para la siguiente gramtica y las cadenas de la forma anbb: G = ({a,b},{S,A,B,C},S,P), donde P={ S -> AC C -> AB B -> CC A -> a C -> b S -> SS A -> AA } (a) Ejecuta el brute force parser para n= 2,...,8 y apunta el nmero de nodos generados. Qu observacin puedes hacer acerca del nmero de nodos generados? Y del tiempo que ha tardado? Sabes el motivo? (b) Elimina la produccin S SS y ejecuta de nuevo el brute force parser para n=2,...,8 y apunta el nmero de nodos generados. Compara los resultados con los del apartado (a). Sabes cul es el motivo de la diferencia? (c) Aadindolo al cambio anterior, cambia la produccin AAA a AaA. Ejecuta el brute force parser para n=2,...,8 y apunta el nmero de nodos. Compara los resultados con los de los apartados (a) y (b). Sabes cul es el motivo de las diferencias?
6. El estudiante Carlos quiere que sus padres le compren un coche. Su padre genera una secuencia en la que transcribe todas las notas que Carlos ha recibido en su vida, una larga cadena hecha con los smbolos de = {a,b,c,d,f} sin un orden particular. Una a es un sobresaliente, y una f es la nota ms baja. Su padre plantea un criterio simple: si Carlos recibe menos que 4 ds, tendr el coche, y de otra forma, no lo tendr. Una f cuenta igual que una d. Su padre te pide que disees una gramtica lineal derecha donde la gramtica genere la secuencia de trascripcin s y slo si Carlos consigue el coche. Nota: Puedes probar si una gramtica lineal derecha genera una palabra con el derivador de fuerza bruta, o bien convirtiendo la gramtica a un autmata finito y comprobando si el AF acepta la palabra. (a) Disea una gramtica lineal derecha con las especificaciones anteriores. (b) La reaccin inicial de Carlos fue de realizar una splica, para que su padre adoptase mtodos menos draconianos, abogando indirectamente a la nocin que la diferencia generacional entre el padre y el hijo pudo haber conducido al padre a ser injustamente duro. El padre decide hacer que una nota f, cuente como dos ds. Modifica la gramtica para que tenga en cuenta este cambio. (c) Con un poco ms de tacto, Carlos fue capaz de discutir satisfactoriamente con su padre, llegando al acuerdo de que una nota de sobresaliente a, debera mitigar un suspenso d. Por qu este lenguaje no puede ser expresado con una gramtica lineal derecha? 7. Transformar las siguientes gramticas regulares lineales derechas a su correspondiente Autmata Finito, utilizando JFLAP. 1) S ::= aA S ::= bB B ::= bS B ::= A ::= aS A ::= 2) S ::= aS S ::= aA A ::= bB A ::= cC B ::= bS B ::= b C ::= cS C ::= 3) S ::= bS S ::= aA S ::= bB S ::= bC A ::= aS B ::= bC B ::= b C ::= cS C ::= c
8. Edita los siguientes autmatas finitos en JFLAP y transfrmalos a sus correspondientes gramticas, utilizando JFLAP. 1) 2) 3)
9. Eliminar las reglas no generativas de la gramtica G con JFLAP. Anota los pasos de transformacin y la gramtica obtenida (para cada paso, anota la produccin no generativa que vas a eliminar y las producciones nuevas que vas aadiendo). G=({a,b,c},{S,A,B},S,P) P={ S ::= Ac | BaA A ::= B | a B ::= bB | } 10. Eliminar las reglas superfluas y smbolos inaccesibles usando JFLAP en la gramtica G. Anota los pasos de transformacin y la gramtica obtenida. G=({a,b,c},{S,A,B},S,P) P={ S ::= aSB | b A ::= a | aA B ::= AaC | bA C ::= cCc}