<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
		<id>https://wiki-ima.plil.fr/mediawiki//api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Froyer</id>
		<title>Wiki d'activités IMA - Contributions de l’utilisateur [fr]</title>
		<link rel="self" type="application/atom+xml" href="https://wiki-ima.plil.fr/mediawiki//api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Froyer"/>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php/Sp%C3%A9cial:Contributions/Froyer"/>
		<updated>2026-05-13T02:55:20Z</updated>
		<subtitle>Contributions de l’utilisateur</subtitle>
		<generator>MediaWiki 1.29.2</generator>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Projets_IMA5_2014/2015&amp;diff=17645</id>
		<title>Projets IMA5 2014/2015</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Projets_IMA5_2014/2015&amp;diff=17645"/>
				<updated>2015-02-24T10:14:46Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Répartition des binômes */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Merci de référencer vos pages de projets ici. Merci aussi d'uniformiser vos formats que ce soit en regardant la présentation des projets déjà créés ou en allant modifier le format des précédents si votre façon de faire vous semble la meilleure. Dans tous les cas un minimum de communication entre les binômes est conseillée.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Répartition des binômes ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;table border=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Projet&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Elèves&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Encadrant Ecole&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Rapport décembre&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Rapports finaux&amp;lt;/th&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[P1 Modélisation et commande de l'auto-ignition d'un moteur HCCI]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;Moulé Alexandre / Taché Clément &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; Anne-Lise Gehin / Jean-Yves Dieulot &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[Fichier:Rapport decembre moule tache.pdf]]  &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[Fichier: RapportFinPFE.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P5 Filtrage des indicateurs numériques de diagnostic]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; ZIOU Ismaïl / HAMZAOUI Oussama &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Belkacem Ould Bouamama &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:rapport_Z.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport PFE ZIOU HAMZAOUI.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[P6 Gestion des flux thermiques du bâtiment Polytech]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;Florian Royer / Zohour Assaieb &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; Belkacem Ould Bouamama &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; [[Fichier:Rapport_Intermédiaire_Royer_Assaieb.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; [[Fichier:Rapport_Final_PFE_ProjetP6.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P7 Utilisation d'un Robot Nao pour les enfants autistes]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Rodriguez Loïc/Ismaïl Tahry&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; GAPAS/Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Projetpfenaomi.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport PFE RodriguezTahry.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P8 Pilulier]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Alexandre Mercier / Emile Pinet&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas VANTROYS / Alexandre BOE &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport decembre PFE pilulier mercier pinet.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport PFE Pinet Mercier.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P9 Agenda pour personnes non lectrices]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Cédric DESPREZ &amp;amp; Soufiane HADDAOUI &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; GAPAS/Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_MiSoutenance_DESPREZ_HADDAOUI.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P11 Détecteur d'obstacles pour fauteuils électriques]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Geoffrey ROSE / Marjorie TIXIER &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; GAPAS / Blaise Conrard &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:Rapport_Intermédiaire_PFE_GAPAS_Rose_Tixier.pdf]]&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P12 Automatiser à l'aide d'une interface LabView la procédure de mesure de conductivité électrique d'un alternateur à griffes]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Hugo FONDU &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Abdelkader Benabou &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:rapport_presoutenance.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P13 Construction d'un support motorisé pour la réalisation des essais de décharges électrostatique]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; JEBBARI Zineb / BEKRAOUI Oumaima &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Nathalie Rolland &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:rapportJebbek.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P19 Contrôle et synchronisation d'instruments en microscopie]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Simon Duthoit&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Samuel Hym &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:RapportPFESimonDuthoit.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P21 Balise Bluetooth Low Energy]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Kévin CHALONO / Armagan YAMNAZ&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas VANTROYS &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[ Fichier:ProjetBLE 1 pdf.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_PFE_Yanmaz_Chalono2.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P21 Bis Prototypage d'interactions localisées et contextualisées ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Olivier Tailliez&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas Vantroys / Yvan Peter &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier: PFE_Olivier_Tailliez.pdf‎]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P22 Google Glass en logistique ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Jérémy Gondry / Vincent Meunier &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_intermediaire_Gondry_Meunier.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_final_PFE_Meunier_Gondry.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P24 Robot de surveillance domestique]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Sébastien DELTOMBE &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Xavier Redon &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_PFE_P24_Deltombe.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P25 SmartMeter]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas Ederlé / Sylvain Fossaert&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Guillaume Renault / Xavier Redon / Alexandre Boé &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:RapportFossaertEderle.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P26 Vehicule Electrique ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Smain Labdouni / Adnane Jaoui &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Arnaud Chielens / Philippe Delarue &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  [[Fichier:RAPPORT_VE_DEC.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  [[Fichier:Rapport_pfe_Jaoui_Labdouni_Fevrier.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P27 Controle Direct de Puissance d'un Convertisseur Matriciel ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Quentin Pesqueux / Nicolas Alexandre &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Philippe Delarue &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  [[Fichier:PFE_IMA5_MATRIX_CONVERTER_Alexandre_Pesqueux.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  [[Fichier:Rapport_PFE_Alexandre_Pesqueux.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P28 Modélisation d'un robot chirurgical déformable pour la simulation et le contrôle]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Charlotte BRICOUT / Nathan MARTIN &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Jérémie DEQUIDT&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:-BRICOUT MARTIN--Rapport PFE.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P33 Ligthing contactless / &amp;quot;wireless&amp;quot;]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Benjamin Lafit &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Alexandre Boé &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:Rapport_Benjamin_Lafit.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P35 Hack-a-Wii : Emulation de wiimote pour rendre la Wii accessibles aux personnes handicapées ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Fabien Violier &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P37 Creation d'un composant d'audit des accès cache mémoire sur un microprocesseur LEON3 simulé en FPGA ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Jérôme Vaessen &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Julien Cartigny / Pierrick Buret &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:Rapport_VAESSEN_presoutenance.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P44 Création d'un systeme domotique sans fil ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Benoit MALIAR / Thomas MAURICE&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Pierrick BURET / Thomas VANTROYS  &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:RapportMaliarMauriceDecembre.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:Rapport_final_Maliar_Maurice.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P45 Aide à la navigation d'un véhicule autonome]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Pierre APPERCÉ&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Rochdi MERZOUKI &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P46 Simulation Temps Réel d'un Environnement de Robots Autonomes Logisticiens]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Valentin VERGEZ&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Rochdi MERZOUKI &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P57 CHRU Lille : Smart Picking]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Mathieu Bossennec / Florian Caron&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Gwénaëlle Maton / Alexandre Boé / Thomas Vantroys &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[P58 Transformation des spectateurs d’un concert en afficheur géant interactif]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; Hautecoeur Mélanie &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; Alexandre Boé / Thomas Vantroys &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[Fichier : PFE_Rapport_Hautecoeur_Melanie.pdf‎]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P59 Assistance globale pour aide au parking]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Mathieu GERIER / Céline LY &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Alexandre BOE / Thomas VANTROYS &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;/table&amp;gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Rapport_Final_PFE_ProjetP6.pdf&amp;diff=17644</id>
		<title>Fichier:Rapport Final PFE ProjetP6.pdf</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Rapport_Final_PFE_ProjetP6.pdf&amp;diff=17644"/>
				<updated>2015-02-24T10:13:00Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : Rapport final du Projet P6 : Régulation thermique des salles de Polytech.

--- Zohour Assaieb &amp;amp; Florian Royer - IMA5 ---&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Rapport final du Projet P6 : Régulation thermique des salles de Polytech.&lt;br /&gt;
&lt;br /&gt;
--- Zohour Assaieb &amp;amp; Florian Royer - IMA5 ---&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=16657</id>
		<title>P6 Gestion des flux thermiques du bâtiment Polytech</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=16657"/>
				<updated>2015-02-09T17:22:36Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Déroulement du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Liens ==&lt;br /&gt;
Il vous est possible de visualiser les différents travaux effectués sur le cloud oneDrive au lien suivant : [http://1drv.ms/1pBsiu6 lien OneDrive]&lt;br /&gt;
Il contient notamment les fichiers matlab, le PowerPoint présentation comparatives des offres pour le matériel, les devis et le MS Project contenant l'ensemble des tâches.&lt;br /&gt;
&lt;br /&gt;
== Présentation du projet ==&lt;br /&gt;
===Contexte===&lt;br /&gt;
Ce projet s'inscrit dans la continuité d'un projet entamé en IMA4 et qui consiste en la réalisation d'un système intelligent de régulation des flux thermiques des radiateurs installés à Polytech Lille pour essayer de réduire au maximum les pertes d'énergie engendrées. Il est réalisé dans le cadre du projet de développement durable initié par la direction de l'école.&lt;br /&gt;
===Objectif===&lt;br /&gt;
Réaliser un système intelligent capable de réguler le flux thermique d'un radiateur d'une salle à Polytech Lille, afin de maintenir la température de cette dernière à valeur constante, en prenant compte certains paramètres parmi lesquels: planning des salles, données météo ou température extérieure … , ainsi que les situations: fenêtre ouverte, utilisation imprévue de salle ... .&lt;br /&gt;
&lt;br /&gt;
Le résultat final est un démonstrateur sur la plateforme de test constitué du radiateur équipé de l'électrovanne automatisé. Par ailleurs, une interface de supervision doit être établi, une interface homme-machine à destination des utilisateurs de la salle peut aussi être envisageable.&lt;br /&gt;
===Cahier des charges===&lt;br /&gt;
*Choix logistique et installation de l'équipement: électrovanne, capteurs, API&lt;br /&gt;
&lt;br /&gt;
*Régulation et commande du radiateur : modélisation, simulation, mises en places des algorithmes et implémentation dans l'API&lt;br /&gt;
&lt;br /&gt;
*Supervision : Simulation du système de défaillance et réalisation de l'interface&lt;br /&gt;
&lt;br /&gt;
*Établir la connexion aux données du planning des salles et données météo&lt;br /&gt;
&lt;br /&gt;
*IHM : Réaliser une interface conviviale avec authentification et gestion des modes de chauffage&lt;br /&gt;
&lt;br /&gt;
==Déroulement du projet==&lt;br /&gt;
===Semaine 1 : 15/09 - 21/09===&lt;br /&gt;
* Analyse du projet&lt;br /&gt;
&lt;br /&gt;
* Réalisation du cahiers des charges et définition des taches&lt;br /&gt;
&lt;br /&gt;
* Etudes comparative des différents équipements&lt;br /&gt;
&lt;br /&gt;
* Comparaisons des entreprises collaboratrices&lt;br /&gt;
&lt;br /&gt;
* Etudes des solutions envisagées&lt;br /&gt;
&lt;br /&gt;
===Semaine 2 : 22/09 - 28/09===&lt;br /&gt;
* Réalisation du diagramme Gant du projet &lt;br /&gt;
&lt;br /&gt;
* Commande des composants chez wago&lt;br /&gt;
&lt;br /&gt;
* Communication avec le directeur technique de Polytech pour diverses informations techniques vis-à-vis des radiateurs&lt;br /&gt;
&lt;br /&gt;
* Analyse du système de commande existant ( projet IMA4 )&lt;br /&gt;
&lt;br /&gt;
===Semaine 3 : 29/09 - 05/10===&lt;br /&gt;
* Modélisation du système&lt;br /&gt;
&lt;br /&gt;
* Contact avec WAGO pour le suivi de la commande des pièces&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Partie Commerciale==&lt;br /&gt;
&lt;br /&gt;
Cette partie du projet consistait à créer un appel d'offre pour savoir quelles entreprises seraient intéressées et ce qu'elles pourraient apporter au projet.&lt;br /&gt;
3 entreprises ont été contactées :&lt;br /&gt;
* Festo&lt;br /&gt;
* Wago&lt;br /&gt;
* Schneider Electronics (qui ne se sont pas montrés intéressés).&lt;br /&gt;
&lt;br /&gt;
Festo a proposé du matériel haut de gamme et monté sur mesure, incluant un service technique dédié à Polytech, ce qui se voulait rassurant, mais qui ne nous intéressait pas dans le cadre du projet (ils prévoyaient en effet de développer le programme à embarquer dans l'automate).&lt;br /&gt;
Wago a proposé du matériel à monter nous même mais 4000€ de moins que Festo. Au final, un ingénieur Wago est venu une journée expliquer comment l'automate fonctionnait et l'utilisation des bibliothèque du matériel.&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : dans cette partie nous avons été confronté à un choix de fournisseur, établissement de bon de commande et étude des datasheets afin de savoir quel matériel on allait recevoir et surtout bien choisir le fournisseur.&lt;br /&gt;
&lt;br /&gt;
==Partie Théorique==&lt;br /&gt;
&lt;br /&gt;
Cette partie du projet avait pour but de démontrer la faisabilité du projet et le gain réel (économique et en confort) de l'utilisation du système qui en résulterait.&lt;br /&gt;
L'objectif principale était de modéliser les échanges mécano-thermo-hydroliques mis en jeux dans un système de chauffage afin de pouvoir modéliser l'effet d'une commande régulée.&lt;br /&gt;
&lt;br /&gt;
==Partie Pratique 1 : Mise en place du programme embarqué==&lt;br /&gt;
&lt;br /&gt;
==Partie Pratique 2 : Programmation des interfaces graphiques==&lt;br /&gt;
&lt;br /&gt;
Durant cette partie du projet nous tentons de mettre en place une interface graphique permettant de visualiser les différentes erreurs que pourrait rencontrer le système pour fonctionner (supervision), et nous allons récupérer les valeurs de température de la pièce ainsi que d'ouverture de la vanne sur les 72 dernières heures.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=16656</id>
		<title>P6 Gestion des flux thermiques du bâtiment Polytech</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=16656"/>
				<updated>2015-02-09T17:22:01Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Partie Commerciale */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Liens ==&lt;br /&gt;
Il vous est possible de visualiser les différents travaux effectués sur le cloud oneDrive au lien suivant : [http://1drv.ms/1pBsiu6 lien OneDrive]&lt;br /&gt;
Il contient notamment les fichiers matlab, le PowerPoint présentation comparatives des offres pour le matériel, les devis et le MS Project contenant l'ensemble des tâches.&lt;br /&gt;
&lt;br /&gt;
== Présentation du projet ==&lt;br /&gt;
===Contexte===&lt;br /&gt;
Ce projet s'inscrit dans la continuité d'un projet entamé en IMA4 et qui consiste en la réalisation d'un système intelligent de régulation des flux thermiques des radiateurs installés à Polytech Lille pour essayer de réduire au maximum les pertes d'énergie engendrées. Il est réalisé dans le cadre du projet de développement durable initié par la direction de l'école.&lt;br /&gt;
===Objectif===&lt;br /&gt;
Réaliser un système intelligent capable de réguler le flux thermique d'un radiateur d'une salle à Polytech Lille, afin de maintenir la température de cette dernière à valeur constante, en prenant compte certains paramètres parmi lesquels: planning des salles, données météo ou température extérieure … , ainsi que les situations: fenêtre ouverte, utilisation imprévue de salle ... .&lt;br /&gt;
&lt;br /&gt;
Le résultat final est un démonstrateur sur la plateforme de test constitué du radiateur équipé de l'électrovanne automatisé. Par ailleurs, une interface de supervision doit être établi, une interface homme-machine à destination des utilisateurs de la salle peut aussi être envisageable.&lt;br /&gt;
===Cahier des charges===&lt;br /&gt;
*Choix logistique et installation de l'équipement: électrovanne, capteurs, API&lt;br /&gt;
&lt;br /&gt;
*Régulation et commande du radiateur : modélisation, simulation, mises en places des algorithmes et implémentation dans l'API&lt;br /&gt;
&lt;br /&gt;
*Supervision : Simulation du système de défaillance et réalisation de l'interface&lt;br /&gt;
&lt;br /&gt;
*Établir la connexion aux données du planning des salles et données météo&lt;br /&gt;
&lt;br /&gt;
*IHM : Réaliser une interface conviviale avec authentification et gestion des modes de chauffage&lt;br /&gt;
&lt;br /&gt;
==Déroulement du projet==&lt;br /&gt;
===Semaine 1 : 15/09 - 21/09===&lt;br /&gt;
* Analyse du projet&lt;br /&gt;
&lt;br /&gt;
* Réalisation du cahiers des charges et définition des taches&lt;br /&gt;
&lt;br /&gt;
* Etudes comparative des différents équipements&lt;br /&gt;
&lt;br /&gt;
* Comparaisons des entreprises collaboratrices&lt;br /&gt;
&lt;br /&gt;
* Etudes des solutions envisagées&lt;br /&gt;
&lt;br /&gt;
===Semaine 2 : 22/09 - 28/09===&lt;br /&gt;
* Réalisation du diagramme Gant du projet &lt;br /&gt;
&lt;br /&gt;
* Commande des composants chez wago&lt;br /&gt;
&lt;br /&gt;
* Communication avec le directeur technique de Polytech pour diverses informations techniques vis-à-vis des radiateurs&lt;br /&gt;
&lt;br /&gt;
* Analyse du système de commande existant ( projet IMA4 )&lt;br /&gt;
&lt;br /&gt;
===Semaine 3 : 29/09 - 05/10===&lt;br /&gt;
* Modélisation du système&lt;br /&gt;
&lt;br /&gt;
* Contact avec WAGO pour le suivi de la commande des pièces&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
===Partie Commerciale===&lt;br /&gt;
&lt;br /&gt;
Cette partie du projet consistait à créer un appel d'offre pour savoir quelles entreprises seraient intéressées et ce qu'elles pourraient apporter au projet.&lt;br /&gt;
3 entreprises ont été contactées :&lt;br /&gt;
* Festo&lt;br /&gt;
* Wago&lt;br /&gt;
* Schneider Electronics (qui ne se sont pas montrés intéressés).&lt;br /&gt;
&lt;br /&gt;
Festo a proposé du matériel haut de gamme et monté sur mesure, incluant un service technique dédié à Polytech, ce qui se voulait rassurant, mais qui ne nous intéressait pas dans le cadre du projet (ils prévoyaient en effet de développer le programme à embarquer dans l'automate).&lt;br /&gt;
Wago a proposé du matériel à monter nous même mais 4000€ de moins que Festo. Au final, un ingénieur Wago est venu une journée expliquer comment l'automate fonctionnait et l'utilisation des bibliothèque du matériel.&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : dans cette partie nous avons été confronté à un choix de fournisseur, établissement de bon de commande et étude des datasheets afin de savoir quel matériel on allait recevoir et surtout bien choisir le fournisseur.&lt;br /&gt;
&lt;br /&gt;
===Partie Théorique===&lt;br /&gt;
&lt;br /&gt;
Cette partie du projet avait pour but de démontrer la faisabilité du projet et le gain réel (économique et en confort) de l'utilisation du système qui en résulterait.&lt;br /&gt;
L'objectif principale était de modéliser les échanges mécano-thermo-hydroliques mis en jeux dans un système de chauffage afin de pouvoir modéliser l'effet d'une commande régulée.&lt;br /&gt;
&lt;br /&gt;
===Partie Pratique 1 : Mise en place du programme embarqué===&lt;br /&gt;
&lt;br /&gt;
===Partie Pratique 2 : Programmation des interfaces graphiques===&lt;br /&gt;
&lt;br /&gt;
Durant cette partie du projet nous tentons de mettre en place une interface graphique permettant de visualiser les différentes erreurs que pourrait rencontrer le système pour fonctionner (supervision), et nous allons récupérer les valeurs de température de la pièce ainsi que d'ouverture de la vanne sur les 72 dernières heures.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=16655</id>
		<title>P6 Gestion des flux thermiques du bâtiment Polytech</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=16655"/>
				<updated>2015-02-09T17:20:37Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Déroulement du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Liens ==&lt;br /&gt;
Il vous est possible de visualiser les différents travaux effectués sur le cloud oneDrive au lien suivant : [http://1drv.ms/1pBsiu6 lien OneDrive]&lt;br /&gt;
Il contient notamment les fichiers matlab, le PowerPoint présentation comparatives des offres pour le matériel, les devis et le MS Project contenant l'ensemble des tâches.&lt;br /&gt;
&lt;br /&gt;
== Présentation du projet ==&lt;br /&gt;
===Contexte===&lt;br /&gt;
Ce projet s'inscrit dans la continuité d'un projet entamé en IMA4 et qui consiste en la réalisation d'un système intelligent de régulation des flux thermiques des radiateurs installés à Polytech Lille pour essayer de réduire au maximum les pertes d'énergie engendrées. Il est réalisé dans le cadre du projet de développement durable initié par la direction de l'école.&lt;br /&gt;
===Objectif===&lt;br /&gt;
Réaliser un système intelligent capable de réguler le flux thermique d'un radiateur d'une salle à Polytech Lille, afin de maintenir la température de cette dernière à valeur constante, en prenant compte certains paramètres parmi lesquels: planning des salles, données météo ou température extérieure … , ainsi que les situations: fenêtre ouverte, utilisation imprévue de salle ... .&lt;br /&gt;
&lt;br /&gt;
Le résultat final est un démonstrateur sur la plateforme de test constitué du radiateur équipé de l'électrovanne automatisé. Par ailleurs, une interface de supervision doit être établi, une interface homme-machine à destination des utilisateurs de la salle peut aussi être envisageable.&lt;br /&gt;
===Cahier des charges===&lt;br /&gt;
*Choix logistique et installation de l'équipement: électrovanne, capteurs, API&lt;br /&gt;
&lt;br /&gt;
*Régulation et commande du radiateur : modélisation, simulation, mises en places des algorithmes et implémentation dans l'API&lt;br /&gt;
&lt;br /&gt;
*Supervision : Simulation du système de défaillance et réalisation de l'interface&lt;br /&gt;
&lt;br /&gt;
*Établir la connexion aux données du planning des salles et données météo&lt;br /&gt;
&lt;br /&gt;
*IHM : Réaliser une interface conviviale avec authentification et gestion des modes de chauffage&lt;br /&gt;
&lt;br /&gt;
==Déroulement du projet==&lt;br /&gt;
===Semaine 1 : 15/09 - 21/09===&lt;br /&gt;
* Analyse du projet&lt;br /&gt;
&lt;br /&gt;
* Réalisation du cahiers des charges et définition des taches&lt;br /&gt;
&lt;br /&gt;
* Etudes comparative des différents équipements&lt;br /&gt;
&lt;br /&gt;
* Comparaisons des entreprises collaboratrices&lt;br /&gt;
&lt;br /&gt;
* Etudes des solutions envisagées&lt;br /&gt;
&lt;br /&gt;
===Semaine 2 : 22/09 - 28/09===&lt;br /&gt;
* Réalisation du diagramme Gant du projet &lt;br /&gt;
&lt;br /&gt;
* Commande des composants chez wago&lt;br /&gt;
&lt;br /&gt;
* Communication avec le directeur technique de Polytech pour diverses informations techniques vis-à-vis des radiateurs&lt;br /&gt;
&lt;br /&gt;
* Analyse du système de commande existant ( projet IMA4 )&lt;br /&gt;
&lt;br /&gt;
===Semaine 3 : 29/09 - 05/10===&lt;br /&gt;
* Modélisation du système&lt;br /&gt;
&lt;br /&gt;
* Contact avec WAGO pour le suivi de la commande des pièces&lt;br /&gt;
&lt;br /&gt;
===Partie Commerciale===&lt;br /&gt;
&lt;br /&gt;
Cette partie du projet consistait à créer un appel d'offre pour savoir quelles entreprises seraient intéressées et ce qu'elles pourraient apporter au projet.&lt;br /&gt;
3 entreprises ont été contactées :&lt;br /&gt;
* Festo&lt;br /&gt;
* Wago&lt;br /&gt;
* Schneider Electronics (qui ne se sont pas montrés intéressés).&lt;br /&gt;
&lt;br /&gt;
Festo a proposé du matériel haut de gamme et monté sur mesure, incluant un service technique dédié à Polytech, ce qui se voulait rassurant, mais qui ne nous intéressait pas dans le cadre du projet (ils prévoyaient en effet de développer le programme à embarquer dans l'automate).&lt;br /&gt;
Wago a proposé du matériel à monter nous même mais 4000€ de moins que Festo. Au final, un ingénieur Wago est venu une journée expliquer comment l'automate fonctionnait et l'utilisation des bibliothèque du matériel.&lt;br /&gt;
'''&lt;br /&gt;
Conclusion :''' dans cette partie nous avons été confronté à un choix de fournisseur, établissement de bon de commande et étude des datasheets afin de savoir quel matériel on allait recevoir et surtout bien choisir le fournisseur.&lt;br /&gt;
&lt;br /&gt;
===Partie Théorique===&lt;br /&gt;
&lt;br /&gt;
Cette partie du projet avait pour but de démontrer la faisabilité du projet et le gain réel (économique et en confort) de l'utilisation du système qui en résulterait.&lt;br /&gt;
L'objectif principale était de modéliser les échanges mécano-thermo-hydroliques mis en jeux dans un système de chauffage afin de pouvoir modéliser l'effet d'une commande régulée.&lt;br /&gt;
&lt;br /&gt;
===Partie Pratique 1 : Mise en place du programme embarqué===&lt;br /&gt;
&lt;br /&gt;
===Partie Pratique 2 : Programmation des interfaces graphiques===&lt;br /&gt;
&lt;br /&gt;
Durant cette partie du projet nous tentons de mettre en place une interface graphique permettant de visualiser les différentes erreurs que pourrait rencontrer le système pour fonctionner (supervision), et nous allons récupérer les valeurs de température de la pièce ainsi que d'ouverture de la vanne sur les 72 dernières heures.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Projets_IMA5_2014/2015&amp;diff=15241</id>
		<title>Projets IMA5 2014/2015</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Projets_IMA5_2014/2015&amp;diff=15241"/>
				<updated>2014-12-17T20:50:25Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Répartition des binômes */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Merci de référencer vos pages de projets ici. Merci aussi d'uniformiser vos formats que ce soit en regardant la présentation des projets déjà créés ou en allant modifier le format des précédents si votre façon de faire vous semble la meilleure. Dans tous les cas un minimum de communication entre les binômes est conseillée.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Répartition des binômes ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;lt;table border=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Projet&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Elèves&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Encadrant Ecole&amp;lt;/th&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Rapport décembre&amp;lt;/th&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[P1 Modélisation et commande de l'auto-ignition d'un moteur HCCI]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;Moulé Alexandre / Taché Clément &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; Anne-Lise Gehin / Jean-Yves Dieulot &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[Fichier:Rapport decembre moule tache.pdf]]  &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P5 Filtrage des indicateurs numériques de diagnostic]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; ZIOU Ismaïl / HAMZAOUI Oussama &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Belkacem Ould Bouamama &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:rapport_Z.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;[[P6 Gestion des flux thermiques du bâtiment Polytech]]&amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt;Florian Royer / Zohour Assaieb &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; Belkacem Ould Bouamama &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;td&amp;gt; [[Fichier:Rapport_Intermédiaire_Royer_Assaieb.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
&amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P7 Utilisation d'un Robot Nao pour les enfants autistes]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Rodriguez Loïc/Ismaïl Tahry&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; GAPAS/Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Projetpfenaomi.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P8 Pilulier]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Alexandre Mercier / Emile Pinet&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas VANTROYS / Alexandre BOE &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport decembre PFE pilulier mercier pinet.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P9 Agenda pour personnes non lectrices]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Cédric DESPREZ &amp;amp; Soufiane HADDAOUI &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; GAPAS/Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_MiSoutenance_DESPREZ_HADDAOUI.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P11 Détecteur d'obstacles pour fauteuils électriques]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Geoffrey ROSE / Marjorie TIXIER &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; GAPAS / Blaise Conrard &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P12 Automatiser à l'aide d'une interface LabView la procédure de mesure de conductivité électrique d'un alternateur à griffes]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Hugo FONDU &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Abdelkader Benabou &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:rapport_presoutenance.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P13 Construction d'un support motorisé pour la réalisation des essais de décharges électrostatique]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; JEBBARI Zineb / BEKRAOUI Oumaima &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Nathalie Rolland &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:rapportJebbek.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P21 Balise Bluetooth Low Energy]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Kévin CHALONO / Armagan YAMNAZ&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas VANTROYS &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[ Fichier:ProjetBLE 1 pdf.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P22 Google Glass en logistique ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Jérémy Gondry / Vincent Meunier &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Laurent Grisoni &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_intermediaire_Gondry_Meunier.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P24 Robot de surveillance domestique]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Sébastien DELTOMBE &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Xavier Redon &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;[[Fichier:Rapport_PFE_P24_Deltombe.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P25 SmartMeter]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Thomas Ederlé / Sylvain Fossaert&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Guillaume Renault / Xavier Redon / Alexandre Boé &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:RapportFossaertEderle.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P26 Vehicule Electrique ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Smain Labdouni / Adnane Jaoui &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Arnaud Chielens / Philippe Delarue &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  [[Fichier:RAPPORT_VE_DEC.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P27 Controle Direct de Puissance d'un Convertisseur Matriciel ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Quentin Pesqueux / Nicolas Alexandre &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Philippe Delarue &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;  [[Fichier:PFE_IMA5_MATRIX_CONVERTER_Alexandre_Pesqueux.pdf]]&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P28 Modélisation d'un robot chirurgical déformable pour la simulation et le contrôle]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Charlotte BRICOUT / Nathan MARTIN &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Jérémie DEQUIDT&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P33 Ligthing contactless / &amp;quot;wireless&amp;quot;]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Benjamin Lafit &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Alexandre Boé &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:Rapport_Benjamin_Lafit.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P37 Creation d'un composant d'audit des accès cache mémoire sur un microprocesseur LEON3 simulé en FPGA ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Jérôme Vaessen &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Julien Cartigny / Pierrick Buret &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:Rapport_VAESSEN_presoutenance.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P44 Création d'un systeme domotique sans fil ]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Benoit MALIAR / Thomas MAURICE&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Pierrick BURET / Thomas VANTROYS  &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; [[Fichier:RapportMaliarMauriceDecembre.pdf]] &amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P45 Aide à la navigation d'un véhicule autonome]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Pierre APPERCÉ&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Rochdi MERZOUKI &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P46 Simulation Temps Réel d'un Environnement de Robots Autonomes Logisticiens]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Valentin VERGEZ&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Rochdi MERZOUKI &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P57 CHRU Lille : Smart Picking]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Mathieu Bossennec / Florian Caron&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Gwénaëlle Maton / Alexandre Boé / Thomas Vantroys &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
 &amp;lt;/tr&amp;gt;&lt;br /&gt;
 &amp;lt;tr&amp;gt;&amp;lt;td&amp;gt;[[P59 Assistance globale pour aide au parking]]&amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Mathieu GERIER / Céline LY &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt; Alexandre BOE / Thomas VANTROYS &amp;lt;/td&amp;gt;&lt;br /&gt;
    &amp;lt;td&amp;gt;&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;/tr&amp;gt;&lt;br /&gt;
&amp;lt;/table&amp;gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Rapport_Interm%C3%A9diaire_Royer_Assaieb.pdf&amp;diff=15240</id>
		<title>Fichier:Rapport Intermédiaire Royer Assaieb.pdf</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Rapport_Interm%C3%A9diaire_Royer_Assaieb.pdf&amp;diff=15240"/>
				<updated>2014-12-17T20:48:24Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=14230</id>
		<title>P6 Gestion des flux thermiques du bâtiment Polytech</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=14230"/>
				<updated>2014-10-13T12:26:15Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Liens */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Liens ==&lt;br /&gt;
Il vous est possible de visualiser les différents travaux effectués sur le cloud oneDrive au lien suivant : [http://1drv.ms/1pBsiu6 lien OneDrive]&lt;br /&gt;
Il contient notamment les fichiers matlab, le PowerPoint présentation comparatives des offres pour le matériel, les devis et le MS Project contenant l'ensemble des tâches.&lt;br /&gt;
&lt;br /&gt;
== Présentation du projet ==&lt;br /&gt;
===Contexte===&lt;br /&gt;
Ce projet s'inscrit dans la continuité d'un projet entamé en IMA4 et qui consiste en la réalisation d'un système intelligent de régulation des flux thermiques des radiateurs installés à Polytech Lille pour essayer de réduire au maximum les pertes d'énergie engendrées. Il est réalisé dans le cadre du projet de développement durable initié par la direction de l'école.&lt;br /&gt;
===Objectif===&lt;br /&gt;
Réaliser un système intelligent capable de réguler le flux thermique d'un radiateur d'une salle à Polytech Lille, afin de maintenir la température de cette dernière à valeur constante, en prenant compte certains paramètres parmi lesquels: planning des salles, données météo ou température extérieure … , ainsi que les situations: fenêtre ouverte, utilisation imprévue de salle ... .&lt;br /&gt;
&lt;br /&gt;
Le résultat final est un démonstrateur sur la plateforme de test constitué du radiateur équipé de l'électrovanne automatisé. Par ailleurs, une interface de supervision doit être établi, une interface homme-machine à destination des utilisateurs de la salle peut aussi être envisageable.&lt;br /&gt;
===Cahier des charges===&lt;br /&gt;
*Choix logistique et installation de l'équipement: électrovanne, capteurs, API&lt;br /&gt;
&lt;br /&gt;
*Régulation et commande du radiateur : modélisation, simulation, mises en places des algorithmes et implémentation dans l'API&lt;br /&gt;
&lt;br /&gt;
*Supervision : Simulation du système de défaillance et réalisation de l'interface&lt;br /&gt;
&lt;br /&gt;
*Établir la connexion aux données du planning des salles et données météo&lt;br /&gt;
&lt;br /&gt;
*IHM : Réaliser une interface conviviale avec authentification et gestion des modes de chauffage&lt;br /&gt;
&lt;br /&gt;
==Déroulement du projet==&lt;br /&gt;
===Semaine 1 : 15/09 - 21/09===&lt;br /&gt;
* Analyse du projet&lt;br /&gt;
&lt;br /&gt;
* Réalisation du cahiers des charges et définition des taches&lt;br /&gt;
&lt;br /&gt;
* Etudes comparative des différents équipements&lt;br /&gt;
&lt;br /&gt;
* Comparaisons des entreprises collaboratrices&lt;br /&gt;
&lt;br /&gt;
* Etudes des solutions envisagées&lt;br /&gt;
&lt;br /&gt;
===Semaine 2 : 22/09 - 28/09===&lt;br /&gt;
* Réalisation du diagramme Gant du projet &lt;br /&gt;
&lt;br /&gt;
* Commande des composants chez wago&lt;br /&gt;
&lt;br /&gt;
* Communication avec le directeur technique de Polytech pour diverses informations techniques vis-à-vis des radiateurs&lt;br /&gt;
&lt;br /&gt;
* Analyse du système de commande existant ( projet IMA4 )&lt;br /&gt;
&lt;br /&gt;
===Semaine 3 : 29/09 - 05/10===&lt;br /&gt;
* Modélisation du système&lt;br /&gt;
&lt;br /&gt;
* Contact avec WAGO pour le suivi de la commande des pièces&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=14229</id>
		<title>P6 Gestion des flux thermiques du bâtiment Polytech</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=P6_Gestion_des_flux_thermiques_du_b%C3%A2timent_Polytech&amp;diff=14229"/>
				<updated>2014-10-13T12:24:32Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Présentation du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Liens ==&lt;br /&gt;
Il vous est possible de visualiser les différents travaux effectués sur le cloud oneDrive au lien suivant : [http://1drv.ms/1pBsiu6]&lt;br /&gt;
Il contient notamment les fichiers matlab, le PowerPoint présentation comparatives des offres pour le matériel, les devis et le MS Project contenant l'ensemble des tâches.&lt;br /&gt;
&lt;br /&gt;
== Présentation du projet ==&lt;br /&gt;
===Contexte===&lt;br /&gt;
Ce projet s'inscrit dans la continuité d'un projet entamé en IMA4 et qui consiste en la réalisation d'un système intelligent de régulation des flux thermiques des radiateurs installés à Polytech Lille pour essayer de réduire au maximum les pertes d'énergie engendrées. Il est réalisé dans le cadre du projet de développement durable initié par la direction de l'école.&lt;br /&gt;
===Objectif===&lt;br /&gt;
Réaliser un système intelligent capable de réguler le flux thermique d'un radiateur d'une salle à Polytech Lille, afin de maintenir la température de cette dernière à valeur constante, en prenant compte certains paramètres parmi lesquels: planning des salles, données météo ou température extérieure … , ainsi que les situations: fenêtre ouverte, utilisation imprévue de salle ... .&lt;br /&gt;
&lt;br /&gt;
Le résultat final est un démonstrateur sur la plateforme de test constitué du radiateur équipé de l'électrovanne automatisé. Par ailleurs, une interface de supervision doit être établi, une interface homme-machine à destination des utilisateurs de la salle peut aussi être envisageable.&lt;br /&gt;
===Cahier des charges===&lt;br /&gt;
*Choix logistique et installation de l'équipement: électrovanne, capteurs, API&lt;br /&gt;
&lt;br /&gt;
*Régulation et commande du radiateur : modélisation, simulation, mises en places des algorithmes et implémentation dans l'API&lt;br /&gt;
&lt;br /&gt;
*Supervision : Simulation du système de défaillance et réalisation de l'interface&lt;br /&gt;
&lt;br /&gt;
*Établir la connexion aux données du planning des salles et données météo&lt;br /&gt;
&lt;br /&gt;
*IHM : Réaliser une interface conviviale avec authentification et gestion des modes de chauffage&lt;br /&gt;
&lt;br /&gt;
==Déroulement du projet==&lt;br /&gt;
===Semaine 1 : 15/09 - 21/09===&lt;br /&gt;
* Analyse du projet&lt;br /&gt;
&lt;br /&gt;
* Réalisation du cahiers des charges et définition des taches&lt;br /&gt;
&lt;br /&gt;
* Etudes comparative des différents équipements&lt;br /&gt;
&lt;br /&gt;
* Comparaisons des entreprises collaboratrices&lt;br /&gt;
&lt;br /&gt;
* Etudes des solutions envisagées&lt;br /&gt;
&lt;br /&gt;
===Semaine 2 : 22/09 - 28/09===&lt;br /&gt;
* Réalisation du diagramme Gant du projet &lt;br /&gt;
&lt;br /&gt;
* Commande des composants chez wago&lt;br /&gt;
&lt;br /&gt;
* Communication avec le directeur technique de Polytech pour diverses informations techniques vis-à-vis des radiateurs&lt;br /&gt;
&lt;br /&gt;
* Analyse du système de commande existant ( projet IMA4 )&lt;br /&gt;
&lt;br /&gt;
===Semaine 3 : 29/09 - 05/10===&lt;br /&gt;
* Modélisation du système&lt;br /&gt;
&lt;br /&gt;
* Contact avec WAGO pour le suivi de la commande des pièces&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=13850</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=13850"/>
				<updated>2014-06-18T15:44:35Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;include nopre noesc src=&amp;quot;/home/pedago/pimasc/include/video-MesureConsommation-iframe.html&amp;quot; /&amp;gt;&lt;br /&gt;
__TOC__&lt;br /&gt;
&amp;lt;br style=&amp;quot;clear: both;&amp;quot;&amp;gt;&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables : [[Fichier:Codes_finaux.zip]]&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;Commandé&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;Commandé&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;quot;&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== semaine 1 Mars ====&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
==== semaine 2 Mars ====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
==== semaine 3 Mars ====&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
==== semaine 4 de Mars ====&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
==== première semaine de Avril ====&lt;br /&gt;
&lt;br /&gt;
===== Le design de la carte =====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie Module de chauffage ===&lt;br /&gt;
&lt;br /&gt;
Cette partie a été traité sur les 3 dernières semaines du projet en parallèle avec la partie IHM et Réseau de Capteur.&lt;br /&gt;
Nous avons élaboré une carte sur laquelle se branchera le réseau EDF, le radiateur et la consigne délivrée par une carte similaire à celle cu capteur mais sans celui-ci.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:CommandeRad.jpg]]&lt;br /&gt;
&lt;br /&gt;
La carte sera aussi capable de ce servir du réseau EDF pour alimenter le µContrôleur, nous avons donc prévu une alimentation (de type transformateur) pour passer du 220V AC à 3.3V DC. Pour plus de sécurité, il est important d'avoir un régulateur de tension en aval, d'où le régulateur sur le module capteur (Cf. Partie réseaux de capteurs).&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT-correct.JPG]]&lt;br /&gt;
&lt;br /&gt;
Fonctionnement de la carte :&lt;br /&gt;
* Alimentation du transformateur par la phase et le neutre&lt;br /&gt;
* Un fusible est placé sur la phase en cas de pépins&lt;br /&gt;
* En parallèle du 220V on alimente aussi :&lt;br /&gt;
** Le radiateur (Phase, Neutre et Terre)&lt;br /&gt;
** L'optocoupleur (sur les broches 4 et 5) qui n'est rien d'autre qu'un interrupteur.&lt;br /&gt;
* Les Pins 7 et 9 de l'alim permettent d'alimenter le µC en +3.3V.&lt;br /&gt;
* Le PIN C de la partie Ultra Basse Tension (UBT) est un PIN d'entré ici (et de sortie %au µC). Ce PIN détermine si la Diode de l'optocoupleur sera allumée ou éteinte.&lt;br /&gt;
* Concernant l'optocoupleur : Il s'agit d'un composant permettant de bien distinguer la partie UBT de la carte, de la partie BT. Le photoTriac n'est passant que si la diode (PIN 1 et 2) est allumée.&lt;br /&gt;
* L'optocoupleur ne supportant pas les courants élevés (limité à 1A), on utilise un triac de puissance (20A sur 600V). La gâche en sortie de l'optocoupleur est donc soit à 0A soit à +8mA). Sur 0, le triac n'est pas passant, sur 8mA, il est passant.&lt;br /&gt;
&lt;br /&gt;
On obtient alors soit aucun signal (marche) sur le fil pilote, soit un signal pleine alternance (arrêt).&lt;br /&gt;
&lt;br /&gt;
N.B: Une erreur de conception : La gâche du triac de puissance alimentée par un voltage de 3.3V, la masse est &amp;quot;flottante&amp;quot; dans ce cas, le Triac est tjs à l'état bas. De plus le circuit UBT et BT ne sont pas séparé, l'optocoupleur ne sert à rien...&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT.JPG]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Bilan ==&lt;br /&gt;
Le module capteur envoie régulièrement des informations à destination de la Raspberry, qui est capable de les&lt;br /&gt;
traiter. Il est également ajouté dans la Base de Donnée sur intervention de l'utilisateur (appui d'un bouton poussoir sur un module).&lt;br /&gt;
La Raspberry peut envoyer et recevoir des informations avec les modules chauffages et capteurs.&lt;br /&gt;
Mais le code de réception/interpretation d'une trame API du coté Arduino reste à peaufiner, (ils ne donnent pas encore&lt;br /&gt;
,dans certains cas, des résultats constamment exploitables).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
= Matériel récupéré =&lt;br /&gt;
&lt;br /&gt;
 * 6 arduino UNO&lt;br /&gt;
 * 8 xbee&lt;br /&gt;
 * 3 adaptateurs simple&lt;br /&gt;
 * 1 adaptateur usb&lt;br /&gt;
 * 3 shield xbee &lt;br /&gt;
 * 1 raspberry&lt;br /&gt;
 * 1 carte &amp;quot;maison&amp;quot; pour le projet&lt;br /&gt;
 * 1 &amp;quot;boitier&amp;quot; secteur/banane&lt;br /&gt;
 * 1 modem/routeur WiFi ADSL&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=13849</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=13849"/>
				<updated>2014-06-18T15:43:50Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;include nopre noesc src=&amp;quot;/home/pedago/pimasc/include/video-MesureConsommation-iframe.html&amp;quot; /&amp;gt;&lt;br /&gt;
