Smart Sensor WiFi : Différence entre versions

De Wiki de Projets IMA
(Informations générales)
(Analyse du sujet)
Ligne 27 : Ligne 27 :
 
== Analyse du sujet ==
 
== Analyse du sujet ==
 
On a ici affaire à un réseau de capteurs reliés à une base de donnée centrale
 
On a ici affaire à un réseau de capteurs reliés à une base de donnée centrale
qui est chargée d'interroger ''Alexandre : Pas sur, est-ce les capteurs qui sont à l'origine de la remontée d'information, après configuration par la base centrale ?'' régulièrement les différents capteurs de manière
+
qui est chargée de recevoir les données des différents capteurs de manière
 
à pouvoir présenter à un utilisateur un état des différentes pièces dans
 
à pouvoir présenter à un utilisateur un état des différentes pièces dans
 
lesquelles on aura disposé les capteurs. Cela peut notamment impliquer :
 
lesquelles on aura disposé les capteurs. Cela peut notamment impliquer :
Ligne 33 : Ligne 33 :
 
* Un accès à ces données via une interface web
 
* Un accès à ces données via une interface web
 
* Un accès à ces données via une application mobile
 
* Un accès à ces données via une application mobile
* Un accès à ces données via un programme desktop
 
  
 
''Alexandre : On pourrait tout rassembler en une BDD avec un accès à travers un navigateur ?''
 
''Alexandre : On pourrait tout rassembler en une BDD avec un accès à travers un navigateur ?''
Ligne 48 : Ligne 47 :
 
* Être capable de mesurer l'environnement dans lequel évolue le capteur (Pression, température, lumière, présence, ouverture de porte...)
 
* Être capable de mesurer l'environnement dans lequel évolue le capteur (Pression, température, lumière, présence, ouverture de porte...)
 
* Contacter le serveur via le WiFi pour actualiser la base. ''Alexandre : ce qui implique la prise en compte de la sécurité type WPA2''
 
