stringtranslate.com

Reducción de Turing

En teoría de la computabilidad , una reducción de Turing de un problema de decisión a un problema de decisión es una máquina oráculo que decide un problema dado un oráculo para (Rogers 1967, Soare 1987). Puede entenderse como un algoritmo que podría usarse para resolver si tuviera a su disposición una subrutina para resolverlo . El concepto puede aplicarse análogamente a problemas de funciones .

Si existe una reducción de Turing de a , entonces cada algoritmo para [a] puede usarse para producir un algoritmo para , insertando el algoritmo para en cada lugar donde la máquina oráculo que calcula consulta al oráculo para . Sin embargo, debido a que la máquina oráculo puede consultar al oráculo una gran cantidad de veces, el algoritmo resultante puede requerir más tiempo asintóticamente que el algoritmo para o que la máquina oráculo que calcula . Una reducción de Turing en la que la máquina oráculo se ejecuta en tiempo polinomial se conoce como reducción de Cook .

La primera definición formal de computabilidad relativa, entonces llamada reducibilidad relativa, fue dada por Alan Turing en 1939 en términos de máquinas oráculo . Más tarde, en 1943 y 1952, Stephen Kleene definió un concepto equivalente en términos de funciones recursivas . En 1944, Emil Post utilizó el término "reducibilidad de Turing" para referirse al concepto.

Definición

Dados dos conjuntos de números naturales, decimos que Turing es reducible a y escribimos

si y solo si hay una máquina oráculo que calcula la función característica de A cuando se ejecuta con el oráculo B. En este caso, también decimos que A es B -recursiva y B -computable .

Si hay una máquina oráculo que, cuando se ejecuta con el oráculo B , calcula una función parcial con dominio A , entonces se dice que A es B - recursivamente enumerable y B -computablemente enumerable .

Decimos que Turing es equivalente a y escribimos si ambos y Las clases de equivalencia de los conjuntos equivalentes de Turing se denominan grados de Turing . El grado de Turing de un conjunto se escribe .

Dado un conjunto , un conjunto se llama Turing duro para si para todos . Si además entonces se llama Turing completo para .

Relación entre la completitud de Turing y la universalidad computacional

La completitud de Turing, tal como se acaba de definir más arriba, corresponde sólo parcialmente a la completitud de Turing en el sentido de universalidad computacional. Específicamente, una máquina de Turing es una máquina de Turing universal si su problema de detención (es decir, el conjunto de entradas para las que finalmente se detiene) es completo en muchos-uno para el conjunto de conjuntos recursivamente enumerables. Por lo tanto, una condición necesaria pero insuficiente para que una máquina sea computacionalmente universal es que el problema de detención de la máquina sea Turing-completo para . Insuficiente porque todavía puede darse el caso de que el lenguaje aceptado por la máquina no sea en sí mismo recursivamente enumerable.

Ejemplo

Sea el conjunto de valores de entrada para los cuales la máquina de Turing con índice e se detiene. Entonces los conjuntos y son equivalentes de Turing (aquí denota una función de emparejamiento efectiva). Se puede construir una reducción que muestre usando el hecho de que . Dado un par , se puede construir un nuevo índice usando el teorema s mn de modo que el programa codificado por ignore su entrada y simplemente simule el cálculo de la máquina con índice e en la entrada n . En particular, la máquina con índice se detiene en cada entrada o se detiene en ninguna entrada. Por lo tanto, se cumple para todos los e y n . Debido a que la función i es computable, esto muestra . Las reducciones presentadas aquí no son solo reducciones de Turing sino reducciones de muchos-uno , que se analizan a continuación.

Propiedades

El uso de una reducción

Dado que cada reducción de un conjunto a un conjunto tiene que determinar si un solo elemento está en solo un número finito de pasos, solo puede hacer un número finito de consultas de pertenencia al conjunto . Cuando se analiza la cantidad de información sobre el conjunto utilizada para calcular un solo bit de , esto se precisa mediante la función de uso . Formalmente, el uso de una reducción es la función que envía cada número natural al número natural más grande cuya pertenencia en el conjunto fue consultada por la reducción al determinar la pertenencia de en .

Reducciones más fuertes

Hay dos formas comunes de producir reducciones más fuertes que la reducibilidad de Turing. La primera es limitar la cantidad y la forma de realizar consultas al oráculo.

La segunda forma de producir una noción de reducibilidad más fuerte es limitar los recursos computacionales que puede utilizar el programa que implementa la reducción de Turing. Estos límites a la complejidad computacional de la reducción son importantes cuando se estudian clases subrecursivas como P . Un conjunto A es reducible en tiempo polinómico a un conjunto si hay una reducción de Turing de a que se ejecuta en tiempo polinómico. El concepto de reducción en el espacio logarítmico es similar.

Estas reducciones son más fuertes en el sentido de que proporcionan una distinción más precisa entre clases de equivalencia y satisfacen requisitos más restrictivos que las reducciones de Turing. En consecuencia, dichas reducciones son más difíciles de encontrar. Puede que no haya forma de construir una reducción de muchos-uno de un conjunto a otro incluso cuando exista una reducción de Turing para los mismos conjuntos.

Reducciones más débiles

Según la tesis de Church-Turing , una reducción de Turing es la forma más general de una reducción efectivamente calculable. Sin embargo, también se consideran reducciones más débiles. Se dice que un conjunto es aritmético en si es definible por una fórmula de aritmética de Peano con como parámetro. El conjunto es hiperaritmético en si hay un ordinal recursivo tal que es computable a partir de , el salto de Turing α -iterado de . La noción de constructibilidad relativa es una noción de reducibilidad importante en la teoría de conjuntos .

Véase también

Notas

  1. ^ Es posible que B sea un problema indecidible para el que no existe ningún algoritmo.

Referencias

Enlaces externos