Remove ads
Da Wikipédia, a enciclopédia livre
No ramo da Complexidade computacional a hierarquia polinomial é a hierarquia das Classes de complexidade que generaliza as classes P, NP e Co-NP para Máquinas oráculo. É uma contrapartida limitada de recursos para a Hierarquia aritmética e Hierarquia analítica da Lógica matemática.
Este artigo não cita fontes confiáveis. (Dezembro de 2011) |
Existem várias definições equivalentes para as classes de hierarquia polinomial.
1. Para a definição do oráculo da hierarquia polinomial, defina:
:
onde P é o conjunto de problemas de decisão que podem ser resolvidos em tempo polinomial. Então, para i ≥ 0 defina:
: : :
tal que AB é o conjunto de problemas de decisão solucionável por uma maquina de Turing na classe A aumentada por um oráculo para um problema completo na classe B. Por exemplo, </math>, and é a classe de problemas solucionáveis em tempo polinomial por um oráculo para um dado problema NP-Completo.
2. Para a definição existencial/universal da definição de hierarquia polinomial, assuma que seja uma linguagem ( i.e. um problema de decisão, como o sub-conjunto de {0,1}* ), seja um polinômio e defina:
:
Tal que é algum padrão de codificação para o par de strings binárias x e y como uma única string binária. L representa o conjunto de pares ordenados de strings, onde a primeira string x é um membro de e a segunda string w sendo "short" ( ) que diz que x é membro de . Em outras palavras, se e somente se existe uma testemunha w "short" tal que . Da mesma forma, define:
:
Note que osteoremas de De Morgan permanecem válidos. e , onde Lc é o complemento de L.
Considere como a classe das linguagens. Extenda esses operadores para trabalhar em classes inteiras de linguagens pela definição:
: :
Novamente, os teoremas de De Morgan permanece válidos. e , onde .
As classes NP e Co-NP podem ser definidas como e , onde P é a classe de todas as linguagens decidíveis viáveis ( Tempo polinomial ). A hierarquia polinomial pode ser definida recursivamente como:
: : :
Note que e .
Essa definição reflete a conexão forte entre hierarquia polinomial e a Hierarquia aritmética, onde R e RE são análogas a P e NP, respectivamente. A Hierarquia analítica também é definida de forma parecida para dar hierarquia para sub-conjuntos dos números reais.
3. Uma definição equivalente em termos de uma Máquina de Turing alternada define ( respectivamente, ) como o conjunto de problemas de decisão solvíveis em tempo polinomial em uma máquina de Turing alternada com alternações, iniciando em um estado inicial.
As definições implicam nas relações:
Diferentemente das hierarquias aritimétrica e analitica, as quais tem inclusões certas, é uma questão aberta se qualquer uma dessas inclusões é certa, embora acredita-se que elas sejam todas verdade. Se qualquer ou , então a hierarquia desmorona para o nível k: Para todo , . Em particular, se P = NP a hierarquia desmorona completamente.
A união de todas as classes na hierarquia polinomial tem como complexidade a classe PH.
A hierarquia polinomial é análoga ( em uma complexidade bem menor )a Hierarquia exponencial e Hierarquia aritmética.
Sabemos que PH está contido em PSPACE, mas não se sabe se as duas classes são iguais. Uma reformulação útil desse problema é que PH = PSPACE se e somente se estruturas de lógica de segunda ordem não ganham nenhuma força da adição da operação Fechamento sobre transitividade.
Se a hierarquia polinomial possuir algum problema completo, então ela possui um número finito de niveis. Já que temos PSPACE-completude problemas, sabemos que se PSPACE = PH, então a hierarquia polinomial irá desmoronar, uma vez que se um problema completo de PSPACE seria -completo para algum k.
Cada classe na hierarquia polinomial contem problemas -completo ( Problemas completo sobre um tempo polinomial de redução muitos para um ). Além do mais, cada classe na hierarquia polinomial é fechada sob -reduções: Signifcando que para a classe na hierarquia e uma linguagem , se então também. Juntos, esses dois fatos implicam em que se é um problema completo para , então e . Em outras palavras, se uma linguagem é definida em algum oráculo em , então podemos assumir que é definido baseado em um problema completo para . Problemas completos então atuam como "representantes" das classes para as quais eles são completos.
O Teorema de Sipser–Lautemann afirma que a classe BPP está contida em um segundo nível da hierarquia polinomial.
O Teorema de Karp–Lipton afirma que para qualquer k, não está contido em SIZE(nk).
O Teorema de Toda afirma que a hierarquia polinomial está contida em P#P.
Um exemplo de um problema natural em é a minimização de circuitos. Dado um número k e um circuito A computando uma Função booleana f, determina se existe um circuito com pelo menos K chaves que computa a mesma função f. Seja o conjunto de todos os circuitos booleanos, a linguagem:
É dicidivel em tempo polinomial. A linguagem:
É a linguagem de minimização de circuitos. pois é decidivel em tempo polinomial e porque, dados , se e somente se existe um circuito tal que para todas as entradas , .
Um problema completo para é a satisfatibilidade para formulas booleanas com k alterações de quantificadores ( Abreviando, QBFk ou QSATk ). Essa é a versão do Problema de satisfatibilidade booliana para . Nesse problema, nos recebemos uma formula booleana f com variaveis particionadas em k conjuntos, X1, ..., Xk. Temos que determinar a veracidade de:
Isso é, existe uma valoração para as variáveis em X1 tal que, para todas as valorações em X2, existe uma valoração de valores para as variaveis em X3, ... f é verdade? A variação do problema acima é completa para . A variante na qual o primeiro quantificador é para todos, o segundo Existe', etc., é completa para .
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.