Itinerario Formación IoT/Industria 4.0

En un acercamiento a esta disciplina, se busca conocer las tecnologías necesarias para el desarrollo de soluciones IoT/Industria Conectada y valiéndonos para ello de herramientas, tecnologías, protocolos y software libre/open source que hay a nuestra disposición, de forma que cualquier empresa por pequeña que sea pueda hacer un proyecto sencillo de IoT/Industria 4.0 con una inversión mínima, sea cual sea el sector al que pertenezca.

No solo las grandes empresas pueden dar el salto a IoT, la tecnologías libres permiten que sea factible la digitalización de las pymes con una inversión económica mínima y que surja la innovación desde las propias empresas con una formación adecuada a sus trabajadores.

Fundamentos IoT (Nivel 1)20 h
Dispositivos HW IoT (Nivel 2)20 h
Infraestructuras IoT (Nivel 3)20 h
Conectividad IoT (Nivel 3)20 h
Plataformas IoT (Nivel 4)20 h
Desarrollo Soluciones IoT con Herramientas Libres (Nivel 5)20 h

Ver Anexo I con el material necesario para impartir los cursos de este itinerario.

Fundamentos IoT (Nivel 1)

Objetivo

Describir los fundamentos de Internet de las Cosas e identificar los distintos mercados a los que el alumno puede orientar su actividad profesional.

Dado que las comunicaciones, la conexión a Internet y los dispositivos conectados es un aspecto importante actualmente y los conceptos de computación y comunicaciones van unidos de la mano cuando hablamos de las TIC (Tecnologías de la Información y de la Comunicación), vamos a tratar también en este curso las comunicaciones y la programación de los dispositivos conectados.

Toda la documentación del curso y el código usado es libre y accesible desde https://www.aprendiendoarduino.com/.

Al finalizar el curso el alumno será capaz de:

  • Conocer qué es IoT
  • Reconocer las tecnologías y arquitecturas de IoT
  • Capas en IoT
  • Saber los retos de IoT
  • Importancia de la seguridad den IoT
  • Empresas en IoT
  • Conocer los mercados verticales de IoT
  • Saber los servicios que ofrece IoT

Requisitos Alumnos

No son necesarios requisitos previos de los alumnos para asistir a este curso

Contenido del Curso

  • Qué es el IoT. Visión Holística
  • Ecosistema IoT
  • Retos de IoT
  • Industria 4.0. IIoT
  • Empresas en IoT
  • Mercados Verticales IoT
  • Campos Profesionales IoT
  • Aplicaciones IoT

Dispositivos HW IoT (Nivel 2)

Objetivo

Visión general del HW en el ecosistema IoT y puesta en práctica. Identificar la solución Hardware y Firmware más correcta para un proyecto IoT.

Analizar el hardware y el firmware utilizado dentro el ecosistema IoT y programar algunas las plataformas de prototipado más populares del mercado

Toda la documentación del curso y el código usado es libre y accesible desde https://www.aprendiendoarduino.com/.

Al finalizar el curso el alumno será capaz de:

  • Conocer las plataformas HW IoT 
  • Conocer el firmware usado en las plataformas HW
  • Identificar la solución Hardware y Firmware más correcta para un proyecto IoT
  • Utilizar plataformas de prototipado IoT

Requisitos Alumnos

Haber cursado el módulo de Fundamentos IoT o tener experiencia en HW y Firmware IoT.

Contenido del Curso

  • Dispositivos IoT
  • HW IoT Industrial
  • Firmware: SW de los dispositivos
  • Plataforma de Prototipado
  • Prácticas Firmware
  • HW IoT Comercial

Infraestructuras de Comunicaciones IoT (Nivel 3)

Objetivo

Visión detallada de las infraestructuras y conectividad en IoT con ejemplos prácticos en algunas tecnologías. El alumno será capaz de analizar las necesidades de una solución IoT, ofrecer la mejor solución e implementarla. 

Utilizar las Infraestructuras de comunicación que se usan hoy en día para IoT

Toda la documentación del curso y el código usado es libre y accesible desde https://www.aprendiendoarduino.com/.

Al finalizar el curso el alumno será capaz de:

  • Conocer las diferentes infraestructuras de comunicaciones IoT disponibles en el mercado
  • Comparar las tecnologías inalámbricas y saber elegir la más adecuada dependiendo del proyecto.
  • Ofrecer e implantar soluciones IoT a nivel de conectividad e infraestructuras IoT a partir del análisis de necesidades del proyecto
  • Utilizar algunas de las comunicaciones con placas de prototipado como Arduino y ESP8266

Requisitos Alumnos

Haber cursado el módulo de Fundamentos IoT o tener experiencia en infraestructuras y conectividad IoT.

Contenido del Curso

  • Conectividad IoT
  • Redes Inalámbricas IoT
  • Infraestructura de Comunicación IoT
  • Prácticas de Comunicaciones IoT

Conectividad IoT (Nivel 3)

Objetivo

Visión detallada de las infraestructuras y conectividad en IoT con ejemplos prácticos en algunas tecnologías. El alumno será capaz de analizar las necesidades de una solución IoT, ofrecer la mejor solución e implementarla. 

Analizar los protocolos más populares para dotar de conectividad a los dispositivos IoT y configurar el software

Toda la documentación del curso y el código usado es libre y accesible desde https://www.aprendiendoarduino.com/.

Al finalizar el curso el alumno será capaz de:

  • Conocer los protocolos más populares usados en IoT
  • Profundizar en el protocolo HTTP y el uso de API REST
  • Profundizar en el protocolo MQTT y su uso en aplicaciones IoT
  • Instalar, configurar y usar un broker MQTT
  • Ofrecer e implantar soluciones IoT a nivel de conectividad e infraestructuras IoT a partir del análisis de necesidades del proyecto

Requisitos Alumnos

Haber cursado el módulo de Fundamentos IoT o tener experiencia en infraestructuras y conectividad IoT.

Contenido del Curso

  • Protocolos IoT
  • Protocolo HTTP
  • Uso de API REST
  • Protocolo MQTT
  • Práctica MQTT

Plataformas IoT (Nivel 4)

Objetivo

Visión general de las plataformas IoT y trabajo detallado en algunas de ellas. Proponer, instalar y configurar la plataforma más adecuada para el desarrollo de soluciones IoT.