__TOC__&lt;br /&gt;
&amp;lt;br style=&amp;quot;clear: both;&amp;quot;&amp;gt;&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables : [[Fichier:Codes_finaux.zip]]&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;Commandé&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;Commandé&lt;br /&gt;
|&amp;lt;font color=&amp;quot;blue&amp;gt;RENDU&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== semaine 1 Mars ====&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
==== semaine 2 Mars ====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
==== semaine 3 Mars ====&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
==== semaine 4 de Mars ====&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
==== première semaine de Avril ====&lt;br /&gt;
&lt;br /&gt;
===== Le design de la carte =====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie Module de chauffage ===&lt;br /&gt;
&lt;br /&gt;
Cette partie a été traité sur les 3 dernières semaines du projet en parallèle avec la partie IHM et Réseau de Capteur.&lt;br /&gt;
Nous avons élaboré une carte sur laquelle se branchera le réseau EDF, le radiateur et la consigne délivrée par une carte similaire à celle cu capteur mais sans celui-ci.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:CommandeRad.jpg]]&lt;br /&gt;
&lt;br /&gt;
La carte sera aussi capable de ce servir du réseau EDF pour alimenter le µContrôleur, nous avons donc prévu une alimentation (de type transformateur) pour passer du 220V AC à 3.3V DC. Pour plus de sécurité, il est important d'avoir un régulateur de tension en aval, d'où le régulateur sur le module capteur (Cf. Partie réseaux de capteurs).&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT-correct.JPG]]&lt;br /&gt;
&lt;br /&gt;
Fonctionnement de la carte :&lt;br /&gt;
* Alimentation du transformateur par la phase et le neutre&lt;br /&gt;
* Un fusible est placé sur la phase en cas de pépins&lt;br /&gt;
* En parallèle du 220V on alimente aussi :&lt;br /&gt;
** Le radiateur (Phase, Neutre et Terre)&lt;br /&gt;
** L'optocoupleur (sur les broches 4 et 5) qui n'est rien d'autre qu'un interrupteur.&lt;br /&gt;
* Les Pins 7 et 9 de l'alim permettent d'alimenter le µC en +3.3V.&lt;br /&gt;
* Le PIN C de la partie Ultra Basse Tension (UBT) est un PIN d'entré ici (et de sortie %au µC). Ce PIN détermine si la Diode de l'optocoupleur sera allumée ou éteinte.&lt;br /&gt;
* Concernant l'optocoupleur : Il s'agit d'un composant permettant de bien distinguer la partie UBT de la carte, de la partie BT. Le photoTriac n'est passant que si la diode (PIN 1 et 2) est allumée.&lt;br /&gt;
* L'optocoupleur ne supportant pas les courants élevés (limité à 1A), on utilise un triac de puissance (20A sur 600V). La gâche en sortie de l'optocoupleur est donc soit à 0A soit à +8mA). Sur 0, le triac n'est pas passant, sur 8mA, il est passant.&lt;br /&gt;
&lt;br /&gt;
On obtient alors soit aucun signal (marche) sur le fil pilote, soit un signal pleine alternance (arrêt).&lt;br /&gt;
&lt;br /&gt;
N.B: Une erreur de conception : La gâche du triac de puissance alimentée par un voltage de 3.3V, la masse est &amp;quot;flottante&amp;quot; dans ce cas, le Triac est tjs à l'état bas. De plus le circuit UBT et BT ne sont pas séparé, l'optocoupleur ne sert à rien...&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT.JPG]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Bilan ==&lt;br /&gt;
Le module capteur envoie régulièrement des informations à destination de la Raspberry, qui est capable de les&lt;br /&gt;
traiter. Il est également ajouté dans la Base de Donnée sur intervention de l'utilisateur (appui d'un bouton poussoir sur un module).&lt;br /&gt;
La Raspberry peut envoyer et recevoir des informations avec les modules chauffages et capteurs.&lt;br /&gt;
Mais le code de réception/interpretation d'une trame API du coté Arduino reste à peaufiner, (ils ne donnent pas encore&lt;br /&gt;
,dans certains cas, des résultats constamment exploitables).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
= Matériel récupéré =&lt;br /&gt;
&lt;br /&gt;
 * 6 arduino UNO&lt;br /&gt;
 * 8 xbee&lt;br /&gt;
 * 3 adaptateurs simple&lt;br /&gt;
 * 1 adaptateur usb&lt;br /&gt;
 * 3 shield xbee &lt;br /&gt;
 * 1 raspberry&lt;br /&gt;
 * 1 carte &amp;quot;maison&amp;quot; pour le projet&lt;br /&gt;
 * 1 &amp;quot;boitier&amp;quot; secteur/banane&lt;br /&gt;
 * 1 modem/routeur WiFi ADSL&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=13835</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=13835"/>
				<updated>2014-06-17T19:38:18Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Fichiers */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&amp;lt;include nopre noesc src=&amp;quot;/home/pedago/pimasc/include/video-MesureConsommation-iframe.html&amp;quot; /&amp;gt;&lt;br /&gt;
