Forma Normal de Chomsky

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:

ou
ou

onde , e são variáveis (símbolos não-terminais), α é um símbolo terminal (um símbolo que representa um valor constante), é a variável inicial, e ε é a cadeia vazia. Além disso, nem nem 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 para denotar o tamanho da gramática original , o tamanho do inchaço no pior dos casos pode variar de a , dependendo do algoritmo de transformação utilizado (Lange and Leiß, 2009).

Definição alternativa

editar

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:

  ou
 

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

Convertendo uma gramática para a Forma Normal de Chomsky

editar
  1. Introduzir  
  2. : Introduzir uma nova regra   onde   é a variável inicial anterior.
  3. Eliminar todas as regras  
  4. : Regras   são regras da forma   onde   e   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   no seu RHS, adicione um conjunto de regras novas consistindo das diferentes combinações possíveis de   substituído ou não substituído por  . Se uma regra tem   como um símbolo único em seu RHS, adicione uma nova regra   a menos que   já tenha sido removida através deste processo. Por exemplo, examine a seguinte gramática G:
  6. ::  
  7. ::  
  8. ::  
  9. :G tem uma regra epsilon. Quando o   é removido, temos o seguinte:
  10. ::  
  11. ::  
  12. :Repare que temos que contar todas as possibilidades de   e assim realmente acabamos adicionando 3 regras.
  13. Eliminar todas as regras unitárias
  14. : 
  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  
  17. ::   adicione a regra   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   por   onde   são novas variáveis.
  20. : Se  , substitua   nas regras acima por alguma nova variável   e adicione a regra  .

Ver também

editar

Referências

editar
  • 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.)
  • Michael Sipser (1997). Introduction to the Theory of Computation. [S.l.]: PWS Publishing. ISBN 0-534-94728-X  (Pages 98–101 of section 2.1: context-free grammars. Page 156.)
  • John Martin (2003). Introduction to Languages and the Theory of Computation. [S.l.]: McGraw Hill. ISBN 0-07-232200-4  (Pages 237–240 of section 6.6: simplified forms and normal forms.)
  • Michael A. Harrison (1978). Introduction to Formal Language Theory. [S.l.]: Addison-Wesley. ISBN 978-0201029550  (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.