P/polyEn la teoría de la complejidad computacional, P/poly es la clase de complejidad de los lenguajes reconocidos por una máquina de Turing de tiempo polinomial con una función de asesoramiento limitada polinomialmente. También se define de manera equivalente como la clase PSIZE de lenguajes que tienen circuitos de tamaño polinómico.[1][2] Esto significa que la máquina que reconoce un idioma puede usar una función de asesoramiento diferente o un circuito diferente dependiendo de la longitud de la entrada y que la función o circuito de asesoramiento variará solo según el tamaño de la entrada. Por ejemplo, la popular prueba de primalidad Miller-Rabin puede formularse como un algoritmo P/poly: el "consejo" es una lista de candidatos a valores para probar. Es posible calcular previamente una lista de, como máximo, n valores de modo que cada número compuesto de n bits se asegure de tener un testigo a en la lista. Por ejemplo, para determinar correctamente la primalidad de los números de 32 bits, es suficiente probar a = 2, 7 y 61.[3] La existencia de listas cortas de testigos candidatos sigue del hecho de que para cada n compuesto, 3/4s de todos los valores posibles son testigos; un simple argumento de recuento similar a la de la prueba de que BPP en P/poly muestra que existe una lista adecuada de valores a para cada tamaño de entrada, aunque encontrarla puede ser caro. P/poly, a diferencia de otras clases de tiempo polinomial como P o BPP, generalmente no se considera una clase práctica para la computación. De hecho, contiene todos los lenguajes unarios indecidibles, ninguno de los cuales puede ser resuelto en general por computadoras reales. Por otro lado, si la longitud de entrada está limitada por un número relativamente pequeño y las cadenas de consejos son cortas, puede usarse para modelar algoritmos prácticos con una fase de preprocesamiento costosa separada y una fase de procesamiento rápido, como en el ejemplo anterior. Importancia de P/polyP / poly es una clase importante por varias razones. Para la informática teórica, hay varias propiedades importantes que dependen de P/poly:
Una de las razones más interesantes por las que P/poly es importante es la propiedad de que si NP no es un subconjunto de P/poly, entonces P ≠ NP. Esta observación fue el centro de muchos intentos de probar P ≠ NP . Se sabe que para un oráculo aleatorio A, NP A no es un subconjunto de P A/poly con probabilidad 1.[1] P/poly también se usa en el campo de la criptografía. La seguridad a menudo se define 'contra' los adversarios P/poly. Además de incluir la mayoría de los modelos prácticos de cómputo como BPP, esto también admite la posibilidad de que los adversarios puedan realizar una precomputación pesada para entradas de hasta una cierta longitud, como en la construcción de tablas arcoíris. Aunque no todos los lenguajes en P/poly son lenguajes dispersos, existe una reducción de Turing en tiempo polinómico de cualquier idioma en P/poly a un idioma disperso.[8] El polinomio probabilístico de error acotado está contenido en P/polyEl teorema de Adleman establece que BPP ⊆ P/poly, donde BPP es el conjunto de problemas que se pueden resolver con algoritmos aleatorios con error de dos lados en el tiempo polinómico. Leonard Adleman demostró inicialmente un resultado más débil, a saber, que RP ⊆ P/poly;[9] y este resultado se generalizó a BPP ⊆ P / poly por Bennett y Gill.[10] Las variantes del teorema muestran que BPL está contenido en L/poly y AM está contenido en NP / poly . PruebaSea L un lenguaje en BPP, y sea M (x, r) un algoritmo de tiempo polinómico que decida L con un error ≤ 1/3 (donde x es la cadena de entrada y r es un conjunto de bits aleatorios) Construya una nueva máquina M' (x, R), que ejecute M 18*n veces y obtenga un voto mayoritario de los resultados (donde n es la longitud de entrada y R es una secuencia de 18*n rs independientemente aleatorios). Por lo tanto, M' también es tiempo polinomial y tiene una probabilidad de error ≤ 1/en por el límite de Chernoff. Si podemos arreglar R entonces obtenemos un algoritmo que es determinista. Si Bad (x) se define como { R : M ' ( x, R ) es incorrecto}, tenemos: El tamaño de entrada es n, por lo que hay 2n entradas posibles. Por lo tanto, por el límite de la unión, la probabilidad de que una R aleatoria sea mala para al menos una entrada x es En palabras, la probabilidad de que R sea mala para algunas x es menor que 1, por lo tanto, debe haber una R que sea buena para todas las x. Tome esa R como la cadena de consejos en nuestro algoritmo P/poly . Referencias
|