__TOC__&lt;br /&gt;
&amp;lt;br style=&amp;quot;clear: both;&amp;quot;&amp;gt;&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables : [[Fichier:Codes_finaux.zip]]&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== semaine 1 Mars ====&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
==== semaine 2 Mars ====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
==== semaine 3 Mars ====&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
==== semaine 4 de Mars ====&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
==== première semaine de Avril ====&lt;br /&gt;
&lt;br /&gt;
===== Le design de la carte =====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie Module de chauffage ===&lt;br /&gt;
&lt;br /&gt;
Cette partie a été traité sur les 3 dernières semaines du projet en parallèle avec la partie IHM et Réseau de Capteur.&lt;br /&gt;
Nous avons élaboré une carte sur laquelle se branchera le réseau EDF, le radiateur et la consigne délivrée par une carte similaire à celle cu capteur mais sans celui-ci.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:CommandeRad.jpg]]&lt;br /&gt;
&lt;br /&gt;
La carte sera aussi capable de ce servir du réseau EDF pour alimenter le µContrôleur, nous avons donc prévu une alimentation (de type transformateur) pour passer du 220V AC à 3.3V DC. Pour plus de sécurité, il est important d'avoir un régulateur de tension en aval, d'où le régulateur sur le module capteur (Cf. Partie réseaux de capteurs).&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT-correct.JPG]]&lt;br /&gt;
&lt;br /&gt;
Fonctionnement de la carte :&lt;br /&gt;
* Alimentation du transformateur par la phase et le neutre&lt;br /&gt;
* Un fusible est placé sur la phase en cas de pépins&lt;br /&gt;
* En parallèle du 220V on alimente aussi :&lt;br /&gt;
** Le radiateur (Phase, Neutre et Terre)&lt;br /&gt;
** L'optocoupleur (sur les broches 4 et 5) qui n'est rien d'autre qu'un interrupteur.&lt;br /&gt;
* Les Pins 7 et 9 de l'alim permettent d'alimenter le µC en +3.3V.&lt;br /&gt;
* Le PIN C de la partie Ultra Basse Tension (UBT) est un PIN d'entré ici (et de sortie %au µC). Ce PIN détermine si la Diode de l'optocoupleur sera allumée ou éteinte.&lt;br /&gt;
* Concernant l'optocoupleur : Il s'agit d'un composant permettant de bien distinguer la partie UBT de la carte, de la partie BT. Le photoTriac n'est passant que si la diode (PIN 1 et 2) est allumée.&lt;br /&gt;
* L'optocoupleur ne supportant pas les courants élevés (limité à 1A), on utilise un triac de puissance (20A sur 600V). La gâche en sortie de l'optocoupleur est donc soit à 0A soit à +8mA). Sur 0, le triac n'est pas passant, sur 8mA, il est passant.&lt;br /&gt;
&lt;br /&gt;
On obtient alors soit aucun signal (marche) sur le fil pilote, soit un signal pleine alternance (arrêt).&lt;br /&gt;
&lt;br /&gt;
N.B: Une erreur de conception : La gâche du triac de puissance alimentée par un voltage de 3.3V, la masse est &amp;quot;flottante&amp;quot; dans ce cas, le Triac est tjs à l'état bas. De plus le circuit UBT et BT ne sont pas séparé, l'optocoupleur ne sert à rien...&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT.JPG]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Bilan ==&lt;br /&gt;
Le module capteur envoie régulièrement des informations à destination de la Raspberry, qui est capable de les&lt;br /&gt;
traiter. Il est également ajouté dans la Base de Donnée sur intervention de l'utilisateur (appui d'un bouton poussoir sur un module).&lt;br /&gt;
La Raspberry peut envoyer et recevoir des informations avec les modules chauffages et capteurs.&lt;br /&gt;
Mais le code de réception/interpretation d'une trame API du coté Arduino reste à peaufiner, (ils ne donnent pas encore&lt;br /&gt;
,dans certains cas, des résultats constamment exploitables).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
= Matériel récupéré =&lt;br /&gt;
&lt;br /&gt;
 * 6 arduino UNO&lt;br /&gt;
 * 8 xbee&lt;br /&gt;
 * 3 adaptateurs simple&lt;br /&gt;
 * 1 adaptateur usb&lt;br /&gt;
 * 3 shield xbee &lt;br /&gt;
 * 1 raspberry&lt;br /&gt;
 * 1 carte &amp;quot;maison&amp;quot; pour le projet&lt;br /&gt;
 * 1 &amp;quot;boitier&amp;quot; secteur/banane&lt;br /&gt;
 * 1 modem/routeur WiFi ADSL&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Codes_finaux.zip&amp;diff=13834</id>
		<title>Fichier:Codes finaux.zip</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Codes_finaux.zip&amp;diff=13834"/>
				<updated>2014-06-17T19:31:43Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : a téléversé une nouvelle version de « Fichier:Codes finaux.zip » : Version du 23 avril 2014 à 20:17 rétablie&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Codes_finaux.zip&amp;diff=13833</id>
		<title>Fichier:Codes finaux.zip</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Codes_finaux.zip&amp;diff=13833"/>
				<updated>2014-06-17T19:31:10Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : a téléversé une nouvelle version de « Fichier:Codes finaux.zip »&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Discussion_utilisateur:Froyer&amp;diff=13823</id>
		<title>Discussion utilisateur:Froyer</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Discussion_utilisateur:Froyer&amp;diff=13823"/>
				<updated>2014-06-16T22:17:23Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : Page créée avec « Erreur lors du dépôt à la date butoir, désolé pour le désagrément »&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Erreur lors du dépôt à la date butoir, désolé pour le désagrément&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Royer-Gondry.pdf&amp;diff=13822</id>
		<title>Fichier:Royer-Gondry.pdf</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Royer-Gondry.pdf&amp;diff=13822"/>
				<updated>2014-06-16T22:15:48Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12552</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12552"/>
				<updated>2014-04-22T12:33:31Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Introduction */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables :&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== semaine 1 Mars ====&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
