Evaluación de competencias 4
- Desarrollar el algoritmo de búsqueda A*
- Aplicar el algoritmo A* en un entorno y con diferentes heurísticas
- A partir de una descripción, ser capaz de formalizar un problema de búsqueda (lights-outs)
- Desarrollar la habilidad y creatividad para definir heurísticas no triviales.
- Poder analizar, así sea informalmente, la admisibilidad de una heurística.
- Comparar heurísticas no triviales.
De forma paralela, en esta tarea se desarrolla el uso de la herencia en el desarrollo orientado a objetos en
python, y se utiliza en forma intensiva a las funciones como pasajeros de primera clase. Igualmente, para este
problema, los estudiantes manejarán estructuras de datos más complejas como los Deque
, los heapq
, tablas hash
y conjuntos (como estructura de datos).
-
En el archivo
busquedas.py
se encuentra la clase abstractaProblema
(para búsquedas), la claseNodo
, para la estructura de datos que nos ayudará en la búsqueda, así como ls 4 búsquedas no informadas más utilizadas: BFS, DFS, IDS y UCS. Estas búsquedas las vimos en clase y no vamos a repetir. En clase se dio un ejemplo de el uso de dichas búsquedas para el problema de los dos recipientes. Revisa y familiarizate con dichas clases y funciones. Si es necesario desarrolla un problema pequeñito para que las pruebes (el problema de los misioneros y los canibales es un ejemplo fácil de programar y fácil de aplicar). -
En el mismo archivo, en la parte final, se encuentra el encabezado para desarrollar la función de búsqueda utilizando el algoritmo A*. Recuerda que en general estamos haciendo la búsqueda en grafos con el fin de reducir el número de estados explorados. Con el fin que pruebes si el algortimo que desarrollaste funciona, en el archivo
ocho_puzzle.py
se encuentra programado y funcionando el problema del ocho puzzle, así como las dos heurísicas vistas en clase. Con el fin de comparar resultados, se presenta la solucion de 3 problemas (3 estados iniciales diferentes) con ambas heurísticas y con la búsqueda de costo uniforme. Puedes cambiar esto y experimentar, hasta que estes seguro que tu algoritmo es eficiente. -
En el archivo
lightsout.py
se encuentra un nuevo reto, el juego (rompecabezas, puzzle o solitario, como se le quiera llamar) de Lights Out. La idea y operación básica de este juego se puede ver en Wikipedia, y no se detallan en las instrucciones. Desarrolla el problema del juego de Lights Out, definiendo los métodos deacciones_legales
,sucesor
,costo_local
y modificando el método__init__
. Puedes inspirarte en el ocho puzzle. -
Si bien existe una solución analítica (un algoritmo) para cualquier posición inicial del juego, a nosotros nos interesa utilizarlo como pretexto para desarrollar un método de búsqueda. Propón una huerística para el problema, especifica porque consideras que es admisible, y programala en la función
h_1
. -
Ahora propon una segunda heurística (proponer una puede ser algo dificil, pero dos ya implica creatividad). Argumenta porque crees que es admisible esta heurística.
-
Ejecuta el programa y revisa las soluciones con ambas heurísticas, y sobre esto, determina si hay una que parece dominante sobre la otra, y porqué.