El algoritmo de Dios es un concepto originado en discusiones sobre formas de resolver el rompecabezas del cubo de Rubik,[1] pero que también se puede aplicar a otros rompecabezas combinatorios y juegos matemáticos.[2] Se refiere a cualquier algoritmo que produzca una solución con la menor cantidad de movimientos posibles, siendo la idea que solo un ser omnisciente conocería un paso óptimo de cualquier configuración dada. Pero hay un rompecabezas llamado Pyraminx Duo donde hay una tabla donde se soluciona el rompecabezas con el algoritmo de Dios para cada una de sus 324 combinaciones totales y cualquier persona que entienda la tabla puede resolverlo con el algoritmo de Dios.[3]
La noción se aplica a los rompecabezas que pueden asumir un número finito de "configuraciones", con un arsenal relativamente pequeño y bien definido de "movimientos" que pueden ser aplicables a configuraciones y luego conducir a una nueva configuración. Resolver el rompecabezas significa llegar a una "configuración final" designada, una configuración singular o una de una colección de configuraciones. Para resolver el rompecabezas se aplica una secuencia de movimientos, partiendo de alguna configuración inicial arbitraria.
Se puede considerar que un algoritmo resuelve tal rompecabezas si toma como entrada una configuración inicial arbitraria y produce como salida una secuencia de movimientos que conducen a una configuración final (si el rompecabezas se puede resolver a partir de esa configuración inicial, de lo contrario, indica la imposibilidad de una solución). Una solución es óptima si la secuencia de movimientos es lo más corta posible. Este recuento se conoce como el número de Dios,[4] o, más formalmente, el valor minimax.[5] El algoritmo de Dios, entonces, para un rompecabezas dado, es un algoritmo que resuelve el rompecabezas y produce solo soluciones óptimas.
Algunos escritores, como David Joyner, consideran que para que un algoritmo se denomine correctamente "algoritmo de Dios", también debería ser práctico, lo que significa que el algoritmo no requiere cantidades extraordinarias de memoria o tiempo. Por ejemplo, el uso de una tabla de búsqueda gigante indexada por configuraciones iniciales permitiría encontrar soluciones muy rápidamente, pero requeriría una cantidad extraordinaria de memoria.[6]
En lugar de pedir una solución completa, se puede pedir de manera equivalente un solo movimiento de una configuración inicial pero no final, donde el movimiento es el primero de alguna solución óptima. Un algoritmo para la versión de un solo movimiento del problema se puede convertir en un algoritmo para el problema original invocándolo repetidamente mientras se aplica cada movimiento informado a la configuración actual, hasta que se alcanza uno final. Por el contrario, cualquier algoritmo para el problema original puede convertirse en un algoritmo para la versión de un solo movimiento truncando su salida a su primer movimiento.
Los acertijos más conocidos que encajan en esta descripción son los acertijos mecánicos como el cubo de Rubik, las Torres de Hanói y el juego del 15. También se cubre el juego para una persona del solitario Senku, así como muchos acertijos de lógica, como el problema de los misioneros y caníbales. Estos tienen en común que se pueden modelar matemáticamente como un grafo dirigido, en el que las configuraciones son los vértices y los movimientos los arcos.
El juego del 15 se puede resolver en 80 movimientos de una sola ficha[7] o 43 movimientos de varias fichas[8] en el peor de los casos. Para su generalización el n- rompecabezas, el problema de encontrar una solución óptima es NP-hard.[9] Por lo tanto, se desconoce si existe un algoritmo de Dios práctico para este problema, pero parece poco probable.
Para las Torres de Hanói, se conoce el algoritmo de un Dios para cualquier número de discos. El número de movimientos es exponencial en el número de discos ( ).[10]
Richard Korf publicó en 1997 un algoritmo para determinar el número mínimo de movimientos para resolver el cubo de Rubik.[11] Si bien se sabía desde 1995 que 20 era un límite inferior en el número de movimientos para la solución en el peor de los casos, se demostró en 2010 a través de extensos cálculos por computadora que ninguna configuración requiere más de 20 movimientos.[12] Por tanto, 20 es un límite superior marcado en la longitud de las soluciones óptimas. El matemático David Singmaster había "conjeturado precipitadamente" que este número era 20 en 1980.[5]
Se han encontrado números para el cubo de tres colores, cuyo número total de configuraciones es:
En marzo-abril de 2012, se descubrió que el número de Dios para el cubo de tres colores opuestos es 15 FTM, 17 QTM o 14 STM (según la métrica STM, la rotación de cualquier capa intermedia también se considera un movimiento).[13]
Sin embargo, algunos juegos bien conocidos con un conjunto muy limitado de reglas y movimientos simples y bien definidos nunca han tenido el algoritmo de Dios para una estrategia ganadora determinada. Algunos ejemplos son los juegos de mesa ajedrez y go.[14] Ambos juegos tienen un número de posiciones que aumenta rápidamente con cada movimiento. El número total de todas las posiciones posibles, aproximadamente 10154 para el ajedrez[15] y 10180 (en un tablero de 19 × 19) para el go,[16] es demasiado grande para permitir una solución de fuerza bruta con la tecnología informática actual (compare el ahora resuelto, con gran dificultad, el cubo de Rubik en solo aproximadamente 4.3×1019 posiciones[17]). En consecuencia, no es posible una determinación de fuerza bruta del algoritmo de Dios para estos juegos. Si bien se han construido computadoras de ajedrez que son capaces de vencer incluso a los mejores jugadores humanos, no calculan el juego hasta el final. Deep Blue, por ejemplo, buscaba solo 11 movimientos hacia delante (contando un movimiento de cada jugador como dos movimientos), reduciendo el espacio de búsqueda a solo 1017.[18] Después de esto, evaluó la ventaja de cada posición de acuerdo con las reglas derivadas del juego y la experiencia humanos.
Incluso esta estrategia no es posible con el go. Además de tener muchísimas más posiciones para evaluar, nadie hasta ahora ha construido con éxito un conjunto de reglas simples para evaluar la fuerza de una posición de go como se ha hecho con el ajedrez.[19] Los algoritmos de evaluación son propensos a cometer errores elementales[20] por lo que incluso para una mirada limitada hacia el futuro con el objetivo limitado a encontrar la posición interina más fuerte, un algoritmo de Dios no ha sido posible para el go.
Por otro lado, las damas, con similitudes superficiales con el ajedrez, han sido sospechadas durante mucho tiempo de ser "jugadas" por sus expertos practicantes.[21] En 2007, Schaeffer et al. demostró que esto era así calculando una base de datos de todas las posiciones con diez o menos piezas. Por lo tanto, Schaeffer tiene un algoritmo de Dios para todos los juegos finales de damas y lo utilizó para demostrar que todos los juegos de damas perfectamente jugados terminarán en empate.[22] Sin embargo, las damas con sólo 5×1020 posiciones[23] e incluso menos, 3.9×1013, en la base de datos de Schaeffer,[24] es un problema mucho más fácil de descifrar y es del mismo orden que el cubo de Rubik.
La magnitud del conjunto de posiciones de un rompecabezas no determina por completo si es posible un algoritmo de Dios. El rompecabezas de la Torre de Hanói ya resuelto puede tener un número arbitrario de piezas, y el número de posiciones aumenta exponencialmente como . Sin embargo, el algoritmo de solución es aplicable a problemas de cualquier tamaño, y dado que el tiempo de ejecución del algoritmo es el problema es NP-hard.[25]