* Contacter le serveur via le WiFi pour actualiser la base. ''Alexandre : ce qui implique la prise en compte de la sécurité type WPA2''
* Éventuellement, être reconfigurable à distance (ou via l'USB pour modifier par exemple le SSID/password du réseau) ''Alexandre : l'USB va augmenter la complexité du capteur (son coût et sa taille) et ne semble pas adapté dans le cas où le nombre de capteurs est grand.''
+
* Éventuellement, être reconfigurable à distance (via un serveur web embarqué dans le microcontrôleur)
 
* Être capable de gérer sa consommation d'énergie.
 
* Être capable de gérer sa consommation d'énergie.
 
* Agir en temps que datalogger si le réseau n'est pas accessible.
 
* Agir en temps que datalogger si le réseau n'est pas accessible.
Ligne 75 : Ligne 74 :
 
L'inconvénient de cette solution est qu'elle ne gère malheureusement pas les identifications '''PEAP''' utilisées sur le réseau de
 
L'inconvénient de cette solution est qu'elle ne gère malheureusement pas les identifications '''PEAP''' utilisées sur le réseau de
 
l'Université. Cependant aucune puce utilisable répondant à nos critères n'a pu être trouvée lors de nos recherche. En revanche, le
 
l'Université. Cependant aucune puce utilisable répondant à nos critères n'a pu être trouvée lors de nos recherche. En revanche, le
réseau WPA2 usuel est parfaitement géré.
+
réseau WPA2 usuel est parfaitement géré. Il faut donc trouver un mécanisme d'authentification alternatif pour le réseau.
  
 
Dans un premier temps, on se concentrera sur la mise en place d'un prototype fonctionnel a base d'un simple capteur de température. On
 
Dans un premier temps, on se concentrera sur la mise en place d'un prototype fonctionnel a base d'un simple capteur de température. On
Ligne 81 : Ligne 80 :
  
 
==== Le serveur ====
 
==== Le serveur ====
On propose une solution à base d'une machine sous Linux (Raspberry Pi pour une version plus compacte
+
On propose une solution à base d'une machine sous Linux hébergeant un serveur MySQL et PHP.
ou un vrai serveur pour une version destinée à administrer des réseaux de capteurs de taille plus importante. ''Alexandre : J'opte pour un vrai serveur, l'option Raspberry ne me semble pas pertinente''
 
  
Le SGBD utilisé serait '''MySQL''' ou '''SQLite'''.
+
Le SGBD utilisé sera '''MySQL'''.
  
 
La partie web du serveur destinée à présenter à l'utilisateur une vue des données serait développée en PHP/HTML5/CSS3.
 
La partie web du serveur destinée à présenter à l'utilisateur une vue des données serait développée en PHP/HTML5/CSS3.
La partie serveur qui recevra les flots de communication des capteurs serait programmée en Python. Cette partie servira
+
Les capteurs enverront les données sous forme JSON au serveur web qui se chargera du traitement.
à recueillir les données des capteurs et à les formater pour les insérer dans la base. Éventuellement des opérations
 
pourront être effectuées sur ces données, exemple transformer un entier 8 bits en une température entre 20° et 30°.
 

Version du 5 février 2014 à 13:19

Informations générales

Page de wiki du projet Smart Sensor WiFi

Étudiants Thomas Maurice et Benoit Maliar

Tuteurs Alexandre Boé et Thomas Vantroys

Les fichiers sources du projet sont disponibles via Git. Alexandre : Il n'est pas possible de faire un Git en interne à Polytech ? Thomas M: Pas pour le moment, l'école n'a pas la machine qui va bien.

Énoncé initial du projet

L'objectif du projet consiste en la conception et la réalisation de capteurs autonomes communiquant en WiFi afin de pouvoir remonter régulièrement des informations sur l'état des salles de cours. Les capteurs seront par exemple des détecteurs de lumières, de pression, de qualité de l'air, ...

La communication sera obligatoirement réalisée en WiFi sur le réseau de l'université en respectant les contraintes de sécurité (WPA2, ...).

Deux options sont possibles :

  • Refaire complètement une carte avec un microcontroleur et une puce wifi (comme par exemple les spark)
  • Réaliser un shield pour raspberry pi contenant les différents capteurs.

Analyse du sujet

On a ici affaire à un réseau de capteurs reliés à une base de donnée centrale qui est chargée de recevoir les données des différents capteurs de manière à pouvoir présenter à un utilisateur un état des différentes pièces dans lesquelles on aura disposé les capteurs. Cela peut notamment impliquer :

  • Un accès à ces données via une interface web
  • Un accès à ces données via une application mobile

Alexandre : On pourrait tout rassembler en une BDD avec un accès à travers un navigateur ?

On identifie donc deux parties au projet :

  • La partie capteur
  • La partie serveur

Cahier des charges

Spécifications des capteurs

Les caractéristiques souhaitées pour les capteurs sont :

  • Être capable de mesurer l'environnement dans lequel évolue le capteur (Pression, température, lumière, présence, ouverture de porte...)
  • Contacter le serveur via le WiFi pour actualiser la base. Alexandre : ce qui implique la prise en compte de la sécurité type WPA2
  • Éventuellement, être reconfigurable à distance (via un serveur web embarqué dans le microcontrôleur)
  • Être capable de gérer sa consommation d'énergie.
  • Agir en temps que datalogger si le réseau n'est pas accessible.

Spécifications du serveur

Les caractéristiques souhaitées pour le serveur sont :

  • Être capable de contacter ou d'être contacté par les capteurs via le réseau.
  • Respecter les contraintes de sécurité (WPA2)
  • Être capable d'authentifier les clients
  • Stocker les données reçues dans une base de données et éventuellement faire des calculs et des statistiques sur ces données.
  • Présenter sous format compréhensibles les données au client (web ou appli)
  • Vérifier l'état des capteurs et notifier un responsable en cas d'anomalie (déconnexion du réseau, valeur anormale d'un capteur...)

Propositions de solutions technologiques

Les capteurs

Nous proposons de réaliser une carte basée sur un ATmega328 dans lequel on pourra flasher du code Arduino. Pour gérer le WiFi, nous proposons une solution utilisant le board CC3000 d'Adafruit lien ici.

L'avantage de cette solution est que la carte est optimisée pour les breadboards et peut du coup facilement être clipsée sur la carte. Elle possède également l'avantage d'être fournie avec la bibliothèque Arduino qui va bien (et qui est bien open source) de manière à pouvoir être pilotée depuis un Arduino ou dans notre cas un AVR tout simple. Enfin, le dernier avantage est qu'Adafruit travaille en mode "Open Hardware" ce qui signifie que les plans de la carte sont disponibles en ligne, ce qui nous permettrait d'intégrer la carte WiFi au sein de notre projet facilement dans un second temps.

L'inconvénient de cette solution est qu'elle ne gère malheureusement pas les identifications PEAP utilisées sur le réseau de l'Université. Cependant aucune puce utilisable répondant à nos critères n'a pu être trouvée lors de nos recherche. En revanche, le réseau WPA2 usuel est parfaitement géré. Il faut donc trouver un mécanisme d'authentification alternatif pour le réseau.

Dans un premier temps, on se concentrera sur la mise en place d'un prototype fonctionnel a base d'un simple capteur de température. On étendra ensuite les capacités de la chose à des capteurs peut être plus complexes style I2C ou SPI.

Le serveur

On propose une solution à base d'une machine sous Linux hébergeant un serveur MySQL et PHP.

Le SGBD utilisé sera MySQL.

La partie web du serveur destinée à présenter à l'utilisateur une vue des données serait développée en PHP/HTML5/CSS3. Les capteurs enverront les données sous forme JSON au serveur web qui se chargera du traitement.