PM2M/2019/TP: Difference between revisions

From air
Jump to navigation Jump to search
 
(16 intermediate revisions by the same user not shown)
Line 34: Line 34:
** Présentation IoT ETL Mashup avec [[Node-RED]] sur [[CampusIoT]]* 05/03 13H30-16H45 au [http://fabmstic.imag.fr/wp-content/uploads/2017/11/plan_im2ag.jpg fablab FabMSTIC] (Apportez vos machines)
** Présentation IoT ETL Mashup avec [[Node-RED]] sur [[CampusIoT]]* 05/03 13H30-16H45 au [http://fabmstic.imag.fr/wp-content/uploads/2017/11/plan_im2ag.jpg fablab FabMSTIC] (Apportez vos machines)
** [[PM2M_Docker|Getting started]]
** [[PM2M_Docker|Getting started]]
* 05/03 13H30-16H45 au [http://fabmstic.imag.fr/wp-content/uploads/2017/11/plan_im2ag.jpg fablab FabMSTIC] (Apportez vos machines)** Tutoriel
* 05/03 13H30-16H45 au [http://fabmstic.imag.fr/wp-content/uploads/2017/11/plan_im2ag.jpg fablab FabMSTIC] (Apportez vos machines)
[[ STM32 IoTNode B-L475E-IOT01A|STM32 IoTNode]] ([https://www.linkedin.com/in/michael-escoda-a2776916/ Michael ESCODA], ST Microelectronics Grenoble) 1H30 (à confirmer)
** Tutoriel [[STM32 IoTNode B-L475E-IOT01A|STM32 IoTNode]] ([https://www.linkedin.com/in/michael-escoda-a2776916/ Michael ESCODA], ST Microelectronics Grenoble) 1H30 (à confirmer)
** Travail en équipe
** Travail en équipe
* 12/03 13H30-16H45 au [http://fabmstic.imag.fr/wp-content/uploads/2017/11/plan_im2ag.jpg fablab FabMSTIC] (Apportez vos machines)
* 12/03 13H30-16H45 au [http://fabmstic.imag.fr/wp-content/uploads/2017/11/plan_im2ag.jpg fablab FabMSTIC] (Apportez vos machines)
Line 71: Line 71:
* Sat-IoT et LPGAN
* Sat-IoT et LPGAN
* Eclipse IOTA Trinity
* Eclipse IOTA Trinity
* [[zenoh]]
* [[Acoustic Data Communications for Underwater IoT Applications]] ([[Remotely Operated Vehicle|ROV]]s, [[Unmanned Underwater Vehicule|UUV]]s ...)
* FOTA ([Firmware Over-The-Air]) dans les réseaux LPWAN
* FOTA ([[Firmware Over-The-Air]]) dans les réseaux LPWAN
* [[Eclipse Keyple]]
* ...
* [[Eclipse Kuksa]]
* [[Eclipse fog∅5]]
* [[Eclipse ioFog]]
* [[Eclipse hawkbit]]
* [[Eclipse Vorto]]
* [[Eclipse 4diac]]
* [[Eclipse Wakaama]]
* [[Apache Mynewt]]
* [[Open Air Interface]]


==Fiche "Privacy & Sécurity"==
==Fiche "Privacy & Sécurity"==
Line 98: Line 107:
# ODBII dongle BLE
# ODBII dongle BLE
# [https://www.seeedstudio.com/OBD-II-CAN-BUS-Development-Kit-p-2993.html Grove OBD-II CAN-BUS Development Kit]
# [https://www.seeedstudio.com/OBD-II-CAN-BUS-Development-Kit-p-2993.html Grove OBD-II CAN-BUS Development Kit]
# Multichannel gas sensor [[MiCS-6814]]

# [http://micropython.org/stm32/ micropython sur STM32]


==Mini-Projet==
==Mini-Projet==
Line 127: Line 139:


* '''Campagne d'instrumentation de la température et de l'humidité du batiment IM2AG'''
* '''Campagne d'instrumentation de la température et de l'humidité du batiment IM2AG'''
** Etudiants: Nicolas Huchet, Loïc Houdebine
** [[Sagemcom Siconia]] (x20)
** Equipements:
** [[Elsys ERS CO2]]
*** [[Sagemcom Siconia]] (x20)
** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]
*** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]

** [[I-NUCLEO-LRWAN1]]
* '''Station de mesure de la qualité de l'air [[LoRa]]WAN'''
** [http://wiki.seeedstudio.com/Grove-Dust_Sensor/ Grove Dust Sensor]
** [[Eclipse IOTA Trinity]]
** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]


* '''IRock : Surveillance des glissements de terrain'''
* '''IRock : Surveillance des glissements de terrain'''
** Etudiants: Baptiste Marion, Quentin Rozand
** Station méteo [[LoRa]]
** Equipements:
** [https://github.com/CampusIoT/tutorial/tree/master/siconia Sagem Siconia]
*** Station méteo [[LoRa]]
** [[IRock : Surveillance Géotechnique LoRa|Caillou IRock]]
*** [https://github.com/CampusIoT/tutorial/tree/master/siconia Sagem Siconia]
** [[Hyperledger]]
*** [[IRock : Surveillance Géotechnique LoRa|Caillou IRock]]
** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]
*** [[Hyperledger]]
*** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]


* '''Radar et comptage de personnes (fusion d'information)'''
* '''Sport récompensé'''
** Etudiants: yann ducruy, r segretain
** Vélo d'entrainement Domyos à hacker
** Equipements:
** Modem LoRa 2.4 GHz [https://wireless-solutions.de/products/radiomodules/im282a.html iM282a]
** [[Eclipse IOTA Trinity]]
*** [[OpenHAB]]
*** [[HB100 Miniature Microwave Motion Sensor]]

*** [[SparkFun Grid-EYE Infrared Array Breakout - AMG8833]]
* '''Radar et comptage de véhicules/personnes (fusion d'information)'''
** [[OpenHAB]]
*** [[Hyperledger]]
** Caméra de surveillance IP
*** Voir https://dzone.com/articles/java-autonomous-driving-car-detection-1
** [[HB100 Miniature Microwave Motion Sensor]]
** [[Hyperledger]]


* '''Monitoring du fablab'''
* '''Monitoring du fablab'''
** Etudiants: ABDULLAH HASIM mohd thaquif, CADAVID Juan, GINET Maxence
** [[OpenHAB]]
** Equipements:
** Capteurs LoRaWAN de Température, Détection de présence, détecteur de fumée, ...
** RFXCom, enOcean, ZWave
** [[Hyperledger]]
** '''[[ISofa]]'''
*** [[OpenHAB]]
*** [[OpenHAB]]
*** Capteurs LoRaWAN de Température, Détection de présence, détecteur de fumée, ...
*** Canapé IKEA [http://www.ikea.com/fr/fr/catalog/products/80264964/#/80264964|KNOPPARP]
*** RFXCom, enOcean, ZWave
*** Boutons de Borne Arcade ?
*** [[Papierlogik]]
*** [[Hyperledger]]
*** '''[[ISofa]]'''
** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]
**** [[OpenHAB]]
**** Canapé IKEA [http://www.ikea.com/fr/fr/catalog/products/80264964/#/80264964|KNOPPARP]
**** Boutons de Borne Arcade ?
**** [[Papierlogik]]
*** Réseau LoRaWAN [https://campusiot.github.io/ CampusIoT]


* '''Géolocalisation [[Time difference of arrival|TDOA]] [[LoRa]]'''
* '''Géolocalisation [[Time difference of arrival|TDOA]] [[LoRa]]'''
** Etudiants: Benjamin Gontard, Antoine Duquennoy
** [[CampusIoT]] dataset
** Equipements:
** [https://github.com/CampusIoT/payload-codec/tree/master/src/main/javascript/adeunisrf Adeunis Field Test Device]
*** [[CampusIoT]] dataset
** [https://github.com/CampusIoT/payload-codec/tree/master/src/main/javascript/semtech Semtech LoRaMote]
*** [https://github.com/CampusIoT/payload-codec/tree/master/src/main/javascript/adeunisrf Adeunis Field Test Device]
** STM32 Nucleo LRWAN1 + [https://www.st.com/en/ecosystems/x-nucleo-gnss1a1.html Teseo Nucleo shield]
*** [https://github.com/CampusIoT/payload-codec/tree/master/src/main/javascript/semtech Semtech LoRaMote]
** [https://www3.nd.edu/~cpoellab/teaching/cse40815/Chapter10.pdf ref]
*** STM32 Nucleo LRWAN1 + [https://www.st.com/en/ecosystems/x-nucleo-gnss1a1.html Teseo Nucleo shield]
*** [[I-NUCLEO-LRWAN1]]
*** [https://www3.nd.edu/~cpoellab/teaching/cse40815/Chapter10.pdf ref]

* '''Parking à la seconde'''
** Etudiants: Florian Gourdeau, Loric Coleiro
** Equipements:
*** [[CampusIoT]]
*** STM32 Nucleo
** Teseo GNSS shield
*** [[I-NUCLEO-LRWAN1]]
** [https://www.seeedstudio.com/OBD-II-CAN-BUS-Development-Kit-p-2993.html Grove ODBII]


==@Deprecated: Contenu général des mini-projets==
==@Deprecated: Contenu général des mini-projets==

Latest revision as of 08:24, 8 May 2019

Page 2019 des supports de cours et travaux pratiques de l'UE Projets M2PGI Services Machine-to-Machine et Internet-of-Things.

Enseignants 2019 : Didier Donsez

Partie démarrant 12/02 au 26/03 .

Soutenance du mi-projet durant la semaine d'examen le ??/03 (3H00).

Rendu fiche de synthèse : ??/03 à minuit.

Le mini-projet réalisé en séance a pour objectif la mise en place rapide et agile d'une infrastructure (matérielle et logicielle) de collecte de données capteur. Les mesures de capteurs distribués sont acquises par des dispositifs embarqués et sont remontés vers des serveurs de données hébergés dans un cluster sur un cloud public pour y être analysées (Big Data Analytics) et visualisées (dataviz) et sécurisé avec la blockchain Hyperledger Fabric.

IoT systems over years
IoT Reference Architecture
Sensors Mix


Support de cours

Planning

19/03 13H30-16H45 au fablab FabMSTIC (Apportez vos machines)

    • Travail en équipe
  • 26/03 13H30-16H45 au fablab FabMSTIC (Apportez vos machines)
    • Travail en équipe
  • 08/04 : Rendu des fiches de synthèse
  • 09/04 15H00-18H00 : Soutenances (présentation + questions + démonstration)

Etapes


Remarque TRES TRES importante: ne sauvegardez pas les crédentials des services cloud que vous utilisez (AWS, Digital Ocean, Heroku, Azure, IBM Bluemix, Twitter, OVH ...) dans des dépôts git publiques : placez les dans des documents credentials.json, credentials.properties, credentials.sh, ... et ajoutez les ces documents à .gitignore pour plus de sureté.

Fiche de synthèse

Synthétiser un des sujets suivants en 1 page maximum. La page doit être une entrée du wiki. Chaque synthèse est individuelle.

Fiche "Privacy & Sécurity"

Rédiger en 1 page maximum les aspects "Privacy & Sécurity" de votre projet. La page doit être une entrée du wiki. Chaque fiche est individuelle.

Cartes, Capteurs et Actionneurs

STM32 IoTNode B-L475E-IOT01A
LoPy (LoRa)
SiPy (Sigfox)
  1. SODAQ Explorer
  2. Sagemcom Siconia
  3. Pycom LoPy
  4. Pycom SiPy
  5. Pycom FiPy
  6. STM32 Nucleo + Shield LoRa + Shield Météo
  7. STM32 Nucleo + Shield LoRa + Shield Qualité de l'air
  8. STM32 Nucleo + Récepteur RDS + ESP8266
  9. STM32 IoTNode
  10. LoRaWAN devices
  11. Modem Microchip RN2483
  12. Modem IMST im282a SX1280 LoRa 2.4 GHz
  13. ODBII dongle BLE
  14. Grove OBD-II CAN-BUS Development Kit
  15. Multichannel gas sensor MiCS-6814
  1. micropython sur STM32

Mini-Projet

Architecture Mini-Projet

Ce mini-projet consiste a mettre en place une infrastructure de collecte de données capteur. L'acquisition des mesures de capteurs distribués se fait sur une carte STM32 Nucleo, sur une carte Intel Galileo ou sur un téléphone Android. Les technologies de comminucation sont : USB Serial, BLE, LoRa, Ethernet, WiFi. Les données sont remontées dans des messages vers un serveur (Node-RED) via un "broker" PubSub (MQTT (Mosquitto ou RabbitMQ), Apache Kafka, PubNub, PubSubHubbub, Socket.io, WebRTC ...). Les formats des messages peuvent être JSON (GeoJSON), BSON, CSV, NMEA 0183, binaire, XML (EEML, KML, AMMP ...) ... Les données peuvent être stockées dans une base de données (SQL ou NoSQL comme MongoDB, Redis.io, InfluxDB, ...) et visualisées en différé ou en direct (Grafana, D3.js, OpenHAB via le connecteur MQTT, Bootleaf pour les données géolocalisées ...). Elles seront sécurisées à l'aide d'une blockchain privée Hyperledger.


Mini-projets

Affectation des mini-projets

Affectation des projets PM2M 2017-2018
Sujet Étudiants Fiche de suivi Dépôt git Documents Matériel

Sujets (provisoire) des mini-projets

  • Campagne d'instrumentation de la température et de l'humidité du batiment IM2AG
  • Monitoring du fablab
    • Etudiants: ABDULLAH HASIM mohd thaquif, CADAVID Juan, GINET Maxence
    • Equipements:

@Deprecated: Contenu général des mini-projets

Les équipes ne font qu'une partie des manipulations en fonction du sujet du mini-projet affecté.

CoAP Binding for OpenHAB

Extension de Node-RED

Création ou Amélioration de Nodes

Le code devra être recontribué en open-source sur GitHub et catalogué dans http://flows.nodered.org/

Déploiement sur plateforme Cloud

Le serveur Node-RED et le "broker" PubSub MQTT (Mosquitto ou RabbitMQ) peuvent être hébergé sur une plateforme cloud 'gratuite' ou 'pas chère' comme Windows Azure ou Amazon EC2, Heroku, IBM Bluemix, Digital Ocean, OVH ou sur votre machine via des images Docker.

Attention, Eduroam bloque le port 1883 du protocole MQTT (entre autre).

PubSub des mesures capteur avec Apache Kafka

GPS > Kafka > Storm on Azure Demo

Remplacer le broker MQTT par le broker PubSub Apache Kafka qui peut fonctionner en configuration distribuée et répliquée (plusieurs serveurs sur une plateforme cloud).

PubSub des mesures capteur avec Apache Flume

Remplacer le broker MQTT par le broker PubSub Apache Flume qui peut fonctionner en configuration distribuée et répliquée (plusieurs serveurs sur une plateforme cloud).

Collecte, Stockage et Visualisation des mesures capteur avec Logstash, Elastic Search, Kibana

voir NodeRED ElasticSearch3

Routage avec Apache Nifi

Décodage avec Eclipse Vorto

Affichage des positions avec Bootleaf

Refactorer et améliorer Bootleaf afin de visualiser en temps réel les données géolocalisées de vos capteurs ou des traces (séries temporelles de positions). Exemple: tester la présence d'un champ latlon, latlonalt, geo, ... dans le JSON des flows Node-RED.

Analyse des mesures capteurs en temps réel avec Apache Spark Streaming

Installer Spark sur un petit cluster EC2 (1 master et 2 slaves en Ubuntu 14.04 t2.micro).

S'inspirer du script Scala MQTTCount pour calculer des valeurs agrégées (avg, min, max) des groupes de capteurs sur des fenêtres de 5 minutes.

Faire de même avec les brokers Apache Kafka et Apache Flume

Intégration à un ESB Apache Camel

Compléter le tutoriel avec un déploiement de composants Apache Camel Vous pourrez utiliser les composants suivants

Monitoring de votre infrastructure avec Telegraf, InfluxDB, Grafana et Kapacitor

Monitoring de votre infrastructure avec AWS Cloudwatch et Grafana

Pour monitorer les machines qui hébergent les serveurs (Mosquitto, ...) sur AWS EC2:

Soutenances

Planning des soutenances

COMING SOON

Instructions pour les soutenances des mini-projets

  • chaque soutenance dure 15 minutes comportant une présentation de 7 minutes ainsi qu'une démonstration de 5 minutes et 3 à 5 minutes de questions/réponses.
  • respectez le temps donc repetez la
  • remplissez le doodle pour choisir un creneau de passage
  • la présentation mettra en avant
    • le titre (avec les noms prénoms des binômes)
    • les applications IoT cibles/envisagées
    • le ou les architectures (successivement) implémentées,
    • les composants logiciels et matériels utilisés,
    • les métriques (langages de programmation, sloc, performance ...),
    • les problèmes rencontrés et les solutions élaborées,
    • la conclusion
    • des perspectives possibles à votre développement.

Le code, le rapport et le PDF de la presentation doivent être livré dans un dépôt Github la veille de la soutenance. Le rapport qui détaille les éléments de la présentation sera livré dans un README.md ou README.html dans le dépôt GitHub.

Envoyez le lien vers le dépôt Github (code + présentation) avant la soutenance.

La présentation peut-être réalisée avec Reveal.js.

Pensez a répéter vos présentations.

Visualisation

Stockage

Liens

Autres

Galeries

Galerie 2018

PM2M 2018PM2M 2018PM2M 2018PM2M 2018PM2M 2018PM2M 2018PM2M 2018PM2M 2018

Galerie 2017

Galerie 2016

Suivez les tweets :

Galerie 2015

Galerie 2014

PM2M 2014PM2M 2014PM2M 2014PM2M 2014PM2M 2014PM2M 2014PM2M 2014PM2M 2014