stringtranslate.com

Gramática de precedencia de operadores

Una gramática de precedencia de operadores es un tipo de gramática para lenguajes formales .

Técnicamente, una gramática de precedencia de operadores es una gramática libre de contexto que tiene la propiedad (entre otras) [1] de que ninguna producción tiene un lado derecho vacío o dos no terminales adyacentes en su lado derecho. Estas propiedades permiten definir relaciones de precedencia entre las terminales de la gramática. Un analizador que explota estas relaciones es considerablemente más simple que los analizadores de propósito más general, como los analizadores LALR . Se pueden construir analizadores de precedencia de operadores para una gran clase de gramáticas libres de contexto.

Relaciones de precedencia

Las gramáticas de precedencia de operadores se basan en las siguientes tres relaciones de precedencia entre los terminales: [2]

Estas relaciones de precedencia de operadores permiten delimitar los identificadores en las formas oracionales derechas : marca el extremo izquierdo, aparece en el interior del identificador y marca el extremo derecho. A diferencia de otros analizadores de reducción de desplazamiento, todos los no terminales se consideran iguales a los efectos de identificar identificadores. [3] Las relaciones no tienen las mismas propiedades que sus contrapartes sin puntos; mi. gramo. generalmente no implica ni se deriva de . Además, generalmente no se cumple y es posible.

Supongamos que entre los terminales a i y a i +1 siempre hay exactamente una relación de precedencia. Supongamos que $ es el final de la cadena. Luego para todos los terminales b definimos: y . Si eliminamos todos los no terminales y colocamos la relación de precedencia correcta: , , entre los terminales restantes, quedan cadenas que pueden ser analizadas por un analizador ascendente fácilmente desarrollado .

Ejemplo

Por ejemplo, se pueden introducir las siguientes relaciones de precedencia de operadores para expresiones simples: [4]

Se derivan de los siguientes hechos: [5]

La cadena de entrada [4]

después de agregar marcadores finales e insertar relaciones de precedencia se vuelve

Análisis de precedencia de operadores

Tener relaciones de precedencia permite identificar identificadores de la siguiente manera: [4]

Generalmente no es necesario escanear toda la oración para encontrar el identificador.

Algoritmo de análisis de precedencia de operadores

El siguiente algoritmo es de Aho et al.: [6]

Si $ está en la parte superior de la pila y ip apunta a $, entonces regrese en caso contrario Sea a el terminal superior de la pila y b el símbolo al que apunta ip si  a  b o a b entonces empuja b hacia la pila       avanzar ip al siguiente símbolo de entrada de lo contrario si  a  b entonces repite    pop la pila hasta que el terminal de la pila superior esté relacionado con el terminal emergente más recientemente else error() end

Funciones de precedencia

Un analizador de precedencia de operadores normalmente no almacena la tabla de precedencia con las relaciones, que pueden llegar a ser bastante grandes. En cambio, se definen las funciones de precedencia f y g . [7] Mapean símbolos terminales a números enteros, por lo que las relaciones de precedencia entre los símbolos se implementan mediante comparación numérica: ⁠ ⁠ debe cumplirse si se cumple, etc.

No todas las tablas de relaciones de precedencia tienen funciones de precedencia, pero en la práctica para la mayoría de las gramáticas se pueden diseñar dichas funciones. [8]

Algoritmo para construir funciones de precedencia.

El siguiente algoritmo es de Aho et al.: [9]

  1. Cree símbolos f a y g a para cada terminal gramatical a y para el símbolo de final de cadena;
  2. Dividir los símbolos creados en grupos de modo que f a y g b estén en el mismo grupo si (puede haber símbolos en el mismo grupo incluso si sus terminales no están conectados por esta relación);
  3. Crea un grafo dirigido cuyos nodos son los grupos. Para cada par ⁠ ⁠ de terminales haga: coloque una arista del grupo de g b al grupo de f a if , en caso contrario si coloque una arista del grupo de f a al de g b ;
  4. Si el gráfico construido tiene un ciclo, entonces no existen funciones de precedencia. Cuando no hay ciclos, sea ⁠ ⁠ la longitud del camino más largo del grupo de f a y sea ⁠ ⁠ la longitud del camino más largo del grupo de g a .

Ejemplo

Considere la siguiente tabla (repetida desde arriba): [10]

El uso del algoritmo conduce al siguiente gráfico:

 gimiendo \ fid carajo* \ / gramo* / f+  | \ | g+ | | g$f$

de donde extraemos las siguientes funciones de precedencia de las alturas máximas en el gráfico acíclico dirigido :

Idiomas de prioridad del operador

La clase de lenguajes descritos por las gramáticas de precedencia de operadores, es decir, lenguajes de precedencia de operadores, está estrictamente contenida en la clase de lenguajes deterministas libres de contexto y contiene estrictamente lenguajes visiblemente pushdown . [11]

Los lenguajes de precedencia de operadores disfrutan de muchas propiedades de cierre: unión, intersección, complementación, [12] concatenación, [11] y son la clase cerrada más grande conocida bajo todas estas operaciones y para la cual el problema de vacío es decidible. Otra característica peculiar de los lenguajes de precedencia de operadores es su analizabilidad local, [13] que permite un análisis paralelo eficiente.

También hay caracterizaciones basadas en una forma equivalente de autómatas y lógica monádica de segundo orden. [14]

Notas

  1. ^ Aho, Sethi y Ullman 1988, pág. 203
  2. ^ Aho, Sethi y Ullman 1988, págs. 203-204
  3. ^ Aho, Sethi y Ullman 1988, págs. 205-206
  4. ^ abc Aho, Sethi y Ullman 1988, pág. 205
  5. ^ Aho, Sethi y Ullman 1988, pág. 204
  6. ^ Aho, Sethi y Ullman 1988, pág. 206
  7. ^ Aho, Sethi y Ullman 1988, págs. 208-209
  8. ^ Aho, Sethi y Ullman 1988, pág. 209
  9. ^ Aho, Sethi y Ullman 1988, págs. 209-210
  10. ^ Aho, Sethi y Ullman 1988, pág. 210
  11. ^ ab Crespi Reghizzi y Mandrioli 2012
  12. ^ Crespi Reghizzi, Mandrioli y Martín 1978
  13. ^ Barenghi y col. 2015
  14. ^ Lonati y col. 2015

Referencias

Otras lecturas

enlaces externos