Analizar las  las plataformas existentes en IoT e instalar y configurar alguna de las más utilizadas.

Toda la documentación del curso y el código usado es libre y accesible desde https://www.aprendiendoarduino.com/.

Al finalizar el curso el alumno será capaz de:

  • Conocer las plataformas IoT Generalistas y especializadas más usadas
  • Conocer plataformas open source, instalar y configurar en un servidor
  • Encontrar la plataforma adecuada para una solución IoT, instalación y configuración
  • Programar servicios usando Node-Red
  • Uso de Bases de Datos para almacenamiento de datos
  • Configuración y uso de Dashboards
  • Analizar datos de forma visual

Requisitos Alumnos

Haber cursado el módulo de Fundamentos IoT o tener experiencia en plataformas IoT.

Contenido del Curso

  • Plataformas Cloud Generalistas
  • Plataformas Cloud Especializadas
  • Práctica de Plataformas Cloud
  • Plataformas Privadas/Libres
  • Práctica Plataformas Privadas/Libres
  • Servicios IoT
  • Node-Red
  • Bases de Datos
  • Dashboards
  • Ejemplos prácticos IoT

Desarrollo Soluciones IoT con Herramientas Libres (Nivel 5)

Objetivo

Este curso pretende unificar todos los conocimiento adquiridos en los anteriores cursos del itinerario IoT para hacer un proyecto “full stack” de IoT.

Unificar los conocimientos adquiridos en los otros cursos, identificar necesidades reales con respuestas desde el IoT y desarrollar una solución específica para una necesidad.

Toda la documentación del curso y el código usado es libre y accesible desde https://www.aprendiendoarduino.com/.

Al finalizar el curso el alumno será capaz de:

  • Proponer e implementar soluciones IoT como respuesta a necesidades específicas
  • Desarrollar un proyecto IoT  estructurado según las fases relacionadas en cada módulo  que de respuesta a una necesidad real del entorno del alumno

Requisitos Alumnos

Los alumnos deberán haber cursado todos los cursos del itinerario IoT o tener experiencia en el desarrollo de soluciones IoT

Contenido del Curso

  • Repaso de conceptos
  • Ejemplo de soluciones IoT Completas
  • Identificación de necesidades
  • Presentación preliminar
  • Desarrollo del Proyecto
  • Presentación del Proyecto

Arduino y LoRaWAN

Arduino MKR WAN 1300

MKR WAN 1300 es una placa potente que combina la funcionalidad de la conectividad MKR Zero y LoRa. Es la solución ideal para los fabricantes que desean diseñar proyectos de IoT con una mínima experiencia previa en redes que tengan un dispositivo de baja potencia.

La placa MKR WAN 1300 tiene comunicación inalámbrica unido a un diseño de la placa MKR Zero Board, es decir, que tendremos soporte para aplicaciones de 32 bits. La placa cuenta con 256KB de Memoria flash y 32KB SRAM. Puede funcionar con la energía de dos pilas de 1,5V y todo en un tamaño de 67,64 x 25mm. Al tener comunicación inalámbrica, el dispositivo al que se conecte tendrá opción de comunicarse a Internet.

El MKR WAN 1300 usar el módulo Murata CMWX1ZZABZ Lo-Ra module que lleva el transceiver Semtech SX1276:

Más información: https://store.arduino.cc/mkr-wan-1300

Buen artículo para sobre el MKR 1300: http://tinkerman.cat/arduino-mkr-wan-1300/

Moteino

Moteino es una plataforma de desarrollo compatible con Arduino inalámbrica de baja potencia basada en el popular chip ATmega328p utilizado en el Arduino-UNO, lo que lo hace 100% compatible con el IDE de Arduino (entorno de programación).

Para la programación, necesitará un adaptador FTDI externo para cargar los sketchs, con las ventajas de un menor costo y un tamaño más pequeño. La variante MoteinoUSB incluye el convertidor de serie USB.

Los Moteinos son compatibles y se pueden comunicar con cualquier otra plataforma Arduino o de desarrollo que utilice los populares transceptores HopeRF RFM69 o LoRa. Moteino también viene con un chip de memoria flash SPI opcional para programación inalámbrica o registro de datos.

Web Moteino: https://lowpowerlab.com/guide/moteino/

Moteino fue diseñado para ser una plataforma de desarrollo compacta, altamente personalizable y asequible, adecuada para IoT, domótica y proyectos inalámbricos de largo alcance. Estas son algunas de las características que distinguen a Moteino:

  • diseño modular pequeño y ligero que se adapta a recintos minúsculos
  • las configuraciones flexibles permiten el uso de varios transceptores inalámbricos
  • potencia realmente ultra baja: con tan solo ~ 2uA alcanzables en el modo de suspensión profunda, los Moteinos permiten que los proyectos con batería, como los sensores inalámbricos de movimiento/entorno, funcionen durante años. El modo de suspensión de Watchdog está en ~ 6uA (activación periódica). El nuevo 8Mhz Moteino permite el modo de sueño 100nA más bajo posible
  • Las radios sub-Ghz y LoRa producen un rango mucho más largo que las bandas de 2.4Ghz
  • programable de forma inalámbrica: puede volver a flashearlo sin cables, cuando se implementa en ubicaciones difíciles (solo con radios RFM69)
  • fácil de usar desde el familiar IDE Arduino, muchos ejemplos de código brindados para ayudarlo a comenzar

Pinout:

Los transceiver soportados por Moteino son:

Transceiver Datasheets

Muy buena explicación de los módulos de Adafruit: https://learn.adafruit.com/adafruit-rfm69hcw-and-rfm96-rfm95-rfm98-lora-packet-padio-breakouts/overview

Librería para los módulos RFM69: https://github.com/LowPowerLab/RFM69

IMPORTANTE: Los módulos RFM69 no son LoRa y no son compatibles con los módulos RFM95/RFM96. Además los módulos RFM95/RFM96 necesitan de una librería de terceros.

Más información RFM69:

Uso con Lora: https://lowpowerlab.com/guide/moteino/lora-support/

Librería para los módulos LoRa RFM95 (868-915mhz) and RFM96 (433mhz).: http://www.airspayce.com/mikem/arduino/RadioHead/index.html

Getting started para instalar el soporte y las librerías: https://lowpowerlab.com/guide/moteino/programming-libraries/

Github: https://github.com/LowPowerLab y Librería: https://github.com/LowPowerLab/Moteino

Comprar Moteino:https://lowpowerlab.com/shop/

Moteino weather shield: https://lowpowerlab.com/2016/09/09/weathershield-r2-released/ with a BME280 which includes all Temperature/Humidity/Pressure readings all in 1 sensor.

Moteino PowerShield: https://lowpowerlab.com/guide/powershield/

Gateway LoRa con Moteino + Raspberry Pi:

Dragino

En Dragino http://www.dragino.com/ podemos encontrar Hardware para LoRa: http://www.dragino.com/products/products-list.html

Wiki: http://wiki.dragino.com/index.php?title=Main_Page

La librería recomendada es: https://github.com/matthijskooijman/arduino-lmic, pero puede usarse la librería Radiohead: http://www.airspayce.com/mikem/arduino/RadioHead/

LoRa Shield:

Otro HW LoRa compatible con Arduino

Existen más HW de desarrollo compatible con Arduino con módulos LoRa diferentes:

Gateways LoRa

En las redes LoRaWan un gateway es un dispositivo dentro de la arquitectura de red que recibe los datos transmitidos por un dispositivo de nodo final y que reenvían los paquetes de datos a un servidor de red centralizado. Los datos de un nodo final LoRa pueden ser recibidos por múltiples puertas de enlace (gateway),

Los gateways o puertas de enlace son un puente transparente entre los dispositivos finales y el servidor de red central. Uno o más dispositivos finales se conectan a una o más puertas de enlace, mediante una conexión inalámbrica de un solo salto, usando tecnología RF LoRa™ o FSK, formando así una red en estrella.

Una o más puertas de enlace se conectan al servidor de red central por medio de conexiones IP estándar, formando así una red en estrella. Las comunicaciones entre los dispositivos y el servidor de red, son generalmente unidireccionales o bidireccionales, pero el estándar también soporta multidifusión, permitiendo la actualización de software en forma inalámbrica, u otras formas de distribución de mensajes en masa.

Los gateways son enrutadores equipados con un concentrador LoRa, lo que les permite recibir paquetes LoRa. Por lo general, puede encontrar dos tipos de puertas de enlace:

  • Las pasarelas se ejecutan con un firmware mínimo, por lo que son de bajo costo y fáciles de usar (por ejemplo, The Things Gateway) y solo ejecutan el software de reenvío de paquetes.
  • Gateways que ejecutan un sistema operativo, para el cual el software de reenvío de paquetes se ejecuta como un programa de fondo (por ejemplo, Kerlink IoT Station, Multitech Conduit). Esto le da más libertad al administrador del gateway para administrar su puerta de enlace e instalar su propio software.

Una forma de montar un gateway LoRa barato es con una Raspberry Pi y un hat de Moteino con un módulo LoRa:

Un gateway simple con LoPy: https://www.hackster.io/bucknalla/lopy-lorawan-nano-gateway-using-micropython-and-ttn-a9fb19

Construir un gateway LoRa barato: http://cpham.perso.univ-pau.fr/LORA/RPIgateway.html

Módulos LoRa para conectar un ordenador y haga de gateway: https://www.cooking-hacks.com/waspmote-gateway-sx1272-lora-sma-4-5-dbi-868-mhz y tutorial LoRa gateway Libelium: http://www.libelium.com/development/waspmote/documentation/lora-gateway-tutorial/

Lista de gateways de loriot: https://www.loriot.io/lora-gateways.html

The things gateway: https://www.thethingsnetwork.org/docs/gateways/gateway/

The Things Gateway permite que dispositivos como sensores y computadoras integradas se conecten a internet. Con un proceso fácil de conectar, está creando el aspecto más sustancial de su red de datos IoT. Active la puerta de enlace en solo 5 minutos y cree su propia red local. Con la capacidad de servir a miles de nodos, la puerta de enlace es el componente principal de su red conectada. Esta versión funciona a 868MHz para uso en la UE y 915Mhz para uso en los EE.UU.

Lista de gateways de thethingsnetwork:

Gateway draguino (open wrt): http://www.dragino.com/products/lora/item/119-lg01-s.html

Ejemplo con Dragino para usarlo como gateway (Lora Shield + Arduino Yun Shield):

Más información:

Librería RadioHead LoRa

Una de las librerías más usadas para módulos LoRa con Arduino es RadioHead: http://www.airspayce.com/mikem/arduino/RadioHead/index.html

Proporciona una biblioteca completa orientada a objetos para enviar y recibir mensajes paquetizados a través de una variedad de radios de datos comunes y otros transportes para microprocesadores integrados.

RadioHead consta de 2 grupos principales de clases: driversy managers.

  • Los drivers proporcionan acceso de bajo nivel a un rango de diferentes radios y otros transportes de mensajes paquetizados.
  • Los managers brindan servicios de envío y recepción de mensajes de alto nivel para una variedad de requisitos diferentes.

Cada programa de RadioHead tendrá una instancia de un driver para proporcionar acceso a la radio o transporte de datos, y generalmente un manager que usa ese driver para enviar y recibir mensajes para la aplicación. El programador debe instanciar un driver y un manager e inicializar el manager. A partir de entonces, las funciones del manager se pueden usar para enviar y recibir mensajes.

También es posible usar un driver por sí mismo, sin un manager, aunque esto solo permite un transporte no confiable y sin dirección a través de las funciones del driver.

Se admite una amplia gama de plataformas de microprocesadores.

Unos ejemplos de drivers:

  • RH_RF69 Works with Hope-RF RF69B based radio modules, such as the RFM69 module
  • RH_NRF24 Works with Nordic nRF24 based 2.4GHz radio modules, such as nRF24L01 and others.
  • RH_RF95 Works with Semtech SX1276/77/78/79, Modtronix inAir4 and inAir9, and HopeRF RFM95/96/97/98 and other similar LoRa capable radios. Supports Long Range (LoRa) with spread spectrum frequency hopping, large payloads etc.
  • RH_Serial Works with RS232, RS422, RS485, RS488 and other point-to-point and multidropped serial connections, or with TTL serial UARTs such as those on Arduino and many other processors, or with data radios with a serial port interface. RH_Serial provides packetization and error detection over any hardware or virtual serial connection. Also builds and runs on Linux and OSX.
  • RHEncryptedDriver Adds encryption and decryption to any RadioHead transport driver, using any encrpytion cipher supported by ArduinoLibs Cryptogrphic Library http://rweather.github.io/arduinolibs/crypto.html

