Archivo de la etiqueta: Machine Learning

Servicios IoT

Esta conferencia sobre IoT con Arduino fue expuesta el 1 de abril de 2017 con motivo del Arduino Day. Puedes ver el video de la conferencia completa en http://www.innovarioja.tv/index.php/video/ver/1661


Las plataformas mismas nos pueden ofrecer diferentes clases de servicios para los datos como visualización de datos, descargas, API para obtener los datos, alertas, etc…

Algunos servicios que podemos encontrar:

  • Almacenamiento de datos
  • Gestión de dispositivos
  • Visualización de datos (Visual Analytics)
  • Descarga de datos
  • API REST para interactuar con la plataforma
  • Notificaciones
  • Alertas/Alarmas
  • Reglas
  • SDK
  • Interacción con otras plataformas
  • Análisis de datos (Machine Learning)
  • Open data

Una plataforma nos puede permitir:

  • Automatizar informes de trabajo, cuadros de mando, etc… Los datos recogidos y guardados genera informes automáticamente de forma periódica o en tiempo real (por ejemplo de la producción) y son enviados.
  • Monitorización en Tiempo real de flotas o del estado de una planta
  • Avisos precoces para mantenimientos predictivos.
  • Control remoto de instalaciones.
  • Eficiencia energética.
  • Automatización de procesos.
  • Análisis de datos (data mining, etc…) para aprendizaje automático.
  • Business intelligence (detectar problemas comunes, medir cuellos de botella, etc…) y ayudar en el mantenimiento predictivo.
  • Integrar con el software corporativo. ERP, CRM, GMAO (Gestión del Mantenimiento Asistido por Ordenador), CMMS.

De Arduino al Procesado de Datos Masivo

Arduino es una herramienta perfecta para la recogida de todo tipo de datos en cualquier lugar y condición, comprobación, pre-procesado y normalización de los datos y finalmente transporte de esos datos de una forma rápida y segura al lugar donde se van a almacenar para posteriormente ser procesados y analizados.

Arduino es capaz de recoger datos, tratarlos en tiempo real (limitado por su capacidad de procesamiento) y comunicarse con el sistema de almacenamiento de datos.

Al ser Arduino un elemento barato y con muchas capacidades de comunicación es posible usarlo en la captura de datos distribuidos y desplegar tantos sensores como sea necesario creando una red de sensores fácilmente escalable.

Y obtener datos distribuidos para visualizarlos y analizarlos:

La adquisición de datos (DAQ) es el proceso de medir un fenómeno eléctrico o físico como voltaje, corriente, temperatura, presión o sonido. Un sistema DAQ consiste de sensores, hardware de medidas DAQ y un PC donde almacenar y tratar los datos. Comparados con los sistemas de medidas tradicionales, los sistemas DAQ basados en PC aprovechan la potencia del procesamiento, la productividad, la visualización y las habilidades de conectividad de los PCs estándares en la industria proporcionando una solución de medidas más potente, flexible y rentable.

Un sistema DAQ básico sería un Arduino que recoge los datos, los procesa y los guarda en una tarjeta SD o un PC conectado, pero con Arduino podemos ir más allá y crear una red de sistemas DAQ interconectados que procesan los datos que capturan y los mandan a una base de datos o repositorio único o distribuido.

Elementos que intervienen

A la hora de recoger datos para su procesamiento debemos responder estas preguntas:

  • ¿Qué quieres medir? – Sensores
  • ¿Cómo lo quieres conectar? – Comunicaciones /Protocolos
  • ¿Donde vas a almacenar los datos? – Plataformas
  • ¿Qué quieres hacer con los datos? – Herramientas de procesado

Todo esto está relacionado con el denominado Internet de las Cosas (IoT).

Elementos que intervienen:

  • Protocolos de comunicación, lenguaje para comunicar el HW y el SW. HTTP, fiware, MQTT, API REST,…

  • Plataformas Software, almacenar y tratar los datos recogidos por nuestros sensores. Pueden ser plataformas de terceros o plataformas propias desarrolladas por nosotros o simplemente guardar en BBDD. Por ejemplo: Carriots, Thingspeak, Temboo, Thinger, etc…
    Además todas estas plataformas SW que están en la nube, deben estar soportadas por un HW de servidores, unas BBDD de gran capacidad y una infraestructura segura que los hospede.
  • Servicios, son los servicios que ofrecen las plataformas como la visualización de los datos recogidos, análisis de los datos, envío de avisos cuando se detecte un evento, interconexión con otras plataformas, etc…
    Servicios ofrecidos por la plataforma carriots: https://www.carriots.com/que-es-carriots

A modo de resumen, estos son los elementos:

Sensor — MCU — Comunicación — Protocolo — Plataforma — Servicios

Uno de los retos del IoT es mandar datos de cualquier sensor a través de cualquier protocolo a cualquier plataforma de forma inalámbrica y usando la menor energía posible (baterías) y todo esto mediante una comunicación segura (cifrada).

Plataformas

Podemos usar de forma gratuita diversas plataformas para conectar nuestro Arduino con ellas y usarlas para mostrar datos, analizar los datos, responder a ciertos eventos, realizar interacciones con Arduino, etc…

Algunas ejemplos de plataformas son: