Problema de Simon

En álgebra abstracta y computación cuántica, el problema planteado por Daniel R. Simon (conocido como problema de Simon) es un caso particular del problema del subgrupo oculto (Hidden Subgroup Problem, HSP), el cual ha sido útil para el planteamiento de algoritmos cuánticos que son eficientes, a diferencia de sus homólogos clásicos, permitiendo resolver problemas teóricos propuestos en las últimas décadas cuyas soluciones son de vital importancia en el campo de la computación cuántica.

Para resolver el problema de Simon se han desarrollado algoritmos clásicos que utilizan fuerza bruta, de los cuales se sabe que su complejidad es exponencial. Para encontrar una  solución eficiente se ha recurrido a algoritmos cuánticos, como el propuesto por el mismo Simon, cuya complejidad es polinomial, reduciendo así el tiempo de cómputo de forma significativa.

Se han desarrollado algoritmos cuánticos para otros casos particulares del problema del subgrupo oculto, pero solo son eficientes aquellos que trabajan sobre grupos abelianos (como el de Simon). Para los grupos no abelianos aún no se han encontrado algoritmos cuánticos eficientes, de hecho estos no llegan a tener mejor desempeño que las soluciones clásicas.

Conceptos previos

Relación de equivalencia

Una relación de equivalencia sobre un grupo G {\displaystyle G} es una relación E G × G {\displaystyle E\subseteq G\times G} que cumple las propiedades:

  1. Reflexiva: g E g {\displaystyle gEg} para cada g {\displaystyle g} que pertenece a G {\displaystyle G} .
  2. Simétrica: Si g E t {\displaystyle gEt} entonces t E g {\displaystyle tEg} .
  3. Transitiva: Si g E t {\displaystyle gEt} y t E u {\displaystyle tEu} entonces g E u {\displaystyle gEu} .

Los elementos g , t {\displaystyle g,t} y u {\displaystyle u} son elementos de G {\displaystyle G} ; note que cada elemento de G {\displaystyle G} está envuelto en un requerimiento 1,2 o 3.

Congruencia entre conjuntos

Congruencia por izquierda

Sea H {\displaystyle H} un subgrupo de G {\displaystyle G} , entonces dos elementos g i {\displaystyle g_{i}} y g j {\displaystyle g_{j}} de G {\displaystyle G} son congruentes módulo H {\displaystyle H} si hay un elemento h k {\displaystyle h_{k}} para el cual g i = g j h k . {\displaystyle g_{i}=g_{j}h_{k}.}

Congruencia por derecha

Sea H {\displaystyle H} un subgrupo de G {\displaystyle G} , entonces dos elementos g i {\displaystyle g_{i}} y g j {\displaystyle g_{j}} de G {\displaystyle G} son congruentes módulo H {\displaystyle H} si hay un elemento h k {\displaystyle h_{k}} para el cual g i = h k g j . {\displaystyle g_{i}=h_{k}g_{j}.}

Suponiendo que H {\displaystyle H} es un subgrupo de G {\displaystyle G} , la congruencia módulo H {\displaystyle H} es una relación de equivalencia en G {\displaystyle G} . La congruencia módulo H {\displaystyle H} particiona a G {\displaystyle G} en una colección de clases de equivalencia que son disyuntas 2 a 2. Cada clase está formada por elementos que son congruentes entre sí.

Cosets

Sea H {\displaystyle H} un subgrupo de G {\displaystyle G} , y sea g G {\displaystyle g\in G} . El coset por izquierda de g {\displaystyle g} respecto a H {\displaystyle H} es el conjunto g H = { g h 1 , g h 2 , . . . , g h k , . . . } {\displaystyle gH=\{gh_{1},gh_{2},...,gh_{k},...\}} siendo H = { h 1 , h 2 , . . . , h k , . . . } {\displaystyle H=\{h_{1},h_{2},...,h_{k},...\}} . Así mismo se define el coset por derecha como el conjunto H g = { h 1 g , h 2 g , . . . , h k g , . . . } {\displaystyle Hg=\{h_{1}g,h_{2}g,...,h_{k}g,...\}} siendo H = { h 1 , h 2 , . . . , h k , . . . } {\displaystyle H=\{h_{1},h_{2},...,h_{k},...\}} .