Managers, cualquier manager puede usarse con cualquier driver:

  • RHDatagram Addressed, unreliable variable length messages, with optional broadcast facilities.
  • RHReliableDatagram Addressed, reliable, retransmitted, acknowledged variable length messages.
  • RHRouter Multi-hop delivery of RHReliableDatagrams from source node to destination node via 0 or more intermediate nodes, with manual routing.
  • RHMesh Multi-hop delivery of RHReliableDatagrams with automatic route discovery and rediscovery.

Esta librería es compatible entre otros con:

Para los módulos con moteino que se ha usado en la demo, son necesarios los drivers: http://www.airspayce.com/mikem/arduino/RadioHead/classRH__RF95.html

Si se quiere añadir una capa de seguridad debe usarse la clase: http://www.airspayce.com/mikem/arduino/RadioHead/classRHEncryptedDriver.html

Si se quiere usar direccionamiento debe usarse la clase: http://www.airspayce.com/mikem/arduino/RadioHead/classRHDatagram.html

IMPORTANTE PARA MODULOS LORA, la librería está configurada por defecto a 434: Check if you have set the right frequency:After putting the library in the right place, you have to also modify the frequency to the frequency you want to use, the position of this issetFrequency() in the file: arduino-xxx\libraries\RadioHead\RH_RF95.cpp;

Para los módulos RFM95 de moteino debe ponerse: setFrequency(868.0);

He hecho un fork de la librería con la modificación para módulos LoRa: https://github.com/jecrespo/RadioHead

Proyecto LoRa con Moteino

A la hora de afrontar un proyecto con LoRa para monitorizar un entorno donde no tenemos acceso a una red ethernet/wifi ni toma eléctrica, podemos planteamos usar Moteino como una solución basada en Arduino de bajo consumo y con módulos LoRa integrados.

La primera duda es que módulo de radio o transceiver usar el RFM69 o RFM95:

  • RFM69 no es LoRa usa modulación FSK en lugar de la modulación LoRa
  • RFM95 es LoRa estándar.

RFM69 y RFM95 son módulos de radio para comunicación a larga distancia, donde la velocidad de transmisión no es crítica (no se hace streaming de vídeo). Al usar modulación diferente no son compatibles entre ellos.

Estos módulos de radio vienen en cuatro variantes (dos tipos de modulación y dos frecuencias). Los RFM69 son los más fáciles de usar, y son bien conocidos y entendidos. Las radios LoRa son más potentes, pero también más caros.

Comparativa y explicación de los módulos: https://learn.adafruit.com/adafruit-rfm69hcw-and-rfm96-rfm95-rfm98-lora-packet-padio-breakouts

Transceiver Moteino: https://lowpowerlab.com/guide/moteino/transceivers/

RFM69

Módulo basado en SX1231 con interfaz SPI

  • +13 a +20 dBm hasta 100 mW Capacidad de salida de potencia (salida de potencia seleccionable en software)
  • Drenaje de corriente de 50 mA (+13 dBm) a 150 mA (+20 dBm) para transmisiones, ~ 30 mA durante la escucha de radio activa.
  • Las radios RFM69 tienen un alcance de aprox. Línea de visión de 500 metros con antenas unidireccionales sintonizadas. Dependiendo de las obstrucciones, la frecuencia, la antena y la potencia de salida, obtendrá rangos más bajos, especialmente si no tiene línea de visión.
  • Crear redes multipunto con direcciones de nodo individuales
  • Motor de paquete cifrado con AES-128

Guía completa del módulo de radio RFM69: https://learn.sparkfun.com/tutorials/rfm69hcw-hookup-guide

Librería Arduino RFM69: https://github.com/LowPowerLab/RFM69

Completa información RFM69: http://www.hoperf.com/upload/rf/RFM69W-V1.3.pdf

Explicación de librería RFM69 https://lowpowerlab.com/2013/06/20/rfm69-library/

RFM95

Módulo basado en LoRa® SX1276 con interfaz SPI

  • Capacidad de salida de potencia de +5 a +20 dBm hasta 100 mW (salida de potencia seleccionable en software)
  • ~ 100mA de pico durante la transmisión de + 20dBm, ~ 30mA durante la escucha activa de la radio.
  • Las radios RFM9x tienen un rango de aprox. Línea de visión de 2 km con antenas unidireccionales sintonizadas. Dependiendo de las obstrucciones, la frecuencia, la antena y la potencia de salida, obtendrá rangos más bajos, especialmente si no tiene línea de visión.

Estos son radios de paquete LoRa de +20 dBm que tienen una modulación de radio especial que no es compatible con los RFM69 pero que puede ir mucho más lejos. Pueden ir fácilmente a la línea de vista de 2 km utilizando antenas de cable simples, o hasta 20 km con antenas direccionales y ajustes.

Completa información RFM95: http://www.hoperf.com/upload/rf/RFM95_96_97_98W.pdf

Librería: http://www.airspayce.com/mikem/arduino/RadioHead/

SX127x Datasheet – The RFM9X LoRa radio chip itself

Librería: http://www.airspayce.com/mikem/arduino/RadioHead/

Módulos Moteino Usados

Optamos LoRa porque da entre un 50% y 100% más de alcance.

LoRa support for Moteino: https://lowpowerlab.com/guide/moteino/lora-support/

Todo sobre moteino y como programarlo: https://lowpowerlab.com/guide/moteino/

Los moteino a usar con LoRa son los moteinoLR y mejor moteinoUSB-LoRa que ya tiene el interfaz USB:

Para wireless programming necesitas las flash extra: https://lowpowerlab.com/guide/moteino/wireless-programming/

Gateway

Si queremos conectar a Internet los sensores, necesitamos un gateway.

Gateway con Raspberry Pi:

Otra opción de gateway es usar un shield LoRa de dragino:

Productos de dragino: http://www.dragino.com/products/products-list.html

Cloud

Ya tenemos el nodo y el gateway, nos falta el cloud que podemos hacerlo con muchas plataformas IoT.

Thingspeak: https://thingspeak.com/

Demo LoRa con Moteino

Medición de temperatura remota de forma inalámbrica usando LoRa con un MoteinUSB with flash https://lowpowerlab.com/guide/moteino/. Integración de los datos en un servidor propio https://www.aprendiendoarduino.com/ y en thingspeak https://thingspeak.com/. Se usa un gateway sencillo de reenvio de mensajes usando un Arduino Yun conectado por WiFi a Internet y un shield LoRa http://www.dragino.com/products/lora/item/102-lora-shield.html

Hardware Utilizado en el módulo LoRa

Hardware utilizado en el gateway:

Esta demo consiste en un cliente basado en un moteino alimentado por batería que manda datos de temperatura de una sonda DHT22 a un nodo central que hace de gateway basado en un Arduino Yun con un shield Lora de Draguino.

Cliente

Para empezar con Moteino, lo primero es instalar el soporte para estas tarjetas e instalar las librerías: https://lowpowerlab.com/guide/moteino/programming-libraries/

Luego la guía de programación con el IDE de Arduino: https://lowpowerlab.com/guide/moteino-programming/arduinoide/

Para LoRa usamos el módulo RFM95: https://lowpowerlab.com/guide/moteino/transceivers/ y necesitaremos la librería recomendada que soporta LoRa: https://lowpowerlab.com/guide/moteino/lora-support/. Para estos módulos la librería recomendada es: http://www.airspayce.com/mikem/arduino/RadioHead/index.html, la descargamos e instalamos.

Tomando como base el ejemplo rf95_client de la librería Radiohead modificado para mandar la temperatura de una sonda DHT22 que es un dato de tipo float, en lugar de “Hello World”.

El código del cliente está disponible en: https://github.com/jecrespo/aprendiendoarduino-lora/blob/master/Demo_LoRa/rf95_client/rf95_client.ino

Servidor/Gateway

Se usa un Arduino Yun https://store.arduino.cc/arduino-yun que dispone de conexión ethernet y wifi y para la red LoRa uso un LoRa shield de draguino http://www.dragino.com/products/module/item/102-lora-shield.html

Más información sobre el shield ver este documento: http://wiki.dragino.com/index.php?title=Lora_Shield

Para este shield uso la misma librería: http://www.airspayce.com/mikem/arduino/RadioHead/index.html,

Tomando como base el ejemplo rf95_server de la librería Radiohead modificado para recibir un float y sacarlo por el puerto de consola.

IMPORTANTE: en el ejemplo de rf95_server no usar el pin 9 para el led (int led = 9;) porque el pin 9 se usa como reset en el shield de draguino.

Una vez comprobado que el servidor recibe datos, debe hacer su función de gateway y mandar los datos a una base de datos alojada en https://www.aprendiendoarduino.com/ y poder ver la gráfica en https://www.aprendiendoarduino.com/servicios/datos/graficas.html

Para grabar datos se debe llamar a una API desde el arduino Yun. Uso el HTTP client para mandar datos https://www.arduino.cc/en/Tutorial/HttpClient. De esta forma hace el Arduino Yun + Shield LoRa de Gateway reenviando los datos recibidos por LoRa a un servidor público.

El código del servidor está en https://github.com/jecrespo/aprendiendoarduino-lora/blob/master/Demo_LoRa/rf95_server/rf95_server.ino

Dispositivos Sigfox y Lora recogiendo datos en campo:

Para mandar los datos a thingspeak uso la API y mando los datos llamando a https://api.thingspeak.com/update?api_key=writeapikey&field1=22.8

Está disponible una vista publica de los datos: https://thingspeak.com/channels/440179

Redes LPWAN

Una red de área amplia de baja potencia (LPWAN – Low-Power Wide-Area Network) o red de baja potencia (LPWA – Low-Power Wide-Area) o red de baja potencia (LPN – Low-Power Network) es un tipo de red de área amplia de telecomunicaciones inalámbricas diseñada para permitir comunicaciones de largo alcance a una velocidad de bits baja entre objetos conectados, como sensores operados con una batería. La baja potencia, la baja velocidad de bits y el uso previsto distinguen este tipo de red de una WAN inalámbrica en que la WAN está diseñada para conectar usuarios o empresas, y transportar más datos, utilizando más potencia. La tasa de datos LPWAN varía de 0,3 kbit/s a 50 kbit/s por canal.

Las redes LPWAN trabajan en la banda ISM libres sin necesidad de licencia.

Redes LPWAN: https://en.wikipedia.org/wiki/LPWAN

Banda ISM

ISM (Industrial, Scientific and Medical) son bandas reservadas internacionalmente para uso no comercial de radiofrecuencia electromagnética en áreas industrial, científica y médica. En la actualidad estas bandas han sido popularizadas por su uso en comunicaciones WLAN (e.g. Wi-Fi) o WPAN (e.g. Bluetooth).

El uso de estas bandas de frecuencia está abierto a todo el mundo sin necesidad de licencia, respetando las regulaciones que limitan los niveles de potencia transmitida. Este hecho fuerza a que este tipo de comunicaciones tengan cierta tolerancia frente a errores y que utilicen mecanismos de protección contra interferencias, como técnicas de ensanchado de espectro

Espectro electromagnético:

Más información:

Bandas ISM:

Frecuencias de LoRa:

En Europa, la banda de 863 a 870 MHz ha sido asignada para operación sin licencia usando FHSS, DSSS o modulación analógica con un ciclo de transmisión de 0.1%, 1% o 10% dependiendo de la banda, o Listen Before Talk (LBT) con Adaptive Frequency Agility (AFA). Aunque esta banda pertenece al rango de dispositivos de corto alcance, se está utilizando en redes de telecomunicaciones inalámbricas de red de área extensa de baja potencia (LPWAN), diseñadas para permitir comunicaciones de largo alcance a una velocidad de bits baja entre objetos (objetos conectados).

Dentro de las bandas libres existen varias posibilidades:

  • Banda 2,4 GHz usando WiFi, Bluetooth o Zigbee.
  • Banda 5 GHz usado WiFi
  • Banda de 868 MHz con opción de usar Zigbee, LoRa o Sigfox
  • Banda de 434 MHz.
  • Frecuencias RFID (13,56 MHz, 125 kHz, etc).