==== semaine 2 Mars ====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
==== semaine 3 Mars ====&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
==== semaine 4 de Mars ====&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
==== première semaine de Avril ====&lt;br /&gt;
&lt;br /&gt;
===== Le design de la carte =====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie Module de chauffage ===&lt;br /&gt;
&lt;br /&gt;
Cette partie a été traité sur les 3 dernières semaines du projet en parallèle avec la partie IHM et Réseau de Capteur.&lt;br /&gt;
Nous avons élaboré une carte sur laquelle se branchera le réseau EDF, le radiateur et la consigne délivrée par une carte similaire à celle cu capteur mais sans celui-ci.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:CommandeRad.jpg]]&lt;br /&gt;
&lt;br /&gt;
La carte sera aussi capable de ce servir du réseau EDF pour alimenter le µContrôleur, nous avons donc prévu une alimentation (de type transformateur) pour passer du 220V AC à 3.3V DC. Pour plus de sécurité, il est important d'avoir un régulateur de tension en aval, d'où le régulateur sur le module capteur (Cf. Partie réseaux de capteurs).&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT-correct.JPG]]&lt;br /&gt;
&lt;br /&gt;
Fonctionnement de la carte :&lt;br /&gt;
* Alimentation du transformateur par la phase et le neutre&lt;br /&gt;
* Un fusible est placé sur la phase en cas de pépins&lt;br /&gt;
* En parallèle du 220V on alimente aussi :&lt;br /&gt;
** Le radiateur (Phase, Neutre et Terre)&lt;br /&gt;
** L'optocoupleur (sur les broches 4 et 5) qui n'est rien d'autre qu'un interrupteur.&lt;br /&gt;
* Les Pins 7 et 9 de l'alim permettent d'alimenter le µC en +3.3V.&lt;br /&gt;
* Le PIN C de la partie Ultra Basse Tension (UBT) est un PIN d'entré ici (et de sortie %au µC). Ce PIN détermine si la Diode de l'optocoupleur sera allumée ou éteinte.&lt;br /&gt;
* Concernant l'optocoupleur : Il s'agit d'un composant permettant de bien distinguer la partie UBT de la carte, de la partie BT. Le photoTriac n'est passant que si la diode (PIN 1 et 2) est allumée.&lt;br /&gt;
* L'optocoupleur ne supportant pas les courants élevés (limité à 1A), on utilise un triac de puissance (20A sur 600V). La gâche en sortie de l'optocoupleur est donc soit à 0A soit à +8mA). Sur 0, le triac n'est pas passant, sur 8mA, il est passant.&lt;br /&gt;
&lt;br /&gt;
On obtient alors soit aucun signal (marche) sur le fil pilote, soit un signal pleine alternance (arrêt).&lt;br /&gt;
&lt;br /&gt;
N.B: Une erreur de conception : La gâche du triac de puissance alimentée par un voltage de 3.3V, la masse est &amp;quot;flottante&amp;quot; dans ce cas, le Triac est tjs à l'état bas. De plus le circuit UBT et BT ne sont pas séparé, l'optocoupleur ne sert à rien...&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT.JPG]]&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12551</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12551"/>
				<updated>2014-04-22T12:32:01Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Avancement du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables :&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== semaine 1 Mars ====&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