Note que g i {\displaystyle g_{i}\equiv } g j {\displaystyle g_{j}} (mod H {\displaystyle H} ), si y sólo si, sus respectivas clases de equivalencia o cosets son iguales, es decir, g i H = g j H {\displaystyle g_{i}H=g_{j}H} . Para obtener distintos cosets, se usarán elementos g i {\displaystyle g_{i}} y g j {\displaystyle g_{j}} que sean incongruentes módulo H {\displaystyle H} .[1]

Periodicidad de funciones que actúan sobre grupos

Definición

Una función f se dice periódica si, para alguna constante P diferente de cero, se tiene que:

f ( x + P ) = f ( x ) {\displaystyle f(x+P)=f(x)}

Para todos los valores de x en el dominio de f. Una constante P distinta de cero para la cual se cumpla la propiedad anterior se denomina período de la función. La menor constante positiva P con esta propiedad, se denomina período fundamental (también período primitivo, período básico o período primo). A menudo, el "período" de una función se utiliza para indicar su período fundamental. Una función con período P se repetirá en intervalos de longitud P, y estos intervalos a veces también se conocen como períodos de la función.

Importancia

Aunque en principio pueda no parecerlo, lo cierto es que las funciones periódicas se relacionan de manera directa con uno de los problemas más difíciles de resolver hasta el momento: la descomposición de un número entero en factores primos.

Aun cuando cualquier número entero tiene una descomposición única en un producto de números primos, encontrar dichos factores primos es un problema difícil. De hecho, la seguridad de las transacciones en línea se basa en el criptosistema de clave pública RSA, cuya fuerza reside en la dificultad de factorizar números grandes.[2]​ En la práctica factorizar enteros con cientos de dígitos es prácticamente imposible, el número más grande factorizado hasta la fecha es RSA-768, un número de 232 cifras decimales, el cual fue factorizado en 2009.[3]​ En la actualidad RSA usa números primos del orden de 10 300 {\displaystyle 10^{300}} y 10 600 {\displaystyle 10^{600}} .

Desde la década de los 70’s es conocido por los matemáticos que factorizar se hace más fácil si se puede resolver otro problema difícil: encontrar el periodo de la función exponencial modular.[2]​ El problema de Simon está estrechamente relacionado con este problema, ya que el algoritmo de Simon, un algoritmo cuántico probabilístico con una complejidad polinomial, resuelve el problema de la determinación del periodo de una función periódica f : { 0 , 1 } n { 0 , 1 } n {\displaystyle f:\{0,1\}^{n}\rightarrow \{0,1\}^{n}} (el problema de la factorización se puede reducir a este último). En contraste, el algoritmo clásico tiene una complejidad exponencial. La implicación del uso de estas técnicas teóricas es la vulnerabilidad de la información protegida en la actualidad por métodos tipo RSA.

Problema del subgrupo oculto

Historia

El problema del subgrupo oculto surge en 1994, cuando Peter Shor Williston, profesor estadounidense de matemáticas aplicadas, basándose en el trabajo de David Elieser Deutsch, profesor israelí y pionero de la computación cuántica, y Daniel R. Simon, master en ciencias de la computación de la Universidad de Toronto, encontró un algoritmo cuántico que podía factorizar enteros exponencialmente más rápido que los métodos clásicos conocidos. Alexei Kitaev, un profesor de física ruso-estadounidense, concluyó que estos algoritmos encajan en un marco para encontrar generadores de subgrupos que son ocultados mediante una función.[4]

Definición

La definición formal del problema del subgrupo oculto (HSP) es:

Input: Sea ( G , f ) {\displaystyle (G,f)} , donde G {\displaystyle G} es un grupo y f {\displaystyle f} una función. f : G X {\displaystyle f:G\rightarrow X} , entonces existe H G {\displaystyle H\subseteq G} tal que f {\displaystyle f} es constante sobre los cosets de H {\displaystyle H} .