El standard de 868 MHz porque ofrece unas características superiores en cuanto al alcance (es 2 o 3 veces mayor que los standards mencionados anteriormente en la banda de 2,4 GHz). El coste de la implementación es relativamente bajo. El consumo de energía es bajo.

La versión de 868 MHz no está disponible en todo el mundo. En los EEUU se requiere una banda de 915 MHz. El hardware para ambos standards es idéntico sin embargo requieren versiones de software distintas.

La banda de 433 MHz es ligeramente mejor respecto al alcance pero no garantiza una transmisión segura de los datos. Debido a que muchos dispositivos trabajan en esta banda, especialmente controles remotos, es frecuente que se produzcan perturbaciones en la transmisión.

868 vs 433: http://www.hkvstar.com/technology-news/433mhz-or-868mhz-wireless-alarm-system-what-s-the-difference.html

Las frecuencias RFID no sirven para medidas de temperatura ya que presentan un alcance muy reducido. Estas frecuencias se suelen utilizar en etiquetas pasivas donde el alcance está limitado a menos de un metro.

LoRa es una modulación patentada dentro de la banda ISM de 868 MHz.

La radio sub-GHz no está diseñada para transmitir audio o video. Se usa mejor para pequeños paquetes de datos. La velocidad de datos es ajustable, pero es común mantener alrededor de 19.2 Kbps. Las velocidades de datos más bajas tendrán más éxito en sus transmisiones.

LPWAN

Una red de área amplia de baja potencia (LPWAN – Low-Power Wide-Area Network) o red de baja potencia (LPWA – Low-Power Wide-Area) o red de baja potencia (LPN – Low-Power Network) es un tipo de red de área amplia de telecomunicaciones inalámbricas diseñada para permitir comunicaciones de largo alcance a una velocidad de bits baja entre objetos conectados, como sensores operados con una batería. La baja potencia, la baja velocidad de bits y el uso previsto distinguen este tipo de red de una WAN inalámbrica en que la WAN está diseñada para conectar usuarios o empresas, y transportar más datos, utilizando más potencia. La tasa de datos LPWAN varía de 0,3 kbit/s a 50 kbit/s por canal.

Una LPWAN se puede usar para crear una red privada de sensores inalámbricos, pero también puede ser un servicio o infraestructura ofrecida por un tercero, lo que permite a los propietarios de sensores implementarlos en el campo sin invertir en tecnología ni infraestructura.

Redes LPWAN: https://en.wikipedia.org/wiki/LPWAN

Hay una serie de estándares y proveedores que compiten en el espacio LPWAN, el más destacado de los cuales incluye:

  • LoRa: LoRa es una tecnología patentada de modulación de radio de espectro expandido (CSS) para LPWAN utilizada por LoRaWAN, Haystack Technologies y Symphony Link.
  • LoRaWan: LoRaWAN es un protocolo de capa de control de acceso a medios para gestionar la comunicación entre las pasarelas LPWAN y los dispositivos de nodo final, mantenidos por LoRa Alliance.
  • Ultra Narrow Band (UNB): UNB, Ultra Narrow Band, tecnología de modulación utilizada por LPWAN por varias compañías entre ellas Sigfox
  • Otros: DASH7, MySensors, NarrowBand IoT (NB-IoT), etc…

Comparativa LPWAN:

Mercado LPWAN:

El ecosistema LPWAN comprende proveedores como Semtech Corporation (EE. UU.), LORIOT (Suiza), NWave Technologies (Reino Unido), SIGFOX (Francia), WAVIoT (Texas, EE. UU.), Actility (Francia), Ingenu (San Diego, EE. UU.) , Link Labs (Maryland, EE. UU.), Weightless SIG, y Senet, Inc. (Portsmouth, Reino Unido), ResIOT (Italia) y otros como proveedores de servicios y empresas. Otras partes interesadas en el mercado de redes LPWAN incluyen operadores de telecomunicaciones como Vodafone (U.K.) y Orange (Francia), entre otros, que integran estos dispositivos inteligentes y los venden a los usuarios finales para satisfacer sus requisitos comerciales únicos.

Más información LPWAN (área extensa de baja energía):

LoRaWAN

LoRaWAN es una especificación para redes de baja potencia y área amplia, LPWAN (en inglés, Low Power Wide Area Network) propuesta por la LoRa Alliance, diseñada específicamente para dispositivos de bajo consumo de alimentación, que operan en redes de alcance local, regional, nacionales o globales. La especificación cubre las capas PHY y MAC de la red, dejando a las aplicaciones el resto de capas. En la banda ISM de 868MHz (915 MHz en otras regiones), con un bitrate de hasta decenas de kbps (de 0.3 kbps hasta  50 kbps).

El estándar de red LoRaWAN apunta a requerimientos característicos de Internet de las Cosas, tales como conexiones bidireccionales seguras, bajo consumo de energía, largo alcance de comunicación, bajas velocidades de datos, baja frecuencia de transmisión, movilidad y servicios de localización. Permite la interconexión entre objetos inteligentes sin la necesidad de instalaciones locales complejas, y además otorga amplia libertad de uso al usuario final, al desarrollador y a las empresas que quieran instalar su propia red para Internet de las Cosas.

La red LoRaWAN (Long Range) es interesante por:

  • Consume tan poco que permite que los dispositivos puedan funcionar años con batería. Para conseguir esto se activa de forma periódica.
  • Tiene un gran alcance que permite llegar a los equipos de difícil acceso (garajes, sótanos, montañas)
  • Ser una red bidireccional
  • Velocidades de datos desde 0.3 kbps a 50 kbps
  • LoRa es una tecnología de comunicación muy interesante en el ámbito IoT.

Elementos en una red LoRa:

  • Dispositivo LoRa
  • Gateway o Pasarela
  • Red IP pública – Cloud
  • Servicios

La arquitectura de red típica, es una red de Redes en Estrella, de forma que la primera estrella está formada por los dispositivos finales y las puertas de enlace, y la segunda estrella está formada por las puertas de enlace y un servidor de red central. En este caso las puertas de enlaces son un puente transparente entre los dispositivos finales y el servidor de red central. Uno o más dispositivos finales se conectan a una o más puertas de enlace, mediante una conexión inalámbrica de un solo salto, usando tecnología RF LoRa™ o FSK, formando así una red en estrella.