==== semaine 2 Mars ====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
==== semaine 3 Mars ====&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
==== semaine 4 de Mars ====&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
==== première semaine de Avril ====&lt;br /&gt;
&lt;br /&gt;
===== Le design de la carte =====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie Module de chauffage ===&lt;br /&gt;
&lt;br /&gt;
Cette partie a été traité sur les 3 dernières semaines du projet en parallèle avec la partie IHM et Réseau de Capteur.&lt;br /&gt;
Nous avons élaboré une carte sur laquelle se branchera le réseau EDF, le radiateur et la consigne délivrée par une carte similaire à celle cu capteur mais sans celui-ci.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:CommandeRad.jpg]]&lt;br /&gt;
&lt;br /&gt;
La carte sera aussi capable de ce servir du réseau EDF pour alimenter le µContrôleur, nous avons donc prévu une alimentation (de type transformateur) pour passer du 220V AC à 3.3V DC. Pour plus de sécurité, il est important d'avoir un régulateur de tension en aval, d'où le régulateur sur le module capteur (Cf. Partie réseaux de capteurs).&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT-correct.JPG]]&lt;br /&gt;
&lt;br /&gt;
Fonctionnement de la carte :&lt;br /&gt;
* Alimentation du transformateur par la phase et le neutre&lt;br /&gt;
* Un fusible est placé sur la phase en cas de pépins&lt;br /&gt;
* En parallèle du 220V on alimente aussi :&lt;br /&gt;
** Le radiateur (Phase, Neutre et Terre)&lt;br /&gt;
** L'optocoupleur (sur les broches 4 et 5) qui n'est rien d'autre qu'un interrupteur.&lt;br /&gt;
* Les Pins 7 et 9 de l'alim permettent d'alimenter le µC en +3.3V.&lt;br /&gt;
* Le PIN C de la partie Ultra Basse Tension (UBT) est un PIN d'entré ici (et de sortie %au µC). Ce PIN détermine si la Diode de l'optocoupleur sera allumée ou éteinte.&lt;br /&gt;
* Concernant l'optocoupleur : Il s'agit d'un composant permettant de bien distinguer la partie UBT de la carte, de la partie BT. Le photoTriac n'est passant que si la diode (PIN 1 et 2) est allumée.&lt;br /&gt;
* L'optocoupleur ne supportant pas les courants élevés (limité à 1A), on utilise un triac de puissance (20A sur 600V). La gâche en sortie de l'optocoupleur est donc soit à 0A soit à +8mA). Sur 0, le triac n'est pas passant, sur 8mA, il est passant.&lt;br /&gt;
&lt;br /&gt;
On obtient alors soit aucun signal (marche) sur le fil pilote, soit un signal pleine alternance (arrêt).&lt;br /&gt;
&lt;br /&gt;
N.B: Une erreur de conception : La gâche du triac de puissance alimentée par un voltage de 3.3V, la masse est &amp;quot;flottante&amp;quot; dans ce cas, le Triac est tjs à l'état bas. De plus le circuit UBT et BT ne sont pas séparé, l'optocoupleur ne sert à rien...&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic-CBT.JPG]]&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Schematic-CBT.JPG&amp;diff=12550</id>
		<title>Fichier:Schematic-CBT.JPG</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Schematic-CBT.JPG&amp;diff=12550"/>
				<updated>2014-04-22T12:31:49Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Schematic-CBT-correct.JPG&amp;diff=12548</id>
		<title>Fichier:Schematic-CBT-correct.JPG</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Schematic-CBT-correct.JPG&amp;diff=12548"/>
				<updated>2014-04-22T12:17:39Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:CommandeRad.jpg&amp;diff=12547</id>
		<title>Fichier:CommandeRad.jpg</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:CommandeRad.jpg&amp;diff=12547"/>
				<updated>2014-04-22T12:13:06Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12546</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12546"/>
				<updated>2014-04-22T12:06:55Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Avancement du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables :&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==== semaine 1 Mars ====&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
==== semaine 2 Mars ====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
==== semaine 3 Mars ====&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
==== semaine 4 de Mars ====&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
==== première semaine de Avril ====&lt;br /&gt;
&lt;br /&gt;
===== Le design de la carte =====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12442</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12442"/>
				<updated>2014-04-16T11:44:56Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Objectifs principaux */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables :&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Avoir une supervision du système. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== semaine 1 Mars ===&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
=== semaine 2 Mars ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
=== semaine 3 Mars ===&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
=== semaine 4 de Mars ===&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
=== première semaine de Avril ===&lt;br /&gt;
&lt;br /&gt;
==== Le design de la carte ====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12420</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12420"/>
				<updated>2014-04-16T01:17:57Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Fichiers */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
* IHM visible sur http://renard.familyds.com/projet&lt;br /&gt;
* Codes téléchargeables :&lt;br /&gt;
* Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== semaine 1 Mars ===&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
=== semaine 2 Mars ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
=== semaine 3 Mars ===&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
=== semaine 4 de Mars ===&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
=== première semaine de Avril ===&lt;br /&gt;
&lt;br /&gt;
==== Le design de la carte ====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12419</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12419"/>
				<updated>2014-04-16T01:17:21Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Introduction */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
== Fichiers ==&lt;br /&gt;
&lt;br /&gt;
IHM visible sur [http://renard.familyds.com/projet]&lt;br /&gt;
Codes téléchargeables :&lt;br /&gt;
Rapport écrit : [[Fichier:Royer-Gondry.pdf]]&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== semaine 1 Mars ===&lt;br /&gt;
&lt;br /&gt;
	Souhaitant créer un réseau maillé, notre choix s’est porté sur l’utilisation de Xbee Serie 2.&lt;br /&gt;
Un réseau Xbee 2 se définit par un channel et un PAN ID (Personal Area Network).&lt;br /&gt;
Les Xbee peuvent y jouer 3 types de rôle : Coordinateur, Routeur, et End Device (dispositif en fin de ligne). &lt;br /&gt;
&lt;br /&gt;
*Le Coordinateur est «  le médecin » du réseau, c’est celui qui :&lt;br /&gt;
**Attribue les adresses logiques.	&lt;br /&gt;
**Assaissinit le réseau, lorsqu’un périphérique, il redistribue son adresse logique à un autre périphérique existant et lui attribue une autre adresse lorsqu’il rentre dans le réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
*Le Routeur envoie des informations le concernant et sert de relais pour les End Device qui sont trop éloignés des autres modules pour communiquer avec eux.&lt;br /&gt;
&lt;br /&gt;
*Le End Device, joue un rôle mineur dans le réseau il envoie ses propres messages router ceux des autres.&lt;br /&gt;
&lt;br /&gt;
Nous avons décidé que les modules chauffage seront des routeurs, (de par leur rôle les routeurs ne sont pas censés être endormis). &lt;br /&gt;
Les modules capteur seront des end devices. La Raspberry sera le coordinateur.&lt;br /&gt;
&lt;br /&gt;
Durant les séances précédentes, nous travaillons avec les Xbee Series 1, et avions commencé à expérimenter les communications en mode transparent, et à nous pencher sur les communications en API.&lt;br /&gt;
	Nous recevons la commande des Xbee Series 2, il faut flasher leur firmware, si nous voulons pouvoir communiquer avec ces modules en API.&lt;br /&gt;
Pour cela nous utilisons X-CTU, un utilitaire jouant le rôle de gestionnaire de firmware, de moniteur série et de configuration des modules Xbee.&lt;br /&gt;
Un choix s'impose : les modules ne peuvent pas être utilisé à la fois avec des commandes AT ou à la fois avec des commandes API.&lt;br /&gt;
Nous choisissons de flasher les modules avec des firmwares exclusivement API.  &lt;br /&gt;
&lt;br /&gt;
Pour la configuration des Xbee, les principaux registres qui ont été concernés sont&lt;br /&gt;
&lt;br /&gt;
*registre SM=1&lt;br /&gt;
         Sleep Mode veille activé sur stimulus de la broche DTR)&lt;br /&gt;
*registre ID=222&lt;br /&gt;
	 Configure le PAN ID : Personal Area Network Identifiant, indique l'Id du réseau que le module rejoindra de préférence )&lt;br /&gt;
