Complexidade parametrizada

Origem: Wikipédia, a enciclopédia livre.

Em ciência da computação, complexidade parametrizada é um ramo da teoria da complexidade computacional que foca em classificarproblemas computacionais de acordo com sua dificuldade inerente com respeito a múltiplos parâmetros da entrada. A complexidade de um problema é, então, definida como uma função nesses parâmetros. Isso permite a classificação de problemas NP-difíceis em uma escala mais rigorosa que da forma clássica, em que a complexidade do problema é medida de acordo com o número de bits da entrada. O primeiro trabalho sistemático em complexidade parametrizada foi realizado por Downey & Fellows (1999).

Sob a hipótese de que P ≠ NP, existem vários problemas naturais que requerem tempo de execução superpolinomial quando a complexidade é medida apenas em termos do tamanho da entrada, mas são computáveis em tempo polinomial no tamanho da entrada e em tempo exponencial ou pior em um parâmetro . Consequentemente, se é fixado em um valor pequeno e o crescimento da função sobre é relativamente pequeno então tais problemas podem ainda ser considerados tratáveis, apesar de sua classificação tradicional como intratável.

A existência de algoritmos eficientes, exatos e determinísticos que resolvam problemas NP-completos, ou mesmo NP-difíceis é considerada improvável, se parâmetros de entrada não são fixados; todos os algoritmos conhecidos que resolvem esses problemas requerem tempo exponencial (ou pelo menos superpolinomial) no tamanho total da entrada. Entretanto, alguns problemas podem ser resolvidos por algoritmos que são exponenciais apenas no tamanho de um parâmetro fixo enquanto são polinomiais no tamanho da entrada. Tal algoritmo é chamado de tratável em parâmetro fixo (fpt-)algoritmo (na sigla em inglês), porque o problema pode ser resolvido eficientemente para valores pequenos do parâmetro fixo.

Problemas em que algum parâmetro é fixado são chamados de problemas parametrizados. Um problema parametrizado que permite um fpt-algoritmo é dito ser tratável em parâmetro fixo e pertence à classe , e o antigo nome para a teoria da complexidade parametrizada era tratabilidade em parâmetro fixo.

Muitos problemas possuem o seguinte formato: dado um objeto e um inteiro não-negativo , possui alguma propriedade que depende de ? Por exemplo, para o problema da cobertura de vértices, o parâmetro pode ser o número de vértices na cobertura. Em muitas aplicações, por exemplo durante a modelagem de correção de erros, pode-se assumir que o parâmetro é "pequeno" em relação ao tamanho total da entrada. Sendo assim, é interessante verificar se pode-se encontrar um algoritmo que é exponencial apenas em , e não no tamanho da entrada.

Dessa forma, complexidade parametrizada pode ser vista como uma teoria da complexidade bidimensional. Esse conceito é formalizado da seguinte forma:

Um problema parametrizado é uma linguagem , em que é um alfabeto finito. O segundo componente é chamado de parâmetro do problema.
Um problema parametrizado é tratável em parâmetro fixo se a questão “?” pode ser decidida em tempo , em que é uma função arbitrária dependendo unicamente de . A classe de complexidade correspondente é FPT.

Por exemplo, há um algoritmo que resolve o problema de cobertura de vértices em tempo ,[1] em que é o número de vértices e é o tamanho da cobertura de vértices. Isso significa que o problema de cobertura de vértices é tratável em parâmetro fixo com o tamanho da solução agindo como parâmetro.

Classes de complexidade[editar | editar código-fonte]

FPT[editar | editar código-fonte]

FPT contém os problemas tratáveis em parâmetro fixo, que são aqueles que podem ser resolvidos em tempo para alguma função computável . Tipicamente, essa função é vista como unicamente exponencial, como por exemplo mas a definição permite funções que crescem ainda mais rápido. Isso é essencial para grande parte da história inicial da classe. A parte crucial da definição é excluir funções do formato , como . A classe FPL (linear em parâmetro fixo) é a classe de problemas solúveis em tempo para alguma função computável Grohe (1999). FPL é, portanto, uma subclasse de FPT.

Um exemplo é o problema de satisfatibilidade, parametrizado pelo número de variáveis. Uma dada fórmula de tamanho com pode ser verificada com força bruta em tempo . Uma cobertura de vértice de tamanho em um grafo de ordem pode ser encontrada em tempo , então esse problema está, também, em FPT.

Um problema que se pensa não estar em FPT é o problema de Coloração de grafos parametrizado pelo número de cores. É sabido que 3-coloração é NP-difícil, e um algoritmo para um grafo -coloração em tempo para rodaria em tempo polinomial para o tamanho da entrada. Portanto, se o problema de coloração de grafos parametrizado para o número de cores estiver em FPT, então P = NP.