Problema: Encontrar H {\displaystyle H} .

Eficiencia cuántica

Si G {\displaystyle G} es un grupo Abeliano finito, la determinación del problema del subgrupo oculto puede ser teóricamente resuelta mediante un algoritmo cuántico de manera eficiente, es decir con un orden de complejidad  O [ p o l y ( log G ) ] {\displaystyle O[poly{\bigl (}\log \mid G\mid {\bigr )}]} . Sin embargo, no se tiene conocimiento de una solución cuántica eficiente que se pueda implementar cuando se trata con grupos finitos no-Abelianos.

Ejemplo

Definiendo el tamaño de un circuito cuántico como el número mínimo de operaciones elementales que deben componerse para obtener el circuito, y definiendo un Qubit como un vector de módulo unidad en un espacio vectorial complejo bidimensional; suponga que se quiere determinar el orden de un grupo finito Abeliano dado un conjunto generador. Dado un grupo G {\displaystyle G} es posible representar cada elemento del grupo utilizando aproximadamente log G {\displaystyle \log \mid G\mid } Qubits.

Para resolver de manera eficiente este problema mediante un algoritmo cuántico es necesario que el tamaño del circuito cuántico que va a computar el orden de G {\displaystyle G} sea de tamaño polinomial en log G {\displaystyle \log \mid G\mid } , dado que G {\displaystyle G} varía en toda la familia de grupos Abelianos finitos. Finalmente se requiere una “Clase uniforme de algoritmos”, la cual afirma que para un problema de tamaño n {\displaystyle n} , existe una máquina de Turing que dado n {\displaystyle n} , puede producir la descripción del circuito en un número de pasos igual a un polinomio en n {\displaystyle n} . Esto permite asegurar que (en teoría)  es posible construir una máquina explícita para resolver cada problema con un tiempo polinomial en el tamaño del problema.[4]

Definición del problema de Simon

Daniel R. Simon propuso en 1994 un problema en el que se demuestra el poder de la computación cuántica. Éste se presenta de la siguiente manera:

Input: f : { 0 , 1 } n { 0 , 1 } n {\displaystyle f:\{0,1\}^{n}\rightarrow \{0,1\}^{n}} , donde la función cumple alguna de las siguientes condiciones:

  1. f {\displaystyle f} es 1 a 1, es decir, la función es inyectiva.
  2. Existe una cadena s {\displaystyle s} no trivial tal que x , y { 0 , 1 } n , f ( x ) = f ( y ) y = x s {\displaystyle \forall x,y\in \{0,1\}^{n},\,f(x)=f(y)\leftrightarrow y=x\oplus s} , donde el símbolo denota la operación binaria XOR (O exclusivo)

Problema: Determinar cuál de las condiciones prevalece para f {\displaystyle f} y en caso de ser la segunda, determinar cuál es la cadena s {\displaystyle s} .[5]

Relación del problema del subgrupo oculto con el problema de Simon

La relación entre los problemas de Simon y del subgrupo oculto no es evidente, pero de hecho, es posible definirlo utilizando las herramientas que brinda la teoría de grupos.  Esto puede resultar útil al momento de buscar similitudes entre este y otros problemas, que en principio no tienen relación aparente, así como similitudes en sus posibles soluciones.

Buscando la estructura de grupo en el problema de Simon

Lo primero que se debe buscar para formar un grupo es un conjunto y una operación binaria sobre dicho conjunto. En el caso del problema de Simon, se trabaja sobre el conjunto de cadenas de bits de tamaño n {\displaystyle n} , donde n {\displaystyle n} es un entero positivo. El problema de Simon también involucra la operación binaria XOR, definida de la siguiente manera:

Sean a {\displaystyle a} y b {\displaystyle b} bits

a b = 0 {\displaystyle a\oplus b=0} si a = b {\displaystyle a=b}

a b = 1 {\displaystyle a\oplus b=1} si a b {\displaystyle a\neq b}

El problema de Simon se refiere al grupo G = ( { 0 , 1 } n , ) {\displaystyle G=(\{0,1\}^{n},\oplus )} , que resulta ser abeliano.[6]

