Algoritmo de Bernstein–Vazirani

De testwiki
Ir a la navegación Ir a la búsqueda
Circuito quantico del algoritmo de Bernstein–Vazirani.

El Algoritmo de Bernstein–Vazirani es un algoritmo cuántico desarrollado por Ethan Bernstein y Umesh Vazirani en 1992.[1] En esencia, permite conocer un string s binario, esto es, una cadena de caracteres compuesta de ceros y unos (por ejemplo: s = 0010110101001), que está contenido en una función. Más concretamente, se sabe que dicha función toma la forma f(x)=sxmod (2), donde x es otro string y la multiplicación se entiende como producto binario. Este algoritmo funciona de manera similar al de Deutsch-Jozsa, pero en vez de tratar de distinguir entre clases de funciones, busca el string que caracteriza a la función dada. Supongamos a modo de ejemplo que se participa en un juego consistente en encontrar un número oculto escrito en código binario. Con la versión clásica del algoritmo, la única manera de obtener la solución sería ir haciendo comprobaciones del número oculto bit a bit, lo cual requiere al menos N ejecuciones, siendo N el número de bits de s (esto se denota como O(N) en teoría de la complejidad computacional). En el caso del algoritmo de Bernstein-Vazirani, si se consigue codificar dicho número en el string s, una única ejecución del algoritmo bastaría para encontrar el número completo.

La importancia de este algoritmo radica en la superioridad que muestra frente a su equivalente clásico, pudiéndose encontrar el string buscado tras una única ejecución.

Solución clásica

En el caso clásico, es necesario utilizar tantos strings de entrada como bits tenga s, esto es, el número de iteraciones depende de la longitud del string buscado. La manera óptima de obtener dicho string sería por tanto ejecutar la función con bits de la forma xn=00...1...0, donde el 1 se encuentra en el n-ésimo bit, de tal forma que la función devolvería el bit colocado en la misma posición del string s. Tras repetir el proceso para todas las posiciones se obtiene el string buscado. En resumen, para un string de N bits

{f(1...0)=s1f(01...0)=s2...f(0...1)=sN

Algoritmo

La versión cuántica del algoritmo parte de un estado generado tras aplicar una puerta Hadamard a todos los cúbits (que se sobreentienden inicialmente en el estado |0), es decir

|00...0Hn12nx=02n1|x

El segundo paso es hacer la llamada al oráculo cuántico. Se utiliza el oráculo Uf que realiza la transformación |x(1)f(x)|x. Con ello, el estado obtenido anteriormente queda

12nx=02n1|xUf12nx=02n1(1)f(x)|x

Una vez hecho esto, el último paso consiste en volver a aplicar las puertas Hadamard y obtener así el estado |s

12nx=02n1(1)f(x)|xHn|s

En el paso anterior ha de tenerse en cuenta que 12nx=02n1(1)f(x)|xHn12nx,y=02n1(1)xs+sy|x=12nx,y=02n1(1)x(sy)|y=|s, ya que si ys el exponente no se anula y la suma en x cancela todos los términos entre sí. Otra forma de verlo es que una puerta Hadamard es su propia inversa.Plantilla:Invisible

Véase también

Referencias

Plantilla:Listaref

Bibliografía

Enlaces externos

Plantilla:Control de autoridades