Lema do bombeamento para linguagens livre de contexto

Fonte: testwiki
Revisão em 04h00min de 8 de julho de 2022 por imported>Pixial
(dif) ← Revisão anterior | Revisão atual (dif) | Revisão seguinte → (dif)
Saltar para a navegação Saltar para a pesquisa

Predefinição:Sem notas Predefinição:Revisão

O lema do bombeamento para linguagens livres de contexto, também conhecido como o lema Bar-Hillel, é um lema que que sua propriedade é compartilhada por todas as linguagens livres de contexto. Declaração Formal Se uma linguagem L é livre de contexto, então existe algum inteiro p ≥ 1 tal que qualquer cadeia s em L com | s | ≥ p (onde p é um "comprimento de bombeamento") pode ser escrita como

Declaração formal

Se uma linguagem L é livre de contexto, então existe algum inteiro p ≥ 1 tal que qualquer cadeia s em L com | s | ≥ p (onde p é um "comprimento de bombeamento") pode ser escrita como

s = uvxyz

com as subcadeias u, v, x, y e z, de tal modo que

1. |vxy| ≤ p,
2. |vy| ≥ 1, e
3. uv nxy nz pertence a L para todo n ≥ 0.

Declaração Informal e explicação

O lema do bombeamento para linguagens livres de contexto (chamado apenas "o lema do bombeamento" para o resto deste artigo) descreve uma propriedade que todas as linguagens livres de contexto possuem. Propriedade que todas as cadeias da linguagem que têm comprimento de pelo menos p, onde p é uma constante chamada de bombeamento de comprimento que varia entre as linguagens livres de contexto. E s é uma sequência de tamanho pelo menos p, que está na linguagem.

Os estados de bombeamento de s podem ser dividida em cinco subcadeias, s=uvxyz onde vy não pode ser vazia e o comprimento de vxy é no máximo de p, de tal modo que qualquer repetição de v e y produz uma cadeia s que ainda está na linguagem. Este processo de "bombear" cópias adicionais de v e y é o que dá o lema do bombeamento seu nome. Observe que as linguagens finitas (que são regulares e, portanto, livre de contexto) obedecem ao lema do bombeamento trivialmente por ter p igual ao comprimento máximo da cadeia em L, mais um. Como não existem cadeias desse comprimento o lema do bombeamento não é violado. O lema do bombeamento é frequentemente usado para provar que uma determinada linguagem não é livre de contexto, mostrando que para cada p, podemos encontrar alguma cadeia s de comprimento pelo menos p na linguagem que não tem as propriedades descritas acima, ou seja, que ele não pode ser "bombeada", sem conseguir produzir alguma cadeia da linguagem.

Uso do lema

Por exemplo, podemos mostrar que a linguagem L={aibici|i>0} não é livre de contexto usando o lema do bombeamento em uma prova por contradição. Em primeiro lugar, assumimos que L é livre de contexto. Pelo lema de bombagem, existe um número inteiro p que é o comprimento de bombeamento da linguagem. Considere a cadeia s=apbpcp em L. O lema do bombeamento nos diz que pode ser escrito na forma s=uvxyz, onde u,v,x,y, and z são subcadeias, de tal forma que |vxy|p, |vy|1, euvixyiz pertence a L para cada inteiro i0. Escolhendo s e o fato de |vxy|p, vê-se facilmente que a substring vxy não pode conter mais do que duas letras distintas. Ou seja, temos uma das cinco possibilidades para vxy:

  1. vxy=aj para cada jp.
  2. vxy=ajbk para cada j e k com j+kp.
  3. vxy=bj para cada jp.
  4. vxy=bjck para cada j e k com j+kp.
  5. vxy=cj para cada jp.

Para cada caso, é facilmente verificado que uvixyiz não contem iguais números para cada letra em cada i1. Então, uv2xy2z não tem a forma aibici. Isso contradiz a definição de L. Portanto, o que assumimos no início para L, sendo livre de contexto é falso.

Enquanto o lema do bombeamento é muitas vezes uma ferramenta útil para provar que uma determinada linguagem não é livre de contexto, não dos da uma caracterização completa das linguagens livres de contexto. Se uma linguagem não satisfaz a condição dada pelo lema do bombeamento, sabemos que ela não é livre de contexto. Por outro lado, existem linguagens que não são livres de contexto, mas ainda satisfazem a condição dada pelo lema do bombeamento. Existem técnicas de prova mais poderosos disponíveis, tais como lema de Ogden, mas também não dão uma caracterização completa das linguagens livres de contexto.

Veja também

Predefinição:Referências