Aplicando el problema del subgrupo oculto al grupo de Simon

Sea f : { 0 , 1 } n A {\displaystyle f:\{0,1\}^{n}\rightarrow A} y sea H {\displaystyle H} subgrupo de G {\displaystyle G} , se dice que f {\displaystyle f} es H-periódica si y sólo si se cumple:

x h i h j ( h i , h j x H f ( h i ) = f ( h j ) = f ( x ) ) {\displaystyle \forall x\forall h_{i}\forall h_{j}(h_{i},h_{j}\in xH\Rightarrow f(h_{i})=f(h_{j})=f(x))}

h x H g x H ( f ( h ) f ( g ) ) {\displaystyle \forall h\in xH\forall g\notin xH(f(h)\neq f(g))}

En otras palabras, la función f {\displaystyle f} es constante solo para elementos de un mismo coset.

Problema de Simon en términos del problema del subgrupo oculto

El problema de Simon define una función f : { 0 , 1 } n { 0 , 1 } n {\displaystyle f:\{0,1\}^{n}\rightarrow \{0,1\}^{n}} que resulta ser H-periódica para un subgrupo H = s {\displaystyle H=\langle s\rangle } de G {\displaystyle G} donde s {\displaystyle s} pertenece a G {\displaystyle G} .

En G {\displaystyle G} la inversa de cualquier elemento perteneciente al grupo es ella misma, entonces el orden de s {\displaystyle s} es 2. Por lo tanto H {\displaystyle H} es un subgrupo de dos elementos; s {\displaystyle s} , y la identidad.

H = ( { e , s } , ) {\displaystyle H=(\{e,s\},\oplus )}

Se puede entender la condición x G ( f ( x ) = f ( x s ) ) {\displaystyle \forall x\in G(f(x)=f(x\oplus s))} planteada en el problema de Simon como la condición planteada en el problema del subgrupo oculto, formando el coset x H {\displaystyle xH} .

Según la definición dada para H {\displaystyle H} , se sabe que h {\displaystyle h} puede ser s {\displaystyle s} o e {\displaystyle e} .

En estos términos, el problema de Simon consiste en encontrar el elemento generador del subgrupo oculto H {\displaystyle H} ,[7]​ o dicho en otras palabras, encontrar el periodo de la función f {\displaystyle f} que oculta dicho subgrupo.

A partir de las condiciones que presenta la función puede suponerse que no existe una relación entre ellas pero lo cierto es que independientemente del caso que aplique para la función a estudiar, la segunda condición es parcialmente verdadera y gracias a la estructura que el grupo G = ( { 0 , 1 } n , ) {\displaystyle G=(\{0,1\}^{n},\oplus )} presenta se puede establecer la siguiente observación:

Se sabe del grupo G {\displaystyle G} que su identidad es la cadena e = 0 n {\displaystyle e=0^{n}} y por teoría de grupos es válido afirmar que para toda cadena a {\displaystyle a} que pertenezca al grupo, a e = e a = a {\displaystyle a*e=e*a=a} . Entonces, si se aplica la segunda condición haciendo una excepción a la condición de que s {\displaystyle s} es diferente a la cadena trivial, se obtiene que f ( x ) = f ( y ) y = x 0 n {\displaystyle f(x)=f(y)\leftrightarrow y=x\oplus 0^{n}} , lo que es equivalente a decir que f ( x ) = f ( y ) 0 n = x y {\displaystyle f(x)=f(y)\leftrightarrow 0^{n}=x\oplus y} . Por definición de la operación XOR se sabe que al operar dos elementos se obtiene como respuesta 0 si los elementos son iguales, por lo que se puede que concluir que x = y {\displaystyle x=y} , lo que implica que la función envía a un elemento en sí mismo si s = 0 n {\displaystyle s=0^{n}} así que la función estudiada corresponde a la función identidad la cual es 1 a 1, por lo que las condiciones (1) y (2) sobre la función están relacionadas y según el valor de s {\displaystyle s} , se obtiene (2) para una cadena no trivial o (1) en caso contrario.