Una o más puertas de enlace se conectan al servidor de red central por medio de conexiones IP estándar, formando así una red en estrella. Las comunicaciones entre los dispositivos y el servidor de red, son generalmente unidireccionales o bidireccionales, pero el estándar también soporta multidifusión, permitiendo la actualización de software en forma inalámbrica, u otras formas de distribución de mensajes en masa.

La comunicación entre dispositivos finales y las puertas de enlace se hacen en diferentes canales de frecuencias y a distintas velocidades de datos. La selección de la velocidad de datos es un compromiso entre la distancia de alcance, y la duración y consumo de energía del mensaje.

Las velocidades de datos se encuentran en el rango de 0.3 kbps a 50 kbps. Para maximizar en forma conjunta la duración de la batería de los dispositivos finales y la capacidad de la red, el servidor central LoRaWAN maneja la velocidad de datos para cada dispositivo en forma individual, por medio de un esquema adaptativo de velocidad de datos (o ADR, adaptive data rate en inglés).

Más información: https://es.wikipedia.org/wiki/LoRaWAN

LoRaWAN es un protocolo de capa de control de acceso a medios para gestionar la comunicación entre las pasarelas LPWAN y los dispositivos de nodo final, mantenidos por LoRa Alliance.

LoRaWAN define el protocolo de comunicación y la arquitectura del sistema para la red, mientras que la capa física LoRa habilita el enlace de comunicación de largo alcance. LoRaWAN también es responsable de gestionar las frecuencias de comunicación, velocidad de datos y potencia para todos los dispositivos. Los dispositivos en la red son asincrónicos y transmiten cuando tienen datos disponibles para enviar. Los datos transmitidos por un dispositivo de nodo final son recibidos por múltiples puertas de enlace (gateway), que reenvían los paquetes de datos a un servidor de red centralizado. El servidor de red filtra paquetes duplicados, realiza comprobaciones de seguridad y administra la red. Los datos se envían a los servidores de aplicaciones.

Las principales características de LoRaWAN son:

  • Topología estrella
  • Alcance de 10 a 15km en línea de vista
  • Encriptación AES 128
  • Soporte para 3 clases de nodos
  • Administración de dispositivos
  • Redes públicas y privadas
  • Bajo consumo y largo alcance
  • Baja transferencia de datos (hasta 242 bytes)

Algunas plataformas basadas en LoRaWAN incluyen:

  • Globalsat, both a public LoRaWAN and private LoRa Nodes solution provider for WW, include Europe, US, Asia region and Japan market
  • ThingsConnected, a free platform provided by the UK Digital Catapult
  • iFrogLab, public LoRaWAN and LoRa provider for North America and Taiwan
  • IoT-X, platform from Stream Technologies for public and private networks
  • ResIOT.io, platform for private, public networks and IoT projects
  • OpenChirp, open management layer on top of LoRaWAN, developed at Carnegie Mellon University, for data context, storage, visualization, and access control.The primary objective is to simplify the experience of adding and operating new devices in the network, as well as improving performance for communities that share bandwidth and locality.
  • The Things Network, a free and open-source LoRaWAN network provider developed and supported by a worldwide community. https://www.thethingsnetwork.org/
  • Everynet, provides a platform and gateways for Lora use in the Americas, Europe, China.
  • ThingPark Wireless, platform from Actility based on LoRaWAN
  • Senet, public LoRaWAN provider in North America
  • Un operador de LoRaWAN que ofrece gateways y un plataforma cloud es LORIOT: https://www.loriot.io/

Redes LoRaWan en Korea y Holanda: https://www.rcrwireless.com/20160704/carriers/operators-korea-netherlands-deploy-lora-networks-iot-tag23

Lora Alliance:

The things network (TTN)

The Things Network está construyendo una red para el Internet de las cosas mediante la creación de abundante conectividad de datos. La tecnología utilizada es LoRaWAN y permite que las cosas hablen a Internet sin 3G o WiFi. No hay códigos WiFi ni suscripciones a dispositivos móviles. Presenta bajo consumo de batería, largo alcance y bajo ancho de banda. Perfecto para Internet de las cosas.

The Things Network (TTN) es una iniciativa basada en la comunidad para establecer una red global de IoT. La iniciativa fue lanzada por Wienke Giezeman en 2015 y actualmente cubre más de 3.000 pasarelas LoRaWAN instaladas en más de 90 países. Los voluntarios se encargan de la construcción, el cuidado y el pago de los portales.

En Amsterdam, ha sido posible cubrir gran parte del área urbana en solo unas pocas semanas. Los Países Bajos ya están ampliamente abastecidos con TTN. Lo mismo se aplica a Zurich, Berna y Berlín. En Berlín, se necesitaron solo nueve meses para brindar acceso a LoRaWAN a aproximadamente 3,500,000 personas.

Más de 30,000 voluntarios de todo el mundo participan ahora en la creación del “Internet de las cosas” (IoT) en red más grande del mundo.

Más información:

Interesante artículo sobre el uso de TTN con MQTT:  https://sandervandevelde.wordpress.com/2016/07/09/access-the-things-network-telemetry-using-c-m2mqtt/

Web: https://www.thethingsnetwork.org/

The things gateway: https://www.thethingsnetwork.org/docs/gateways/gateway/

Lista de gateways de thethingsnetwork:

Productos de the things network: https://www.element14.com/community/docs/DOC-83471

Wiki: https://www.thethingsnetwork.org/wiki/Hardware/Gateways/Home

Más información:

LoRa

LoRa es un nuevo esquema de modulación para radios de baja potencia. Está patentado, por lo que hay algo de información disponible. Pero también es propietario, lo que significa que necesita una licencia para producir un chip de radio que use la codificación. LoRa se comercializa como una red de área amplia para Internet de las cosas.

LoRa es una tecnología patentada (EP2763321 de 2013 y US7791415 de 2008) desarrollada por Cycleo (Grenoble, Francia) y adquirida por Semtech en 2012. LoRa utiliza bandas de frecuencia de radio subgigahertz sin licencia como 169 MHz, 433 MHz, 868 MHz (Europa) y 915 MHz (América del Norte).