*registre CH&lt;br /&gt;
	 Le Channel, sur les Series 2, ce registre est en lecture seule, le coordinateur scanne le réseau et choisi le canal optimal, les&lt;br /&gt;
	autres Xbee le rejoindront sur son canal, grâce au choix du PAN ID (222) et à la présence d'un coordinateur sur le réseau&lt;br /&gt;
Tout ce qui concerne les adresses MY, sont des adresses logiques donc nous n'y avons pas accès, étant donné que c'est le coordinateur qui s'occupe de les gérer.&lt;br /&gt;
&lt;br /&gt;
=== semaine 2 Mars ===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Elaboration des fonctions en C et en Arduino permettant l'envoi et la réception de données par trame sur le prototype Arduino et sur la Raspberry.&lt;br /&gt;
Nous avons été ralentis sur cette partie. &lt;br /&gt;
Ces fonctions ne fonctionnaient pas pour plusieurs raisons, d'abord électriques, le Xbee pouvait envoyer mais jamais recevoir, cela venait du fait qu'il était endormi et &lt;br /&gt;
réveillé à une fréquence trés élevé. (les fonctions de mise en veille et de réveil n'étant pas encore utilisée du Xbee)  &lt;br /&gt;
Un montage en strong pull up était indispensable pour réveiller constamment le module Xbee.&lt;br /&gt;
Une autre raison, était la construction de la trame. Il y avait des imperfections dans notre compréhension du protocole.&lt;br /&gt;
&lt;br /&gt;
Comme nous avions l'intention de réaliser une carte du module capteur, nous avancions en parallèle, sur le design de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic premiere version.png|400px]]&lt;br /&gt;
&lt;br /&gt;
=== semaine 3 Mars ===&lt;br /&gt;
&lt;br /&gt;
Aprés avoir des primitives de communications fonctionnelles, nous avons implémenté et tester sur l'Arduino, le mode de Veille Watchdog. L'interruption d'ajout, provoqué par un bouton poussoir, elle permet de réveiller manuellement un module afin d'envoyer, en réaction, un message à destination du coordinateur, ce message lui indique que le module doit être ajouté dans la base de donnée. Cela permet dans une utilisation ultérieure de rafraichir plus vite, la mesure de la température&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
=== semaine 4 de Mars ===&lt;br /&gt;
&lt;br /&gt;
Grâce à l'implémentation de fonctions C d'ajout dans la base de données, au niveau du programme tournant sur la Raspberry,&lt;br /&gt;
le prototype du module de capteur envoie une mesure, et cette mesure est stockée dans la base de donnée.&lt;br /&gt;
La phase de prototype est quasiment finie, tout comme l'essentiel de la partie logicielle.&lt;br /&gt;
Nous rencontrons un problème au niveau de la programmation de l'atmega 328p.&lt;br /&gt;
Nous essayons les solutions suivantes:&lt;br /&gt;
&lt;br /&gt;
Téléverser un programme sur un Arduino Uno utilisé en programmateur ISP et relié à l'atmega328p.&lt;br /&gt;
Téléverser un programme à l'aide d'un programmateur AVR ISP Mkll toujours à partir de l'environnement Arduino sur l'atmega328p.&lt;br /&gt;
Nous décidons alors de programmer un Arduino pour ensuite en retirer l'atmega328P. &lt;br /&gt;
Cependant pour des soucis d'autonomie, nous souhaitons modifier les fusibles &amp;quot;les fuses&amp;quot; pour changer &lt;br /&gt;
la fréquence de fonctionnement ainsi que la clock source. En effet, l'atmega sur un Arduino est configuré pour fonctionner&lt;br /&gt;
avec une clock externe 16MHz.&lt;br /&gt;
Après utilisations d'AVR Burn O Mat et d'AVR studio, deux utilitaires pour uploader et flasher les produits AVR, des messages d'erreurs nous indiquent que la source du problème se situe plutôt du coté de nos drivers USB.&lt;br /&gt;
Après plusieurs téléchargement de drivers et manipulations, il n'y a pas de solution.&lt;br /&gt;
&lt;br /&gt;
Nous incluons alors sur la carte des connecteurs, destinés à la reprogrammation ISP dans le cas, où nous réglerons le problème.&lt;br /&gt;
&lt;br /&gt;
=== première semaine de Avril ===&lt;br /&gt;
&lt;br /&gt;
==== Le design de la carte ====&lt;br /&gt;
&lt;br /&gt;
Voici le schematic de la carte avec son régulateur de tension externe, nous avons corrigé certaines choses, comme l'ajout&lt;br /&gt;
d'un crystal externe à 16 MHz pour pouvoir utiliser l'atmega328p en dépit du problème d'upload du programme.&lt;br /&gt;
&lt;br /&gt;
Voici, la version finale de la carte.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:Schematic_avec_regulateur_et_crystal.png|400px]] Le schéma complet de la carte avec des mises à jour, comme l'ajout du Crystal, le régulateur de tension, des connecteurs pour la programmer directement, ou ajouter des capteurs numériques.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:top.png|400px]] La surface Top du PCB&lt;br /&gt;
&lt;br /&gt;
[[Fichier:bottom.png|400px]] La surface Bottom du PCB&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Voici la version finale de la carte, &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Cartefinale.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Testé sur Alimentation Stabilisée, puis ensuite directement sur pile.&lt;br /&gt;
En veille la carte consomme 0,8 mA , en communication la carte consomme 25mA.&lt;br /&gt;
Si elle se met en veille toutes les 16 secondes, on peut prétendre à une autonomie théorique de 7 mois, avec &lt;br /&gt;
2 piles AA 1,5 V (2*2000mAh).&lt;br /&gt;
Ici, nous n'avons pas eu des relevés de températures corrects avec l'alimentation parasite du capteur, donc nous l'alimentons&lt;br /&gt;
un certain moment avant de l'interroger, ceci impactera sur l'autonomie de la carte.&lt;br /&gt;
En ayant réussi à flasher les fusibles de l'atmega pour abaisser sa fréquence de fonctionnement, nous aurions baissé encore plus significativement sa consommation&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12172</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=12172"/>
				<updated>2014-04-15T20:22:30Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* A concevoir */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png|texte descriptif]]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=11932</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=11932"/>
				<updated>2014-04-15T16:26:34Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Partie IHM */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
==== Séance 1 : Cahier des charges spécifiques à l'IHM ====&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png]|texte descriptif]&lt;br /&gt;
&lt;br /&gt;
Une fois cette liste établie, j'ai pu passé la séance suivante à la recherche d'outils de conception.&lt;br /&gt;
&lt;br /&gt;
==== Séance 2 : Listing d'outils utiles à la conception ====&lt;br /&gt;
&lt;br /&gt;
Pour la page générale, j'utiliserai le langage PHP et HTML. Durant cette séance j'ai pris en main le langage grâce à quelques tutoriels sur internet et découvert le Bootstrap twitter qui permet d'avoir des classes CSS et des effets JavaScript pré-faits. De plu, je me suis orienté vers un framework CakePHP pour simplifier le code, cependant, se relevant assez complexe à mettre en oeuvre, j'ai préféré ne pas perdre de temps.&lt;br /&gt;
Le second outil sont fonctions mysql spécifiques à PHP, la doc sur le site de MySQL s'est révélée précieuse.&lt;br /&gt;
Création de l'architecture des fichiers et arborescence du site :&lt;br /&gt;
* fichiers include (header et footer)&lt;br /&gt;
* fichiers de config&lt;br /&gt;
* fichiers CSS et JS&lt;br /&gt;
&lt;br /&gt;
Concernant la météo, on utilisera le site tameteo, qui fournira un fichier XML à parser. On aura donc besoin de libxml2 librairie à étudier.&lt;br /&gt;
&lt;br /&gt;
==== Séance 3 : Mise en place du serveur SQL et des compléments ====&lt;br /&gt;
&lt;br /&gt;
Je connaissais déjà PHPMyadmin, la mise en place de la structure de la base de donnée a donc été assez facile. Le fichier base.sql correspond au fichier importé dans phpmyadmin alors que projet.sql est l'exporté.&lt;br /&gt;
Installation des librairies libxml2-dev php5 et libmysqlclient-dev.&lt;br /&gt;
Commencement du développement php de l'IHM.&lt;br /&gt;
&lt;br /&gt;
==== Séance 4,5,6,7 : Développement de l'IHM ====&lt;br /&gt;
&lt;br /&gt;
Pas de problèmes particuliers.&lt;br /&gt;
Création d'un fichier .inc pour les paramètres de connexion à la BdD. Le programme d'arrière plan utilisera ce même fichier.&lt;br /&gt;
Création d'un fichier &amp;quot;station.conf&amp;quot; où sera enregistré le numéro de la station météo et qui sera aussi utilisé par le programme pour récupérer les infos météo.&lt;br /&gt;
Enfin le fichier new_modul.conf contiendra les adresses des nouveaux modules détectés mais non ajoutés au réseau. L'utilisateur pourra ajouter ce module et la pièce correspondante grâce à l'IHM.&lt;br /&gt;
Codage d'un mini parser php pur récupérer les infos de géolocalisation fournie par tameteo.&lt;br /&gt;
&lt;br /&gt;
==== Séance 8,9 et 10: Développement du parser.c pour la météo - et codage des fonctions qui agissent sur la BdD====&lt;br /&gt;
&lt;br /&gt;
Ce petit programme aura pour but de mettre à jour les infos météo dans la BdD. Il lira le fichier station.conf pour connaître la station pour laquelle il doit lire les infos.&lt;br /&gt;
Voir parser.c et parser.h. Ce programme regroupe les fonctions qui ajouteront les infos reçues par les capteurs dans la BdD, et de lecture de la BdD pour envoyer une consigne au radiateur (Consigne déterminée par le programme principal).&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=11866</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=11866"/>
				<updated>2014-04-15T12:07:46Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Avancement du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== Avancement du projet ==&lt;br /&gt;