Soluciones al problema de Simon

Solución clásica

Para solucionar el problema primero es necesario encontrar el valor adecuado de s {\displaystyle s} diferente al trivial, o en su defecto, s = 0 n {\displaystyle s=0^{n}} ; por lo tanto, se deben revisar todos los valores que pueda tomar s {\displaystyle s} . Como hay 2 n {\displaystyle 2^{n}} posibles elecciones de s {\displaystyle s} , la complejidad sería de O ( 2 n ) {\displaystyle O(2^{n})} . Luego se evalúa la función “q” veces:

Si la función es 2 a 1, entonces, como mucho, q tiene que ser la mitad de entradas para encontrar una repetición.

Si se tienen que evaluar más, entonces, la función es 1 a 1 y s = 0 n {\displaystyle s=0^{n}} .

En definitiva, el número de evaluaciones en el peor de los casos será 2 n 2 + 1 {\displaystyle {\frac {2^{n}}{2}}+1} , es decir que la complejidad es de O ( 2 n 1 + 1 ) {\displaystyle O(2^{n-1}+1)} , la cual es mayor a la que se registraría en la solución cuántica al problema de Simon, la cual es polinomial.

Solución cuántica

Simon propone en su escrito la siguiente rutina para resolver el problema con complejidad polinomial:

Se llevan a cabo O ( n ) {\displaystyle O(n)} repeticiones de la Rutina Doble de Fourier:

  1. Realizar la transformación F {\displaystyle F} en una cadena de n {\displaystyle n} ceros, produciendo 2 n / 2 x | x {\displaystyle 2^{-n/2}\sum _{x}|x\rangle } .
  2. Calcular f ( x ) {\displaystyle f(x)} , concatenando la respuesta a x {\displaystyle x} , esto produce 2 n / 2 x | ( x , f ( x ) ) {\displaystyle 2^{-n/2}\sum _{x}|(x,f(x))\rangle } .
  3. Ejecutar F {\displaystyle F} sobre x {\displaystyle x} , produciendo 2 n y x ( 1 ) x y | ( y , f ( x ) ) {\displaystyle 2^{-n}\sum _{y}\sum _{x}(-1)^{x*y}|(y,f(x))\rangle }

Fin de la rutina doble de Fourier

Luego de estas O ( n ) {\displaystyle O(n)} repeticiones, se obtienen suficientes valores linealmente independientes de y {\displaystyle y} que permiten determinar el valor de la cadena s {\displaystyle s} al resolver el sistema de ecuaciones lineales definido por los valores de y {\displaystyle y} .

Por lo tanto, la complejidad de todo el algoritmo es O ( n T f ( n ) + G ( n ) ) {\displaystyle O(nT_{f}(n)+G(n))} , donde T f ( n ) {\displaystyle T_{f}(n)} es el tiempo requerido para calcular f {\displaystyle f} en inputs de tamaño n {\displaystyle n} , y G ( n ) {\displaystyle G(n)} es el tiempo requerido para resolver el sistema lineal de ecuaciones de n {\displaystyle n} x n {\displaystyle n} .[5]

Referencias

  1. Maxfield, John Edward (1992). «Abstract algebra and solution by radicals». EBSCOhost. 
  2. a b «Shor's algorithm». IBM. 2017. 
  3. Kleinjung, Thorsten (2010). «Factorization of a 768-bit RSA modulus». Eprint. 
  4. a b Lomont, Chris (2004). «The Hidden Subgroup Problem - Review and open problems». arXiv. 
  5. a b Simon, Daniel R. (1994). «On the Power of Quantum Computation». CiteSeerX. 
  6. Harold, Elliotte Rusty (26 de noviembre de 2012). «XOR Defines an Abelian Group». The Cafes>>Math. 
  7. Wright, John (10 de febrero de 2015). «Lecture 10: Hidden Subgroup Problem». Carnegie Mellon University. 
Control de autoridades
  • Proyectos Wikimedia
  • Wd Datos: Q5763587
  • Wd Datos: Q5763587