El formato de modulación de LoRa puede ser generado por piezas Semtech LoRa, incluidos los chips transceptores SX1272 y SX1276. Es una forma económica y eficiente de obtener ganancia de procesamiento en un pequeño transceptor a escala de chip. Funciona con una familia de chips de estación base altamente integrados (SX1301 y SX1257) con alta capacidad, por lo que puede usarla para construir redes punto a multipunto bastante sofisticadas. Más información en https://www.link-labs.com/blog/what-is-lora

La tecnología LoRa de Semtech ofrece características excepcionales como alta sensibilidad de recepción y modulación de espectro ensanchado que permite a estas radios aumentar drásticamente el rango a bajas tasas de bits, mientras sigue funcionando con una potencia de salida de batería (20dBm / 100mW) y modo de reposo de potencia ultrabaja. Estas radios también son compatibles con las modulaciones FSK, pero están destinadas a ser utilizadas con la tecnología de modulación LoRa (Long Range).

Transceivers de LoRa: https://www.semtech.com/products/wireless-rf/lora-transceivers

LoRa es el tipo de modulación en radiofrecuencia patentado por Semtech y que entre sus principales ventajas se encuentra:

  • Alta tolerancia a las interferencias
  • Alta sensibilidad para recibir datos (-168dB)
  • Basado en modulación chirp
  • Bajo Consumo (hasta 10 años con una batería*)
  • Largo alcance 10 a 20km
  • Baja transferencia de datos (hasta 255 bytes)
  • Conexión punto a punto
  • Frecuencias de trabajo: 915Mhz América, 868 Europa, 433 Asia

LoRa quizá sea más adecuada para usar en aplicaciones discretas como edificios inteligentes o campus donde uno es necesaria una red celular. LoRaWAN se refiere a redes públicas amplias basadas en LoRa.

Moteino son una placas basadas en Arduino pensadas para bajo consumo con LoRa: https://lowpowerlab.com/guide/moteino/lora-support/

LoRa vs Zigbee: http://www.rfwireless-world.com/Terminology/LoRa-vs-Zigbee.html

LoRaWan vs Sigfox

Lora pros:

  • De uso gratuito, puede configurar su propia red
  • Envía tantos mensajes como quieras, a buenas velocidades de hasta 50 Kb/s
  • Alcance muy largo (algunos kilómetros en ciudades, hasta 40 km en áreas rurales con antenas direccionales)
  • Bastante poca potencia, dependiendo de la amplificación de su radio, no tan baja como BTLE pero mucho mejor que la celular
  • Coger y elegir la frecuencia que legalmente está permitido usar

Lora contras:

  • Debe administrar su propia red y gateways
  • Chips solo disponibles de SemTech, y bajo patente

Sigfox pros:

  • Red de backend incluida
  • Alcance muy largo (algunos kilómetros en ciudades, hasta 40 km en áreas rurales con antenas direccionales)
  • Muy poca potencia

Sigfox contras

  • Servicio pago por suscripción
  • Ultra lento: 100 bytes / seg
  • No disponible en todas partes, comprobar cobertura https://www.sigfox.com/en/coverage
  • Limite mensajes de subida de 140 x 12 bytes y mensajes de descarga de 4 x 8 bytes al día.
  • Frecuencia fija por ubicación

Buena explicación de Adafruit para LoRa y Sigfox: https://learn.adafruit.com/alltheiot-transports/lora-sigfox

Más información de sigfox y lora https://www.linkedin.com/pulse/iot-how-connect-devices-vasco-barreiros

Interesante: https://austinstartups.com/carriers-aim-to-crush-lora-sigfox-and-others-4d38adc8cc32

Transceivers LoRa

Existen muchos módulos LoRa disponibles en el mercado que podemos usar con Arduino usando las librerías que nos proporcionan.

Semtech

Semtech fabrica diversos módulos LoRa. Los módulos Lora de Semtech son: https://www.semtech.com/products/wireless-rf/lora-transceivers y los gateways: https://www.semtech.com/products/wireless-rf/lora-gateways

El SX1272 es un módulo de Semtech LoRa https://www.semtech.com/products/wireless-rf/lora-transceivers/SX1272

Datasheet: https://www.semtech.com/uploads/documents/sx1272.pdf

Otros módulos de Semtech: https://www.semtech.com/products/wireless-rf

Microchip

Microchip fabrica diversos módulos LoRa RN2903 y RN2483. Ver https://www.microchip.com/design-centers/wireless-connectivity/low-power-wide-area-networks/lora-sup-reg-sup-technology

Comprar: https://www.digikey.es/es/product-highlight/m/microchip-technology/rn2903-and-rn2483-rf-transceiver-modules

Módulo LoRa de Microchip:

Datasheet:

Es un excelente módulo que implementa completamente la pila LoRaWAN. El microcontrolador se comunica con él a través de USART con una estructura de comando simple para configurarlo y enviar / recibir mensajes. El módulo también tiene varios pines GPIO disponibles. Este es el módulo preferido en The Things Network, y hay muchos excelentes proyectos de ejemplo y códigos en Internet para ayudarlo a comenzar.

Hoperf

Hoperf fabrica diversos módulos Lora:http://www.hoperf.com/rf_transceiver/lora/

Los módulos de RFM son pequeños y baratos, lo cual es ideal para proyectos de IoT. Sin embargo, tienen una limitación si desea usarlos con LoRaWAN: la pila no está implementada en el módulo, dejando esa carga al microcontrolador. La pila LoRaWAN requiere bastante espacio de código y es difícil de implementar en algunos microcontroladores de 8 bits.

RFM95W: http://www.hoperf.com/rf_transceiver/lora/RFM95W.html

RFM96W: http://www.hoperf.com/rf_transceiver/lora/RFM96W.html

RFM98W: http://www.hoperf.com/rf_transceiver/lora/RFM98W.html

Datasheet módulos LoRa: http://www.hoperf.com/upload/rf/RFM95_96_97_98W.pdf

Estos son los módulos usados por Moteino: https://lowpowerlab.com/guide/moteino/

Hoperf fabrica otros módulos Sub-GHz como el RFM69 que no usanLora: http://www.hoperf.com/rf_transceiver/

Placa con RFM95/96(W):

LoRa Shield como módulo RFM: https://www.seeedstudio.com/Dragino-LoRa-Shield-support-433M-frenquency-p-2672.html

Otros

Existen otros fabricante de módulos Lora como: