Loading AI tools
Da Wikipédia, a enciclopédia livre
O algoritmo de análise gramatical Earley é um tipo de programa que subdivide uma entrada (input) para que um outro possa atuar sobre ela mais comumente usado em linguística computacional, nomeado após seu inventor, Jay Earley. O algoritmo faz uso de programação dinâmica.[1]
Esta página ou seção carece de contexto. (Outubro de 2023) |
Os analisadores gramaticais Earley são interessantes porque podem analisar todas as linguagens livre de contexto. O algoritmo Earley tem tempo de execução O(n³) (onde n é o comprimento da cadeia de caracteres analisada), no caso geral, tempo quadrático (O(n²)) para gramáticas não ambígua, e tempo linear para quase toda as gramáticas LR(k)?. Seu desempenho é relativamente bom quando as regras são escritas de forma recursiva.
P → S # the start rule S → S + M | M M → M * T | T T → number
2 + 3 * 4
(state no.) Production (Origin) # Comment ---------------------------------
(1) P → • S (0) # start rule (2) S → • S + M (0) # predict from (1) (3) S → • M (0) # predict from (1) (4) M → • M * T (0) # predict from (3) (5) M → • T (0) # predict from (3) (6) T → • number (0) # predict from (5)
(1) T → number • (0) # scan from S(0)(6) (2) M → T • (0) # complete from S(0)(5) (3) M → M • * T (0) # complete from S(0)(4) (4) S → M • (0) # complete from S(0)(3) (5) S → S • + M (0) # complete from S(0)(2) (6) P → S • (0) # complete from S(0)(1)
(1) S → S + • M (0) # scan from S(1)(5) (2) M → • M * T (2) # predict from (1) (3) M → • T (2) # predict from (1) (4) T → • number (2) # predict from (3)
(1) T → number • (2) # scan from S(2)(4) (2) M → T • (2) # complete from S(2)(3) (3) M → M • * T (2) # complete from S(2)(2) (4) S → S + M • (0) # complete from S(2)(1) (5) S → S • + M (0) # complete from S(0)(2) (6) P → S • (0) # complete from S(0)(1)
(1) M → M * • T (2) # scan from S(3)(3) (2) T → • number (4) # predict from (1)
(1) T → number • (4) # scan from S(4)(2) (2) M → M * T • (2) # complete from S(4)(1) (3) M → M • * T (2) # complete from S(2)(2) (4) S → S + M • (0) # complete from S(2)(1) (5) S → S • + M (0) # complete from S(0)(2) (6) P → S • (0) # complete from S(0)(1)
Etapa 1: construção de D0: primeiro conjunto de produções
D0 = ∅ para toda S → α ∈ P (1) faça D0 = D0 ∪ { S → •α/0 } repita para toda A → •Bβ/0 ∈ D0 (2) faça para toda B → φ ∈ P faça D0 = D0 ∪ { B → •φ/0 } até que o cardinal de D0 não aumente
Etapa 2: construção dos demais conjuntos de produção
para r variando de 1 até n (1) faça Dr = ∅; para toda A → α•arβ/s ∈ Dr-1 (2) faça Dr = Dr ∪ { A → αar•β/s }; repita para toda A → α•Bβ/s ∈ Dr (3) faça para toda B → φ ∈ P faça Dr = Dr ∪ { B → •φ/r } para toda A → α•/s de Dr (4) faça para toda B → β•Aφ/k ∈ Ds faça Dr = Dr ∪ { B → βA•φ/k } atéque o cardinal de Dr não aumente
Etapa 3: condição de aceitação da entrada.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.