Reconocimiento de conjuntos numéricos

Una de las funcionalidades que se han añadido en la versión 1.3 de LearningML es el reconicimiento de conjuntos numéricos. ¿Y en qué consiste esto de reconocer números? Pues en honor a la verdad, reconocer patrones numéricos es lo único que pueden hacer los algoritmos de ML. De hecho, cuando trabajamos con imágenes o textos, antes de ser introducidas como entradas del algoritmo, son convertidas (codificadas) a conjuntos numéricos.

En LearningML, cada imagen de ejemplo es convertida en un conjunto de números (denominado tensor). La imagen se divide en una red de 227×227 cuadraditos (pixeles) y el color de cada uno de estos cuadraditos es codificado como una combinación de rojo (R), verde (G) y azul (B). De ahí que el número total de números necesario para codificar una imagen sea 154587 .

Con los textos pasa algo parecido, se construye un diccionario con todas las palabras de todos los textos de ejemplo, se eliminan de ese diccionario palabras que no aportan mucho a la semántica de la frase (stopwords) y se usa la presencia o ausencia de los términos del diccionario en cada texto para codificarlo.

Total, que en realidad, lo que los algoritmos de Machine Learning requieren son conjuntos numéricos. Sin embargo, hasta la versión 1.3, no teníamos la posibilidad de introducir directamente estos conjuntos numéricos en LearningML. Y esto resulta muy útil pues, en muchas ocasiones, los conjuntos de datos que tenemos son, simplemente, conjuntos de datos organizados tabularmente, como en una hoja de cálculo, en el que cada fila de números representa un ejemplar.

Uno de los conjuntos numéricos más característicos y conocidos en el mundo de la estadística y el Machine Learning es el iris dataset. Se trata de 150 ejemplares de flores Iris clasificadas en tres especies: Iris setosa, Iris virgínica e Iris versicolor.  Cada ejemplar se ha caracterizado usando 4 rasgos típicos de las flores: la longitud del sépalo, la anchura del sépalo, la longitud del pétalo y la anchura del pétalo.

Caracterización de un ejemplar mediante la medida de las longitudes y anchuras de sus pétalos y sépalos

Reproducimos aquí 6 de los 150 ejemplares del conjunto:

EjemplarRepresentación numérica del ejemplarRepresentación numérica de la clase
1[5.1, 3.5, 1.4, 0.2]Iris Virginica
2[4.9, 3.0 , 1.4, 0.2]Iris Virginica
3[5.5, 4.2, 1.4, 0.2]Iris Versicolor
4[4.9, 3.1, 1.5, 0.2]Iris Versicolor
5[6.2, 3.4, 5.4, 2.3]Iris Setosa
6[5.9, 3.0 , 5.1, 1.8, 2]Iris Setosa
6 ejemplos de los datos del iris dataset

Puedes descargarte el conjunto completo en formato CSV o en el formato JSON de LearningML (listo para ser cargado en la herramienta) desde los siguientes enlaces:

Iris dataset CSVIris dataset (JSON)

Y ahora vamos a construir con LearningML un modelo de ML con estos datos de ejemplo. El procedimiento es el mismo de siempre:

  1. Introducir los datos de ejemplo (entrenar).
  2. Construir el modelo a partir de los datos de ejemplo (aprender).
  3. Evaluar el modelo (probar).

La única diferencia es que en este caso hacemos clic en el botón “Reconocer números” de la pantalla de inicio.

En el caso de los conjuntos de números, antes de comenzar a introducir datos hay que indicar el número de atributos del conjunto de datos que deseamos procesar. Este valor, por defecto es 2, pero podemos cambiarlo usando la caja de texto “Número de columnas”. En el ejemplo que nos traemos entre mano dicho número es 4.

Ahora creamos las tres clases del problema: Iris Setosa, Iris Versicolor e Iris Virginica, y añadimos los datos numéricos correspondientes a cada clase. La manera de hacerlo es separando los números mediante comas (“,”), como se ve en la siguiente imagen.

Una vez que tenemos los datos de ejemplo, procedemos a construir el modelo de ML haciendo clic en “Aprender a reconocer números”.

Y, una vez finalizado el proceso de aprendizaje, procedemos a realizar algunas pruebas para ver si el modelo nos convence. De nuevo, la manera de introducir los números es separarlos mediante comas.

Por último, y al igual que con los otros tipos de datos (textos e imágenes), podemos construir un programa con Scratch que use el modelo construido para reconocer nuevos conjuntos numéricos que codifiquen nuevos ejemplares (de flores iris en este modelo).

La creación de modelos de reconocimiento de números abre nuevas posibilidades para el diseño de actividades de programación de aplicaciones con inteligencia artificial, y ayudará a trabajar los conceptos de ciencia de datos, big data e incluso IOT (internet de las cosas), pues usando sensores podemos recoger datos sobre distintos fenómenos, clasificarlos, crear un modelo y usarlo para predecir o clasificar nuevos datos recogidos con esos mismos sensores. De esta manera conectamos aún más intimamente las actividades de Inteligencia Artificial con las de robótica educativa. EchidnaSTEM y micro:bit son dos placas para la robótica educativas con las que puedes diseñar alguna actividad de este tipo. ¿Te animas a plantear alguna?