Há uma série de definições alternativas para FPT. Por exemplo, o requerimento de tempo de execução pode ser substituído por . Inclusive, um problema parametrizado está em FPT se possui um "kernel". Kernelização é uma técnica de pré-processamento que reduz a instância original ao seu "kernel absoluto", uma instância possivelmente bem menor que é equivalente à instância original mas possui um tamanho que é limitado à função no parâmetro.

FPT é fechada sob uma redução chamada redução fpt, que simultaneamente preserva o tamanho da instância e o parâmetro.

Obviamente, FPT contém todos os problemas computáveis de tempo polinomial. Ademais, contém todos os problemas de otimização em NP que permitem um esquema de aproximação em tempo polinomial.

Hierarquia W[editar | editar código-fonte]

A hierarquia W é uma coleção de classes de complexidade computacional. Um problema de parametrização está na classe W[i], se toda instância pode ser transformada (em tempo fpt) em um circuito combinatório com cardinalidade no máximo i, de modo que se e somente se há uma valoração satisfatível para as entradas, que valora 1 para no máximo k entradas. A altura é, portanto, o maior número de unidades lógicas com número de entradas ilimitado em qualquer caminho da entrada para a saída. O número de unidades lógicas com número de entradas limitado nos caminhos deve ser limitado por uma constante válida para todas as instâncias do problema.

Note que FPT = W[0] and W[i] W[j] para todo . As classes na hierarquia W são também fechadas sob redução fpt.

Muitos problemas computacionais naturais ocupam os níveis mais baixos, W[1] and W[2].

W[1][editar | editar código-fonte]

Exemplos de problemas W[1]-completos incluem

  • decidir se dado grafo contém um clique de tamanho k
  • decidir se dado grafo contém um Conjunto independente de tamanho k
  • decidir se uma dada máquina de Turing não-determinística de única fita aceita uma palavra em k passos (problema da "aceitação curta por máquinas de Turing")

W[2][editar | editar código-fonte]

Exemplos de problemas W[2]-completos incluem

  • decidir se um dado grafo possui um conjunto dominante de tamanho k
  • decidir se uma dada máquina de Turing multi-fita não-determinística aceita em k passos

W[t][editar | editar código-fonte]

pode ser definida usando a família de problemas SAT Ponderados Cardinalidade--Profundidade- para : é a classe de problemas parametrizados fpt-redutíveis a esse problema, e .

Nesse caso, SAT Ponderados Cardinalidade--Profundidade- é o seguinte problema:

  • Entrada: Uma fórmula Booleana de profundidade no máximo e cardinalidade no máximo , e um número . A profundidade é o número máximo de portões em qualquer caminho da raiz para uma folha, e a cardinalidade é o número máximo de portões com número de entradas no mínimo três em qualquer caminho da raiz para uma folha.
  • Questão: A fórmula possui uma valoração satisfatível de peso Hamming no máximo ?

Pode ser provado que o problema SAT -Normalizado Ponderado é completo para sob reduções fpt.[2] Aqui, SAT -Normalizado Ponderado é o seguinte problema:

  • Entrada: Uma fórmula Booleana de profundidade no máximo com um portão AND no topo, e um número .
  • Questão: A fórmula possui uma valoração satisfeitora de peso Hamming no máximo ?

W[P][editar | editar código-fonte]

W[P] é a classe de problemas que podem ser decididos por uma máquina de Turing não-determinística de tempo polinomial que faz no máximo escolhas não-determinísticas na computação em (uma Máquina de Turing k-restrita). Flum & Grohe (2006)

É sabido que FPT está contida em W[P], e acredita-se que a inclusão é própria. Entretanto, resolver esse problema implicaria em uma solução para o problema P versus NP.

Outras conexões com complexidade computacional não-parametrizada são que: FPT é igual a W[P] se e somente se a satisfatibilidade de circuito pode ser decidida em tempo , ou se e somente se existe uma função não-limitada, não-decrescente e computável de modo que todas as linguagens reconhecidas por uma máquina de Turing não-determinística de tempo polinomial usando f(n)log n escolhas não-determinísticas in P.

XP[editar | editar código-fonte]

XP é a classe de problemas parametrizados que podem ser solucionados em tempo para alguma função computável .

Predefinição:Expand section

Notas[editar | editar código-fonte]

  1. Chen, Kanj & Xia 2006
  2. Buss, Jonathan F, Islam, Tarique (2006). «Simplifying the weft hierarchy». Elsevier. Theoretical Computer Science. 351 (3): 303–313. doi:10.1016/j.tcs.2005.10.002 

Referências[editar | editar código-fonte]

Ligações externas[editar | editar código-fonte]