/AI-Project-Notes

Resumen de la parte práctica que abordamos en el curso de IA. Scripts correspondientes a algoritmos de búsqueda, redes neuronales artificiales y algoritmos genéticos.

Primary LanguageJupyter Notebook

Reporte Semestral IA

Class: IA Created: June 9, 2020 1:57 PM Type: Summary


1.0 Caso de estudio - Problema de N-Damas

El proyecto de N-Reinas consiste en una búsqueda a lo ancho en el cual se busca obtener un acomodo de n reinas en un tablero de tal manera que no haya ataques entre ellas.

data/Untitled.png

El objetivo es reorganizar los bloques de un tablero de 3x3 para que los números que se encuentran en éstos, terminen ordenados de manera ascendente. Sólo se permite deslizar los bloques de manera horizontal o verticalmente en el cuadrado en blanco.

data/Untitled%201.png

1.1 Búsqueda a lo Ancho (BFS)

1.1.1 Funcionamiento

Es una estrategia de búsqueda en la que se expande primero el nodo raíz, a continuación se expanden todos los sucesores del nodo raíz, después sus sucesores, etc.

En general, se expanden todos los nodos a una profundidad en el árbol de búsqueda antes de expandir cualquier nodo del próximo nivel.

data/Untitled%202.png

1.1.1 Implementación visual en el problema de N-Damas

Empieza a realizar la búsqueda y a mover las reinas en este caso representada por cuadros negros.

data/Untitled%203.png

Una vez que encuentra el estado en el que se cumple el objetivo de que no haya ataques entre sí detiene la búsqueda y pinta de rojo a las reinas.

data/Untitled%204.png

1.2 Búsqueda de Profundidad (DFS)

1.2.1 Funcionamiento

Este tipo de búsqueda siempre expande el nodo más profundo en la frontera actual del árbol de búsqueda.

La búsqueda procede inmediatamente al nivel más profundo del árbol de búsqueda, hasta que los nodos de búsqueda no tienen ningún sucesor.

data/Untitled%205.png

1.2.2 Implementación visual en el problema de N-Damas

data/Untitled%206.png

1.3 Búsqueda de Profundidad Limitada(LDFS)

1.3.1 Funcionamiento

Se puede resolver el problema de realizar una búsqueda de profundidad en árboles con hojas ilimitadas definiendo un límite de profundidad L.

Es decir, los nodos a profundidad L se tratan como si no tuvieran ningún sucesor y, por ende, se detiene la expansión de los estados de dicho nodo.

1.3.2 Implementación visual en el problema de N-Damas

data/Untitled%207.png

1.4 Búsqueda Iterativa de Profundidad Limitada(IDFS)

1.4.1 Funcionamiento

La búsqueda con profundidad iterativa es una estrategia general, usada a menudo en combinación con la técnica LDFS, la cual encuentra el mejor límite de profundidad.

Esto se hace aumentando gradualmente el límite, desde 0 hasta L, deteniéndose únicamente en el caso de que se cumpla la meta o se alcance el último nodo del último nivel.

1.4.2 Implementación visual en el problema de N-Damas

data/Untitled%208.png

1.5 Búsqueda Bidireccional

1.5.1 Funcionamiento

El algoritmo bidireccional consiste en hacer dos búsquedas a lo ancho, una empezando en el estado inicial indicado y la otra iniciando en el estado meta deseado, y que al encontrarse con un mismo estado en común previamente percibido, imprime el camino desde el nodo de dicho estado en cada búsqueda hasta el nodo raíz de su respectiva búsqueda.

1.5.2 Implementación visual en el problema de N-Damas

Se inician las dos búsquedas a lo ancho, evitando los obstáculos (cuadros color negro).

data/Untitled%209.png

Una vez que encuentra el resultado pinta de color amarillo el camino a seguir.

data/Untitled%2010.png

1.6.1 Datos de entrada

  • Datos de las entidades
    • Por fines prácticos se extrajeron las coordenadas (en pixeles) de algunas entidades de la República Mexicana en base a una imagen de un mapa satelital.
  • Datos de las rutas
    • Se definieron algunas rutas de manera arbitraria.

data/Untitled%2011.png

cities.csv

data/Untitled%2012.png

routes.csv

NOTA: Ambos datos se recobran de archivos separados por coma (cities.csv, routes.csv). Éstos pueden ser modificados a gusto del usuario antes de ejecutar el programa. Sin embargo, debe considerarse que ambos archivos deben contener datos únicos y toda entidad que exista en el archivo de rutas, deberá de existir en el archive de ciudades.

1.6.2 Algoritmo

data/Untitled%2013.png

Algoritmo principal

data/Untitled%2014.png

Calcula las heurísticas para las ciudades vecinas de la ciudad actual

1.6.3 Resultados

data/Untitled%2015.png

Ejecución Baja California - Durango

data/Untitled%2016.png

Resultado

data/BC-Durango.mp4

Recorrido Baja California - Durango

data/Untitled%2017.png

Ejecución Baja California - Nuevo Leon

data/Untitled%2018.png

Resultado

data/BC-Nuevo-Leon.mp4

Recorrido Baja California - Nuevo Leon

NOTA: Para ejecutar el script es necesario instalar GLFW

2.1.1 Algoritmo

En la línea 85 se genera el flujo de tal manera que los individuos del salón de la fama (los que tengan el menor número de ataques de la población) son enviados directamente a la siguiente generación sin ser sujetos a ningún tipo de modificaciones genéticas (mutaciones).

data/Untitled%2019.png

Parámetros del modelo genético

data/Untitled%2020.png

2.1.2 Resultados

Generaciones y soluciones para N=50, Generaciones = 1000, Población = 3000.

data/Untitled%2021.png

data/Untitled%2022.png

3. Redes Neuronales

data/Untitled%2023.png

Iris Dataset.

3.1.1 Entrenamiento

data/Untitled%2024.png

3.1.2 Pruebas

data/Untitled%2025.png

data/Untitled%2026.png

3.2.1 Entrenamiento

data/Untitled%2027.png

3.2.2 Pruebas

data/Untitled%2028.png

data/Untitled%2029.png

4.0 Descripción

En la libreta jupyter CNN_model_generation define y entrena el modelo de la CNN. Se tomaron como entrada imágenes de 32px x 32px del famoso dataset CIFAR10, pero únicamente de las clases Perro,Gato,Rana para reducir el tiempo de entrenamiento.

Los resultados del entrenamiento del modelo fueron los siguientes:

data/CNN_Training_20_epoch.png

4.1 Capas del Modelo

data/Untitled%2030.png

4.2 Entrenamiento del modelo

data/Untitled%2031.png

4.3.1 Pruebas con muestra de entrenamiento

data/Untitled%2032.png

Se guarda el modelo de la red neuronal entrenada en un archivo .h5

4.3.2 Pruebas con imágenes recobradas de internet

data/Untitled%2033.png

Se recabaron 7 muestras diferentes de internet por cada clasificación (Gato, Rana, Perro) y se redimensionaron para coincidir con las imágenes de entrenamiento de 32px X 32px

data/Untitled%2034.png

Algoritmo de pruebas para imágenes descargadas de la web.

data/Untitled%2035.png

Resultados