&lt;br /&gt;
=== Partie IHM ===&lt;br /&gt;
&lt;br /&gt;
La Raspberry Pi utilisée dans le projet permettra de recevoir une base de donnée MySQL, une interface Web accessible depuis tablette, smartphone et PC, un programme principal permettant la coordination des données.&lt;br /&gt;
Concernant l'interface Homme-Machine (IHM), nous voyons le projet comme un futur produit commercial, l'IHM doit donc être simple, facile et intuitive.&lt;br /&gt;
La première étape de conception consiste à établir une liste des éléments qui devront être présent sur l'IHM. A savoir :&lt;br /&gt;
* Un affichage de la température extérieur (facultatif) ;&lt;br /&gt;
* La température relevée par les capteurs par pièce ;&lt;br /&gt;
* La modification manuelle du mode de confort thermique dans une pièce (Hors-gel, Arret, Economique et confort) ; // chaque mode correspondra à une température&lt;br /&gt;
* Un panneau de configuration permettant de :&lt;br /&gt;
** spécifier la ville pour la météo ;&lt;br /&gt;
** rentrer les identifiants de connexion à la base de donnée ;&lt;br /&gt;
** ajouter un nouveau module au réseau ;&lt;br /&gt;
* Un programmeur pour spécifier les modes de confort à différents moments de la journée ;&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schedulr.png]]&lt;br /&gt;
&lt;br /&gt;
=== Partie réseaux de capteurs ===&lt;br /&gt;
&lt;br /&gt;
Aprés s'être documentés, nous avons:&lt;br /&gt;
&lt;br /&gt;
* Pris en main la communication entre 2 Zigbees, un problème se pose dés lors, comment dissocier les paquets envoyés par le module capteur (arduino+zigbee+capteur de température) de ceux envoyés par le module chauffage au niveau du module coordinateur (la puce Xbee reliée à la Raspberry)&lt;br /&gt;
Des soucis de connexion entre la puce Xbee et l'adaptateur xbee pour breadboard ralentissent la phase de protypage.&lt;br /&gt;
* Commencé le programme de gestion de la communication entre la puce xbee qui servira de coordinateur et la Raspberry &lt;br /&gt;
* Anticipé le futur montage sur carte du module capteur et chauffage qui ajoute certaines problématiques&lt;br /&gt;
** Détection de l'autonomie : On pourrait connecter l'alimentation à une entrée CAN pour détecter un seuil de basse tension cependant, lorsque&lt;br /&gt;
la tension d'alimentation diminue, le voltage de référence diminuera (pin AREF) qu'il soit paramétré en interne ou en externe.&lt;br /&gt;
La solution retenue à ce jour consiste en l'utilisation d'une batterie 3 V, un régulateur step up 3V vers 3,3v - la sortie du régulateur alimentera le Xbee et l'atmega328p tandis qu'on branchera directement sur une entrée CAN l'alimentation 3v. Ainsi le voltage de référence sera constant et on pourra &lt;br /&gt;
détecter la baisse de tension d'alimentation).&lt;br /&gt;
** Gestion de l'autonomie: Etant donné, que l'on fonctionne en batterie, il faudra minimiser la consommation du module capteur.&lt;br /&gt;
Le module de chauffage sera branché sur le secteur (puisqu'une forte tension sera censée alimenter un relai qui permettra d'élever la tension de commande généré à l'aide d'une PWM par l'atmega).&lt;br /&gt;
On peut procéder à quelques concessions qui agrandiront l'autonomie:&lt;br /&gt;
*** La fréquence du module de capteur pourra être, au minimum, de 1MHz, en effet nous utilisons la technologie OneWire pour communiquer avec notre capteur de température, celle nécessite des timings de l'ordre de la microseconde.&lt;br /&gt;
*** Alimenter le capteur de température par son port de donnée, celui-ci consommera seulement lorsqu'il sera interrogé (Alimentation parasite sur Capteur DS18B20)&lt;br /&gt;
*** Mettre en veille le module Xbee et le réveiller périodiquement, la consommation passera d'environ 40mA à quelques nA&lt;br /&gt;
*** Mettre en veille l'atmega à l'aide d'un watchdog timer ce qui divisera sa consommation par un facteur d'environ 5.&lt;br /&gt;
&lt;br /&gt;
==== Au programme des prochaines séances en Mars: ====&lt;br /&gt;
&lt;br /&gt;
En salle de TP électronique, du batiment C.&lt;br /&gt;
* Test du montage d'alimentation parasite du capteur. Intégration sur breadbord avec le DS18B20 en vue d'une validation pour le PCB actuel.&lt;br /&gt;
* Test et visualisation de la commande de chauffage en sortie du module chauffage. Commande réalisée par interruptions puisqu'envoyée en continue. Cela implique de rechercher la fréquence d'interruption optimale pour avoir un signal correspondant au signaux de commande types pour un fil pilote (sur chauffage).&lt;br /&gt;
* Test des montages de régulation d'alimentation 3,3v pour l'atmega.&lt;br /&gt;
&lt;br /&gt;
Au niveau du Raspberry:&lt;br /&gt;
Pour identifier les adresses sources des paquets reçus, la solution serait d'utiliser le Xbee connecté en  mode API : un protocole de communication plus bas niveau que le mode transparent, permettant à la Raspberry de communiquer avec le Zigbee à l'aide de trames. &lt;br /&gt;
Il permet également de récupérer l'adresse source des trames reçues, indispensables pour différencier les informations de température dans chaque pièces et les alertes de basse autonomie des différents modules.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Schedulr.png&amp;diff=11845</id>
		<title>Fichier:Schedulr.png</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Schedulr.png&amp;diff=11845"/>
				<updated>2014-04-15T11:02:37Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : Exemple de programmeur envisagé&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Exemple de programmeur envisagé&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9415</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9415"/>
				<updated>2014-02-12T13:41:34Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques DS18B20+TAR http://fr.mouser.com/ProductDetail/Maxim-Integrated/DS18B20+PAR/?qs=sGAEpiMZZMusbZ2pNxAMx0uevd2%2fnJAJ79Ghy2YiFms%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9333</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9333"/>
				<updated>2014-02-10T23:13:55Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard http://fr.mouser.com/ProductDetail/Parallax/32403/?qs=sGAEpiMZZMuDQH1m5567YR8YnxbMMLjQ&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques 18S20 TO-92-3 http://fr.farnell.com/maxim-integrated-products/ds18s20/thermometre-numerique-18s20-to/dp/9724761&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9332</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9332"/>
				<updated>2014-02-10T23:06:51Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2''' disponibles ici : http://fr.mouser.com/ProductDetail/Digi-International/XB24-BPIT-004/?qs=sGAEpiMZZMtJacPDJcUJY%2fSAm9tUtP8ewOJx%2fVkeOXY%3d&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 thermomètres numeriques 18S20 TO-92-3 http://fr.farnell.com/maxim-integrated-products/ds18s20/thermometre-numerique-18s20-to/dp/9724761&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9288</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9288"/>
				<updated>2014-02-09T17:54:30Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Introduction */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation énergétique des radiateurs de l'école. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9287</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9287"/>
				<updated>2014-02-09T17:53:36Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Introduction */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initié pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9286</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9286"/>
				<updated>2014-02-09T17:47:44Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Introduction */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
Le but final de ce projet devrait ressemblé au système de Schneider suivant : [http://www.youtube.com/watch?v=6NVIcO7KxJQ&amp;amp;feature=c4-overview-vl&amp;amp;list=PLC3A349454A304FEA]&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9285</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9285"/>
				<updated>2014-02-09T17:35:13Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9284</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9284"/>
				<updated>2014-02-09T17:29:37Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;Non, à commander&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|&amp;lt;font color=&amp;quot;lightgreen&amp;quot;&amp;gt;Peut-être, à voir avec T. Vantroys&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|&amp;lt;font color=&amp;quot;lightgreen&amp;quot;&amp;gt;Peut-être, à voir avec T. Vantroys&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|&amp;lt;font color=&amp;quot;greenyellow&amp;quot;&amp;gt;Normalement OUI&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|&amp;lt;font color=&amp;quot;lightgreen&amp;quot;&amp;gt;A voir avec A. Boé et T. Vantroys&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9283</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9283"/>
				<updated>2014-02-09T17:25:58Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|OUI&lt;br /&gt;
|Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|Non, à commander&lt;br /&gt;
|NON&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|OUI&lt;br /&gt;
|NON&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|Peut-être, à voir avec T. Vantroys&lt;br /&gt;
|Nop&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|Peut-être, à voir avec T. Vantroys&lt;br /&gt;
|Nop&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|Normalement OUI&lt;br /&gt;
|Nop&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|A voir avec A. Boé et T. Vantroys&lt;br /&gt;
|NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9282</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9282"/>
				<updated>2014-02-09T17:25:21Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 3 : Matériel nécessaire (pour le prototypage) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Matériel !! Disponibilité à Polytech ? !! Récupéré ?&lt;br /&gt;
|-&lt;br /&gt;
|Une Raspberry Pi et sa carte SD&lt;br /&gt;
|OUI&lt;br /&gt;
|Déjà Récupérée&lt;br /&gt;
|-&lt;br /&gt;
|3 modules XBee '''Série 2'''&lt;br /&gt;
|Non, à commander&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|adaptateurs USB pour XBee&lt;br /&gt;
|OUI&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|2 Breadboards&lt;br /&gt;
|Peut-être, à voir avec T. Vantroys&lt;br /&gt;
|Nop&lt;br /&gt;
|-&lt;br /&gt;
|2 shield XBee avec pins permettant de la positionner sur un Breadboard&lt;br /&gt;
|Peut-être, à voir avec T. Vantroys&lt;br /&gt;
|Nop&lt;br /&gt;
|-&lt;br /&gt;
|2 Arduino Uno&lt;br /&gt;
|Normalement OUI&lt;br /&gt;
|Nop&lt;br /&gt;
|-&lt;br /&gt;
|Quelques fils, LED, résistances.&lt;br /&gt;
|A voir avec A. Boé et T. Vantroys&lt;br /&gt;
|NON&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9281</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9281"/>
				<updated>2014-02-09T17:15:57Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Développement de la structure de données */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee&lt;br /&gt;
* 3 modules XBee Serie 2&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png|800px|center]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px|center]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9280</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9280"/>
				<updated>2014-02-09T17:15:15Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Début du projet */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet et découpage du travail ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
Jérémy s'occupera de la conception des capteurs et des modules pour chauffage (cartes électroniques) ainsi que des codes à implémenter permettant la communication.&lt;br /&gt;
Florian se chargera quant à lui de la supervision Web dans un premier temps, de la base de données ainsi que des programmes à mettre sur la RPI afin de récupérer et stocker les valeurs des données fournies par les capteurs.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee&lt;br /&gt;
* 3 modules XBee Serie 2&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9279</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9279"/>
				<updated>2014-02-09T17:09:06Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Développement de la structure de données */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee&lt;br /&gt;
* 3 modules XBee Serie 2&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.png|600px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:UML-BdD.png&amp;diff=9278</id>
		<title>Fichier:UML-BdD.png</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:UML-BdD.png&amp;diff=9278"/>
				<updated>2014-02-09T17:08:12Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9277</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9277"/>
				<updated>2014-02-09T17:01:46Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 1 : Cahier des charges */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pressions devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee&lt;br /&gt;
* 3 modules XBee Serie 2&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9276</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=9276"/>
				<updated>2014-02-09T17:00:38Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 1 : Cahier des charges */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;Élèves sur le projet :&lt;br /&gt;
Jérémy Gondry IMA4&lt;br /&gt;
Florian Royer IMA4&lt;br /&gt;
&lt;br /&gt;
Encadrants :&lt;br /&gt;
M. Alexandre Boé&lt;br /&gt;
M. Thomas Vantroy&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
==Introduction==&lt;br /&gt;
&lt;br /&gt;
La consommation énergétique d'une maison ou d'une entreprise est souvent un gros problème car on n'est la plupart du temps en manque de moyens techniques ou de systèmes assez modulaires pouvant s'adapter à tout type d'installation. Ce projet a donc été initialisé pour pouvoir offrir un système complet permettant de connaître et de réduire fortement la consommation énergétique due aux radiateurs (qu'ils soient électriques ou à eau chaude). A terme, ce projet pourrait être joint au projet 43 initié par la direction de Polytech afin de réduire la consommation de Polytech. A titre d'exemple, Polytech chauffe les salles jour et nuit, notre devrait permettre de chauffer les salles qui sont utilisées uniquement à des heures prévues, et ainsi économiser au moins 40% de l'énergie.&lt;br /&gt;
&lt;br /&gt;
== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pression devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee&lt;br /&gt;
* 3 modules XBee Serie 2&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8963</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8963"/>
				<updated>2014-02-05T13:53:51Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Développement de la structure de données */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Très bien pour la réactivité, dans l'ensemble tout y est.''&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* Les températures et pression devront être récupérées dans plusieurs pièces à l'aide d'un réseau de capteurs.&lt;br /&gt;
* Ces données seront récupérées par un dispositif centralisé communicant en Ethernet.&lt;br /&gt;
** Ce dispositif servira à élaborer et transmettre, à distance, les commandes aux dispositifs de chauffage.&lt;br /&gt;
** La régulation opérée sur la température, sera modulaire, on pourra étendre la commande à différents types de chauffage (sans modifier fondamentalement le programme embarqué sur le dispositif) &lt;br /&gt;
* Elles seront classées selon une structure de donnée adaptée.&lt;br /&gt;
* Une application android sera développée, elle fera office d'interface utilisateur. &lt;br /&gt;
Elle permettra à l'utilisateur de connaître la température dans l'habitation et d'envoyer une température de consigne.&lt;br /&gt;
&lt;br /&gt;
== Phase prototypage: ==&lt;br /&gt;
Elaboration d'un réseau de capteurs. &lt;br /&gt;
&lt;br /&gt;
Ecarter les problématiques liés à l'électronique (alimentation des dispositifs communicants) pour se concentrer sur la partie logiciel du réseau&lt;br /&gt;
de capteurs.&lt;br /&gt;
&lt;br /&gt;
== Phase implémentation en dur: ==&lt;br /&gt;
&lt;br /&gt;
Elaboration d'une carte électronique pour implémenter les modules capteurs, modules chauffage. &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Section à reprendre pour faire apparaître les différents niveaux du projets. Ici vous mélangez les parties générales et le détail, voire même un début de solution. Par ailleurs, il semble intéressant d'inclure une partie pour étudier la faisabilité de récupération de données météo sur Internet.''&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
''Alexandre : Ici aussi vous mélangez allégrement différents niveaux de réflexion. Par ailleurs, la pression est dans un premier temps pas forcément pertinente (manque de capteur simple a priori). L'idée sera de faire un capteur suffisamment générique pour pouvoir ajouter simplement un capteur ou un autre. La gestion des phases de réveil / endormissement ne doit pas être trop énergivore, une simple RTC (Real Time Clock) devrait être suffisante.''&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé ''Alexandre : Pas sur que ça soit compatible en terme d'énergie : comment s'assurer que le noeud est réveillé au bon moment pour servir de passerelle ?'', on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé). ''Alexandre : Du zigbee classique, même à faible puissance a une porté largement compatible avec l'application visée à mon avis''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé. ''Alexandre : On peut utiliser 802.15.4 en réseau point à point.''&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Pas sécurisé ;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee (pour pouvoir faire communiquer 2 PC)&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Après quelques recherches et plusieurs solutions envisagées, nous sommes parvenus à cette architecture :&lt;br /&gt;
[[Fichier:Architecture-Complète.png]]&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Architecture-Compl%C3%A8te.png&amp;diff=8960</id>
		<title>Fichier:Architecture-Complète.png</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Fichier:Architecture-Compl%C3%A8te.png&amp;diff=8960"/>
				<updated>2014-02-05T13:49:39Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8910</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8910"/>
				<updated>2014-02-04T17:59:40Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Étape 2 : Architecture Optimale du capteur / Mise en réseau */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* Les températures et pression devront être récupérées dans plusieurs pièces. Ces mesures devront être classées et organisées dans une base de donnée ou structure.&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* La consigne sera fournie aux chauffages par un calculateur central (différents types de chauffage : Eau ou radiateur électrique) ;&lt;br /&gt;
* Il existera différents modules :&lt;br /&gt;
** capteurs seuls ;&lt;br /&gt;
** capteurs + contrôleur d'électrovanne (chauffage à eau) -&amp;gt; la partie commande sera liée au projet 43 ;&lt;br /&gt;
** capteurs + contrôleur pour un radiateur électrique à fil pilote ;&lt;br /&gt;
* Ajouter un système d’arrêt d'urgence du chauffage (exemple : à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé, on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé).&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé.&lt;br /&gt;
Le tableau ci-dessous montre les avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Pas sécurisé ;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee (pour pouvoir faire communiquer 2 PC)&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8909</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8909"/>
				<updated>2014-02-04T17:57:07Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Développement de la structure de données */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* Les températures et pression devront être récupérées dans plusieurs pièces. Ces mesures devront être classées et organisées dans une base de donnée ou structure.&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* La consigne sera fournie aux chauffages par un calculateur central (différents types de chauffage : Eau ou radiateur électrique) ;&lt;br /&gt;
* Il existera différents modules :&lt;br /&gt;
** capteurs seuls ;&lt;br /&gt;
** capteurs + contrôleur d'électrovanne (chauffage à eau) -&amp;gt; la partie commande sera liée au projet 43 ;&lt;br /&gt;
** capteurs + contrôleur pour un radiateur électrique à fil pilote ;&lt;br /&gt;
* Ajouter un système d’arrêt d'urgence du chauffage (exemple : à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé, on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé).&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé.&lt;br /&gt;
Avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Pas sécurisé ;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee (pour pouvoir faire communiquer 2 PC)&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.jpg|800px]]&lt;br /&gt;
&lt;br /&gt;
Nous avons prévu de développer un programme qui tournera sur la Raspberry, celle-ci agira comme un relai. Les différents capteurs enverront la température et les alertes de chute de pression au programme tournant sur la Raspberry (RPI), et la RPI enregistrera ensuite dans la base de donnée les différentes valeurs de température.&lt;br /&gt;
La base de données offre de nombreux avantages, comme une facilité d'accès tout en étant sécurisée, le stockage régulier de valeurs, la possibilité de suivre la consommation sur plusieurs jours, semaines, années, accessible grâce à des bibliothèques en C, et naturellement en php pour la supervision.&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	<entry>
		<id>https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8908</id>
		<title>Consommation maison</title>
		<link rel="alternate" type="text/html" href="https://wiki-ima.plil.fr/mediawiki//index.php?title=Consommation_maison&amp;diff=8908"/>
				<updated>2014-02-04T17:51:02Z</updated>
		
		<summary type="html">&lt;p&gt;Froyer : /* Développement de la structure de données */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Étape 1 : Cahier des charges ==&lt;br /&gt;
&lt;br /&gt;
Voici un récapitulatif de ce qui est attendu du projet.&lt;br /&gt;
&lt;br /&gt;
=== Objectifs principaux===&lt;br /&gt;
&lt;br /&gt;
* Les températures et pression devront être récupérées dans plusieurs pièces. Ces mesures devront être classées et organisées dans une base de donnée ou structure.&lt;br /&gt;
* On compte principalement réduire la consommation due au chauffage dans une habitation ou infrastructure ; &lt;br /&gt;
* La consigne sera fournie aux chauffages par un calculateur central (différents types de chauffage : Eau ou radiateur électrique) ;&lt;br /&gt;
* Il existera différents modules :&lt;br /&gt;
** capteurs seuls ;&lt;br /&gt;
** capteurs + contrôleur d'électrovanne (chauffage à eau) -&amp;gt; la partie commande sera liée au projet 43 ;&lt;br /&gt;
** capteurs + contrôleur pour un radiateur électrique à fil pilote ;&lt;br /&gt;
* Ajouter un système d’arrêt d'urgence du chauffage (exemple : à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
=== A concevoir===&lt;br /&gt;
&lt;br /&gt;
* Réseau de capteurs (sans fil) (technologie à déterminer) ;&lt;br /&gt;
* La base de données où seront enregistrés les différentes mesures et consignes à envoyer aux modules ; &lt;br /&gt;
* Supervision complète sur serveur Apache (HTML, PHP) ;&lt;br /&gt;
* Supervision minimale : applications mobile Androïd ;  &lt;br /&gt;
* Programmeur de mise en veille afin d'économiser la pile ou batterie qui alimentera le capteur ;&lt;br /&gt;
* un protocole de communication entre les capteurs et un &amp;quot;appareil central&amp;quot; (de type Raspberry Pi, Fox Board...) ;&lt;br /&gt;
* Création du capteur qui comprendra :&lt;br /&gt;
** La récupération de la température ;&lt;br /&gt;
** Récupération de la pression (pour détecter les chutes suite à l'ouverture d'une fenêtre) ;&lt;br /&gt;
&lt;br /&gt;
* Possibilité d'ajout de &amp;quot;modules&amp;quot;, qui se pluggeront sur les capteurs, correspondant au chauffage commandé par fil pilote, au chauffage commandé par électrovanne (pour les dispositifs utilisant une  chaudière) ;&lt;br /&gt;
* Établir un système permettant la consommation réduite des capteurs (pour l'alimentation : pile, secteurs, pourquoi pas un système de récupération de l'énergie thermique), problématique de la fréquence de rechargement du dispositif d'alimentation des capteurs ;  &lt;br /&gt;
* Mise en veille des capteurs / fréquence de consultation des données. Une mesure toutes les heures ou toutes les demi-heures ne seraient-elles pas suffisantes ? &lt;br /&gt;
* Une récupération sur un serveur NTP (''Network Time Protocol''), de l'heure pour gérer les mises en veille et les heures creuses / heures pleines ;&lt;br /&gt;
&lt;br /&gt;
La problématique d''''adaptabilité du dispositif''' de chauffage commandé doit être prise en compte : changement de milieu (maison ou  bâtiment d'entreprise, le type de chauffage (eau ou électrique), la disponibilité de prises secteurs ou pas.&lt;br /&gt;
&lt;br /&gt;
=== N.B ===&lt;br /&gt;
&lt;br /&gt;
 Ceci est une conclusion de la première réunion avec A. Boé et B. Bouhamama. Il y a de fortes probabilités pour que ce cahier des charges soit complété.&lt;br /&gt;
&lt;br /&gt;
=== Début du projet ===&lt;br /&gt;
&lt;br /&gt;
La prochaine étape consiste à trouver une architecture optimale du capteur et définir la structure de données. On peut alors commencer par diviser le travail, un s'occupera de la mise en place d'un réseau de capteurs et modules, le second de la base de donnée et les outils de supervisions les plus adéquates au système.&lt;br /&gt;
&lt;br /&gt;
== Étape 2 : Architecture Optimale du capteur / Mise en réseau ==&lt;br /&gt;
&lt;br /&gt;
==== Introduction : cahier des charges spécifiques ====&lt;br /&gt;
&lt;br /&gt;
L'objectif final est de réaliser un réseau de capteurs/actionneurs que nous appellerons ici Modules. Ces modules devront permettre de mesurer une température, capter des chutes de pressions et actionner le radiateur. De plus, dans un soucis d'économie d'énergie, les modules devront consommer que très peu d'énergie. Enfin, les modules s'installeront dans une maison ou une infrastructure, impossible de prévoir un câblage entre les modules, il faut donc opter pour une architecture réseau Sans-fil.&lt;br /&gt;
&lt;br /&gt;
==== Norme Wireless ====&lt;br /&gt;
&lt;br /&gt;
Il existe principalement 2 catégories de réseaux :&lt;br /&gt;
[[Fichier:Reseaux.jpg|400px|thumb|left|A gauche un exemple de réseau en étoile, à droite un réseau maillé]]&lt;br /&gt;
&lt;br /&gt;
* Les réseaux de type &amp;quot;star&amp;quot; (ou &amp;quot;en étoile&amp;quot;), utilisent une machine centrale sur laquelle se connectent les périphériques du réseau.&lt;br /&gt;
* Alors que les réseaux de type &amp;quot;mesh&amp;quot; (ou &amp;quot;maillés&amp;quot;), transmettent par le biais d'un coordinateur les données aux différents périphériques connectés. Si le 1er périphérique &amp;quot;comprend&amp;quot; que les données lui sont destinées, il les enregistre, sinon il agit comme un répéteur et transmet au 2ème périphérique et ainsi de suite jusqu'à ce que le nombre maximal de répéteurs parcourus soit atteint ou bien que les données aient trouvées leur destinataire.&lt;br /&gt;
&lt;br /&gt;
Comme on souhaite économiser un maximum d'énergie, il convient d'utilisé un réseau maillé, on se sert de chaque module comme un bridge pour envoyer les données, ce qui fait économiser l'amplitude du signal (en utilisant un réseau en étoile, il faudrait un signal très amplifié pour parcourir la distance que peut parcourir un réseau maillé).&lt;br /&gt;
&lt;br /&gt;
Il existe différentes normes Wireless. On retient ici le Wi-Fi classique 802.11 qui peut être utilisé en étoile (classique) ou en ad-hoc (mesh, un peu compliqué à mettre en place), et la norme Zigbee 802.15 qui ne peut être utilisé qu'en réseau maillé.&lt;br /&gt;
Avantages et inconvénients de chacun :&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Norme !! Avantages !! Inconvénients&lt;br /&gt;
|-&lt;br /&gt;
| Wi-Fi 802.11&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Très répandue, on pourrait ainsi utiliser un routeur ou une box dans une maison comme coordinateur ;&lt;br /&gt;
* Protocole TCP/IP, on pourrait utiliser un serveur DHCP pour faciliter la mise en place du réseau ;&lt;br /&gt;
* Sécurisé par cryptage (WEP ou WPA-PSK)&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* le type ad-hoc et répéteur est compliqué à mettre en place ;&lt;br /&gt;
* Trame de transmission inadaptée au projet. Le Wi-Fi a été principalement développé pour des transferts à grande vitesse de beaucoup de données, or nous souhaitons juste envoyer 2 ou 3 octets à intervalle de temps assez longue ;&lt;br /&gt;
* Très gourmande en ressource, l'alimentation par pile est inenvisageable avec cette technologie ;&lt;br /&gt;
* La portée diffère suivant la norme a/b/g/n/ac mais, elle sera tout de même très limitée par rapport à ce que peut atteindre le Zigbee ;&lt;br /&gt;
* Très grande probabilité interférences avec d'autres appareils, et risque de saturation du réseau si on utilise la bande des 2.4 GHz (limité à 4 ou 5 appareils sur une box par exemple, trop peu). &lt;br /&gt;
|-&lt;br /&gt;
| Zigbee 802.15&lt;br /&gt;
|&amp;lt;font color=&amp;quot;green&amp;quot;&amp;gt;&lt;br /&gt;
* Semblable à une communication série, mais sans-fil ;&lt;br /&gt;
* Trame très simple, nécessite en moyenne que 10% des lignes de codes Wi-Fi ;&lt;br /&gt;
* Portée pouvant atteindre 1 km avec un appareils tout les 30m ;&lt;br /&gt;
* Nous allons utiliser des modules XBee Pro qui ne coûtent que 20€ ;&lt;br /&gt;
* On peut mettre jusque plus de 65 000 appareils en réseau ! ;&lt;br /&gt;
* Consomme très peu. Avec les mode de réveil du module, on peut descendre à 1mA ;&lt;br /&gt;
|&amp;lt;font color=&amp;quot;red&amp;quot;&amp;gt;&lt;br /&gt;
* Pas sécurisé ;&lt;br /&gt;
* Vitesse limitée à 250 kbit/s, mais très suffisant dans le cadre de notre projet ;&lt;br /&gt;
* La portée entre 2 modules est inférieure à 30 m ;&lt;br /&gt;
|-&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
'''Conclusion''' : Nous utiliserons la norme Zigbee et un réseau maillé pour construire le réseau de capteurs. A noter que l'inconvénient majeur est la portée (environ 30 m).&lt;br /&gt;
&lt;br /&gt;
== Étape 3 : Matériel nécessaire (pour le prototypage) ==&lt;br /&gt;
&lt;br /&gt;
Après avoir déterminé l'architecture que nous souhaitons mettre en œuvre, nous pouvons prévoir le matériel dont nous aurons besoin pour le projet :&lt;br /&gt;
&lt;br /&gt;
* Une Raspberry Pi avec câble HDMI verx VGA si possible + une carte SD + câble d'alimentation microUSB&lt;br /&gt;
* 2 Adaptateurs USB pour Zigbee (pour pouvoir faire communiquer 2 PC)&lt;br /&gt;
* 2 Breadboards&lt;br /&gt;
* 2 Adaptateurs Bread Board pour Zigbee&lt;br /&gt;
* 2 Arduino Uno avec câble série.&lt;br /&gt;
* Quelques fils, LED, résistances.&lt;br /&gt;
&lt;br /&gt;
La Raspberry embarquera un serveur Web pour l'application mobile/supervision qui s'adaptera suivant le type de plateforme qui se connectera dessus (smartphone/tablette/PC). Le dashboard sera différent suivant la plateforme. Elle embarquera aussi un serveur de BdD MySQL afin d'y enregistrer les données des modules et des consignes que souhaitent appliquer les utilisateurs finaux (BdD, voir plus bas).&lt;br /&gt;
&lt;br /&gt;
== Développement de la structure de données ==&lt;br /&gt;
&lt;br /&gt;
Pour enregistrer les informations récupérées au niveau des modules, nous aurons besoin d'une structure de données ou BdD.&lt;br /&gt;
Voici le graphique UML de la BdD :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:UML-BdD.jpg|800px]]&lt;/div&gt;</summary>
		<author><name>Froyer</name></author>	</entry>

	</feed>