Forma Normal de Chomsky

Fonte: testwiki
Saltar para a navegação Saltar para a pesquisa

Em ciência da computação, uma gramática livre de contexto está na forma normal de Chomsky se todas as suas regras de produção são da forma:

ABC ou
Aα ou
Sε

onde A, B e C são variáveis (símbolos não-terminais), α é um símbolo terminal (um símbolo que representa um valor constante), S é a variável inicial, e ε é a cadeia vazia. Além disso, nem B nem C podem ser a variável inicial.

Toda gramática na forma normal de Chomsky é uma livre de contexto, e inversamente, toda gramática livre de contexto pode ser transformada em uma equivalente que está na forma normal de Chomsky. Vários algoritmos para realizar tal transformação são conhecidos. Transformações são descritas na maioria dos livros sobre teoria dos autômatos, tais como (Hopcroft and Ullman, 1979). Como apontado por Lange and Leiß, a desvantagem destas transformações é que elas podem levar a um inchaço indesejável no tamanho da gramática. Usando |G| para denotar o tamanho da gramática original G, o tamanho do inchaço no pior dos casos pode variar de |G|2 a 22|G|, dependendo do algoritmo de transformação utilizado (Lange and Leiß, 2009).

Definição alternativa

Outra forma de definir a forma normal de Chomsky (Hopcroft e Ullman 1979, e Hopcroft et al. 2006) é:

Uma gramática formal está na forma reduzida de Chomsky se todas as suas regras de produção são da seguinte forma:

ABC ou
Aα

onde A, B e C são variáveis (símbolos não-terminais), e α é um símbolo terminal. Ao usar esta definição, B ou C pode ser a variável inicial.

Convertendo uma gramática para a Forma Normal de Chomsky

  1. Introduzir S0
  2. : Introduzir uma nova regra S0S onde S é a variável inicial anterior.
  3. Eliminar todas as regras ϵ
  4. : Regras ϵ são regras da forma Aϵ onde A=S0 e AV onde V é a variável do alfabeto da CFG.
  5. : Remover todas as regras com ϵ do seu lado direito (RHS, do inglês Right Hand Side - Lado da Mão Direita). Para cada regra com A no seu RHS, adicione um conjunto de regras novas consistindo das diferentes combinações possíveis de A substituído ou não substituído por ϵ. Se uma regra tem A como um símbolo único em seu RHS, adicione uma nova regra R=Aϵ a menos que R já tenha sido removida através deste processo. Por exemplo, examine a seguinte gramática G:
  6. :: SAbA|B
  7. :: Bb|c
  8. :: Aϵ
  9. :G tem uma regra epsilon. Quando o Aϵ é removido, temos o seguinte:
  10. :: SAbA|Ab|bA|b|B
  11. :: Bb|c
  12. :Repare que temos que contar todas as possibilidades de Aϵ e assim realmente acabamos adicionando 3 regras.
  13. Eliminar todas as regras unitárias
  14. :ABA,BV
  15. :Depois de remover todas as regras ϵ, você pode remover regras unitárias, ou regras cuja RHS contém uma variável e nenhum terminal (que é incompatível com FNC.)
  16. :: Para remover AB
  17. :: BU adicione a regra AU a menos que esta seja uma regra unitária que já foi removida.
  18. Limpar regras restantes que não estão na forma normal de Chomsky.
  19. : Substituir Au1,u2,...uk,k3,u1VΣ por Au1A1,A1u2A2,...,Ak2uk1uk onde Ai são novas variáveis.
  20. : Se uiΣ, substitua ui nas regras acima por alguma nova variável vi e adicione a regra viui.

Ver também

Referências

  • John E. Hopcroft, Rajeev Motwani, e Jeffrey D. Ullman. Introduction to Automata Theory, Languages, and Computation, 3rd Edition, Addison-Wesley, 2006. ISBN 0-321-45536-3. (See subsection 7.1.5, page 272.)
  • John E. Hopcroft e Jeffrey D. Ullman, Introduction to Automata Theory, Languages and Computation, Addison-Wesley Publishing, Reading Massachusetts, 1979. ISBN 0-201-02988-X. (See chapter 4.)
  • Predefinição:Citar livro (Pages 98–101 of section 2.1: context-free grammars. Page 156.)
  • Predefinição:Citar livro (Pages 237–240 of section 6.6: simplified forms and normal forms.)
  • Predefinição:Citar livro (Pages 103–106.)
  • Lange, Martin e Leiß, Hans. To CNF or not to CNF? An Efficient Yet Presentable Version of the CYK Algorithm. Informatica Didactica 8, 2009. ((pdf)
  • Cole, Richard. Converting CFGs to CNF (Chomsky Normal Form), October 17, 2007. (pdf)
  • Sipser, Michael. Introduction to the Theory of Computation, 2nd edition.