<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="fr">
		<id>https://projets-ima.plil.fr/mediawiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ahuet</id>
		<title>Wiki de Projets IMA - Contributions de l’utilisateur [fr]</title>
		<link rel="self" type="application/atom+xml" href="https://projets-ima.plil.fr/mediawiki/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=Ahuet"/>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php/Sp%C3%A9cial:Contributions/Ahuet"/>
		<updated>2026-05-14T00:57:58Z</updated>
		<subtitle>Contributions de l’utilisateur</subtitle>
		<generator>MediaWiki 1.29.2</generator>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45816</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45816"/>
				<updated>2017-10-24T11:50:46Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Création de la VM */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
*Avancement dans la compréhension de l'utilisation de la clef wifi&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 5 derniers points d'accès wifi.&lt;br /&gt;
*Connexion faite entre la machine avec la clef wifi et le point d'accès.&lt;br /&gt;
*Configuration de gandi et de notre serveur dns avec bind9&lt;br /&gt;
&lt;br /&gt;
==== séance 5 ====&lt;br /&gt;
&lt;br /&gt;
*Sécurisation de site web par certificats&lt;br /&gt;
*Sécurisation de site web par dnssec&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
Commencer par se mettre en mode configuration:&lt;br /&gt;
  ap&amp;gt;enable&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
  ap(config)#dot11 ssid tomate&lt;br /&gt;
  ap(config-ssid)#authentication open&lt;br /&gt;
  ap(config-ssid)#vlan 8&lt;br /&gt;
  ap(config-ssid)#mbssid guest-mode &lt;br /&gt;
  ap(config-ssid)#exit&lt;br /&gt;
  ap(config)#Interface dot11radio0&lt;br /&gt;
  ap(config)#ssid tomate&lt;br /&gt;
  ap(config-ssid)#no shutdown&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 mode wep mandatory&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 key 1 size 128bit 05050505050505050505050505&lt;br /&gt;
  ap(config-ssid)#End&lt;br /&gt;
Écrire les modifications:&lt;br /&gt;
  ap#write memory&lt;br /&gt;
Configurer le sous interface pour Dot11 radio 0 et Ethernet.&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
  ap(config)#interface Dot11Radio0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#interface GigabitEthernet0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#end&lt;br /&gt;
  ap#write memory&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie commune===&lt;br /&gt;
&lt;br /&gt;
==== Création de la VM ====&lt;br /&gt;
&lt;br /&gt;
Pour suivre le thème de la promo qui porte sur les fruits, nous&lt;br /&gt;
avons crée une machine virtuelle sur le serveur cordouan qui se nomme IMA5-GROSEILLE.&lt;br /&gt;
&lt;br /&gt;
Cette VM hébergera un site web sécurisé qui se nommera www.groseille.space.&lt;br /&gt;
&lt;br /&gt;
Pour cela on utilisera les commandes : &lt;br /&gt;
&lt;br /&gt;
* xen-create-image pour créer la machine virtuelle&lt;br /&gt;
* lv-create pour que les répertoires /var et /home soient sur les partitions LVM de l'hôte.&lt;br /&gt;
&lt;br /&gt;
Une fois la machine virtuelle crée, on créera la session avec:&lt;br /&gt;
&lt;br /&gt;
  xl create IMA5-GROSEILLE.cfg&lt;br /&gt;
dans le repertoire /etc/xen&lt;br /&gt;
&lt;br /&gt;
et :&lt;br /&gt;
&lt;br /&gt;
  xl console IMA5-GROSEILLE&lt;br /&gt;
pour accéder à la VM.&lt;br /&gt;
&lt;br /&gt;
==== Mise en place des services internet ====&lt;br /&gt;
&lt;br /&gt;
===== Serveur ssh =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur dns =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur de mail =====&lt;br /&gt;
&lt;br /&gt;
En effet nous avons du faire de notre machine virtuelle un serveur de mail pour pouvoir recevoir les&lt;br /&gt;
mail de gandi qui sont envoyé vers : admin@mon_domain donc pour nous : admin@groseille.space&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par certificats =====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par dnssec =====&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45815</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45815"/>
				<updated>2017-10-24T11:50:00Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Création de la VM */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
*Avancement dans la compréhension de l'utilisation de la clef wifi&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 5 derniers points d'accès wifi.&lt;br /&gt;
*Connexion faite entre la machine avec la clef wifi et le point d'accès.&lt;br /&gt;
*Configuration de gandi et de notre serveur dns avec bind9&lt;br /&gt;
&lt;br /&gt;
==== séance 5 ====&lt;br /&gt;
&lt;br /&gt;
*Sécurisation de site web par certificats&lt;br /&gt;
*Sécurisation de site web par dnssec&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
Commencer par se mettre en mode configuration:&lt;br /&gt;
  ap&amp;gt;enable&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
  ap(config)#dot11 ssid tomate&lt;br /&gt;
  ap(config-ssid)#authentication open&lt;br /&gt;
  ap(config-ssid)#vlan 8&lt;br /&gt;
  ap(config-ssid)#mbssid guest-mode &lt;br /&gt;
  ap(config-ssid)#exit&lt;br /&gt;
  ap(config)#Interface dot11radio0&lt;br /&gt;
  ap(config)#ssid tomate&lt;br /&gt;
  ap(config-ssid)#no shutdown&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 mode wep mandatory&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 key 1 size 128bit 05050505050505050505050505&lt;br /&gt;
  ap(config-ssid)#End&lt;br /&gt;
Écrire les modifications:&lt;br /&gt;
  ap#write memory&lt;br /&gt;
Configurer le sous interface pour Dot11 radio 0 et Ethernet.&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
  ap(config)#interface Dot11Radio0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#interface GigabitEthernet0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#end&lt;br /&gt;
  ap#write memory&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie commune===&lt;br /&gt;
&lt;br /&gt;
==== Création de la VM ====&lt;br /&gt;
&lt;br /&gt;
Pour suivre le thème de la promo qui porte sur les fruits, nous&lt;br /&gt;
avons crée une machine virtuelle sur le serveur cordouan qui se nomme IMA5-GROSEILLE.&lt;br /&gt;
Cette VM hébergera un site web sécurisé qui se nommera www.groseille.space.&lt;br /&gt;
&lt;br /&gt;
Pour cela on utilisera les commandes : &lt;br /&gt;
xen-create-image pour créer la machine virtuelle&lt;br /&gt;
&lt;br /&gt;
et lv-create pour que les répertoires /var et /home soient sur les partitions LVM de l'hôte.&lt;br /&gt;
&lt;br /&gt;
Une fois la machine virtuelle crée, on créera la session avec:&lt;br /&gt;
&lt;br /&gt;
  xl create IMA5-GROSEILLE.cfg&lt;br /&gt;
dans le repertoire /etc/xen&lt;br /&gt;
&lt;br /&gt;
et :&lt;br /&gt;
&lt;br /&gt;
  xl console IMA5-GROSEILLE&lt;br /&gt;
pour accéder à la VM.&lt;br /&gt;
&lt;br /&gt;
==== Mise en place des services internet ====&lt;br /&gt;
&lt;br /&gt;
===== Serveur ssh =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur dns =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur de mail =====&lt;br /&gt;
&lt;br /&gt;
En effet nous avons du faire de notre machine virtuelle un serveur de mail pour pouvoir recevoir les&lt;br /&gt;
mail de gandi qui sont envoyé vers : admin@mon_domain donc pour nous : admin@groseille.space&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par certificats =====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par dnssec =====&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45814</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45814"/>
				<updated>2017-10-24T11:49:14Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Partie commune */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
*Avancement dans la compréhension de l'utilisation de la clef wifi&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 5 derniers points d'accès wifi.&lt;br /&gt;
*Connexion faite entre la machine avec la clef wifi et le point d'accès.&lt;br /&gt;
*Configuration de gandi et de notre serveur dns avec bind9&lt;br /&gt;
&lt;br /&gt;
==== séance 5 ====&lt;br /&gt;
&lt;br /&gt;
*Sécurisation de site web par certificats&lt;br /&gt;
*Sécurisation de site web par dnssec&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
Commencer par se mettre en mode configuration:&lt;br /&gt;
  ap&amp;gt;enable&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
  ap(config)#dot11 ssid tomate&lt;br /&gt;
  ap(config-ssid)#authentication open&lt;br /&gt;
  ap(config-ssid)#vlan 8&lt;br /&gt;
  ap(config-ssid)#mbssid guest-mode &lt;br /&gt;
  ap(config-ssid)#exit&lt;br /&gt;
  ap(config)#Interface dot11radio0&lt;br /&gt;
  ap(config)#ssid tomate&lt;br /&gt;
  ap(config-ssid)#no shutdown&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 mode wep mandatory&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 key 1 size 128bit 05050505050505050505050505&lt;br /&gt;
  ap(config-ssid)#End&lt;br /&gt;
Écrire les modifications:&lt;br /&gt;
  ap#write memory&lt;br /&gt;
Configurer le sous interface pour Dot11 radio 0 et Ethernet.&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
  ap(config)#interface Dot11Radio0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#interface GigabitEthernet0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#end&lt;br /&gt;
  ap#write memory&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie commune===&lt;br /&gt;
&lt;br /&gt;
==== Création de la VM ====&lt;br /&gt;
&lt;br /&gt;
Pour suivre le thème de la promo qui porte sur les fruits, nous&lt;br /&gt;
avons crée une machine virtuelle sur le serveur cordouan qui se nomme IMA5-GROSEILLE.&lt;br /&gt;
Cette VM hébergera un site web sécurisé qui se nommera www.groseille.space.&lt;br /&gt;
&lt;br /&gt;
Pour cela on utilisera les commandes : &lt;br /&gt;
xen-create-image pour créer la machine virtuelle&lt;br /&gt;
&lt;br /&gt;
et lv-create pour que les répertoires /var et /home soient sur les partitions LVM de l'hôte.&lt;br /&gt;
&lt;br /&gt;
Une fois la machine virtuelle crée, on créera la session avec:&lt;br /&gt;
&lt;br /&gt;
xl create IMA5-GROSEILLE.cfg&lt;br /&gt;
dans le repertoire /etc/xen&lt;br /&gt;
&lt;br /&gt;
et :&lt;br /&gt;
xl console IMA5-GROSEILLE&lt;br /&gt;
pour accéder à la VM.&lt;br /&gt;
&lt;br /&gt;
==== Mise en place des services internet ====&lt;br /&gt;
&lt;br /&gt;
===== Serveur ssh =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur dns =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur de mail =====&lt;br /&gt;
&lt;br /&gt;
En effet nous avons du faire de notre machine virtuelle un serveur de mail pour pouvoir recevoir les&lt;br /&gt;
mail de gandi qui sont envoyé vers : admin@mon_domain donc pour nous : admin@groseille.space&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par certificats =====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par dnssec =====&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45813</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45813"/>
				<updated>2017-10-24T11:36:30Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
*Avancement dans la compréhension de l'utilisation de la clef wifi&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 5 derniers points d'accès wifi.&lt;br /&gt;
*Connexion faite entre la machine avec la clef wifi et le point d'accès.&lt;br /&gt;
*Configuration de gandi et de notre serveur dns avec bind9&lt;br /&gt;
&lt;br /&gt;
==== séance 5 ====&lt;br /&gt;
&lt;br /&gt;
*Sécurisation de site web par certificats&lt;br /&gt;
*Sécurisation de site web par dnssec&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
Commencer par se mettre en mode configuration:&lt;br /&gt;
  ap&amp;gt;enable&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
  ap(config)#dot11 ssid tomate&lt;br /&gt;
  ap(config-ssid)#authentication open&lt;br /&gt;
  ap(config-ssid)#vlan 8&lt;br /&gt;
  ap(config-ssid)#mbssid guest-mode &lt;br /&gt;
  ap(config-ssid)#exit&lt;br /&gt;
  ap(config)#Interface dot11radio0&lt;br /&gt;
  ap(config)#ssid tomate&lt;br /&gt;
  ap(config-ssid)#no shutdown&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 mode wep mandatory&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 key 1 size 128bit 05050505050505050505050505&lt;br /&gt;
  ap(config-ssid)#End&lt;br /&gt;
Écrire les modifications:&lt;br /&gt;
  ap#write memory&lt;br /&gt;
Configurer le sous interface pour Dot11 radio 0 et Ethernet.&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
  ap(config)#interface Dot11Radio0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#interface GigabitEthernet0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#end&lt;br /&gt;
  ap#write memory&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Partie commune===&lt;br /&gt;
&lt;br /&gt;
==== Création de la VM ====&lt;br /&gt;
&lt;br /&gt;
==== Mise en place des services internet ====&lt;br /&gt;
&lt;br /&gt;
===== Serveur ssh =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur dns =====&lt;br /&gt;
&lt;br /&gt;
===== Serveur de mail =====&lt;br /&gt;
&lt;br /&gt;
En effet nous avons du faire de notre machine virtuelle un serveur de mail pour pouvoir recevoir les&lt;br /&gt;
mail de gandi qui sont envoyé vers : admin@mon_domain donc pour nous : admin@groseille.space&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par certificats =====&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===== Sécurisation de site web par dnssec =====&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45812</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45812"/>
				<updated>2017-10-24T11:32:00Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* séance 4 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
*Avancement dans la compréhension de l'utilisation de la clef wifi&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 5 derniers points d'accès wifi.&lt;br /&gt;
*Connexion faite entre la machine avec la clef wifi et le point d'accès.&lt;br /&gt;
*Configuration de gandi et de notre serveur dns avec bind9&lt;br /&gt;
&lt;br /&gt;
==== séance 5 ====&lt;br /&gt;
&lt;br /&gt;
*Sécurisation de site web par certificats&lt;br /&gt;
*Sécurisation de site web par dnssec&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
Commencer par se mettre en mode configuration:&lt;br /&gt;
  ap&amp;gt;enable&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
  ap(config)#dot11 ssid tomate&lt;br /&gt;
  ap(config-ssid)#authentication open&lt;br /&gt;
  ap(config-ssid)#vlan 8&lt;br /&gt;
  ap(config-ssid)#mbssid guest-mode &lt;br /&gt;
  ap(config-ssid)#exit&lt;br /&gt;
  ap(config)#Interface dot11radio0&lt;br /&gt;
  ap(config)#ssid tomate&lt;br /&gt;
  ap(config-ssid)#no shutdown&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 mode wep mandatory&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 key 1 size 128bit 05050505050505050505050505&lt;br /&gt;
  ap(config-ssid)#End&lt;br /&gt;
Écrire les modifications:&lt;br /&gt;
  ap#write memory&lt;br /&gt;
Configurer le sous interface pour Dot11 radio 0 et Ethernet.&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
  ap(config)#interface Dot11Radio0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#interface GigabitEthernet0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#end&lt;br /&gt;
  ap#write memory&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45811</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45811"/>
				<updated>2017-10-24T11:31:39Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* avancement du travail */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
*Avancement dans la compréhension de l'utilisation de la clef wifi&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 5 derniers points d'accès wifi.&lt;br /&gt;
*Connexion faite entre la machine avec la clef wifi et le point d'accès.&lt;br /&gt;
*Configuration de gandi et de notre serveur dns avec bind9&lt;br /&gt;
&lt;br /&gt;
==== séance 4 ====&lt;br /&gt;
&lt;br /&gt;
*Sécurisation de site web par certificats&lt;br /&gt;
*Sécurisation de site web par dnssec&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
Commencer par se mettre en mode configuration:&lt;br /&gt;
  ap&amp;gt;enable&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
  ap(config)#dot11 ssid tomate&lt;br /&gt;
  ap(config-ssid)#authentication open&lt;br /&gt;
  ap(config-ssid)#vlan 8&lt;br /&gt;
  ap(config-ssid)#mbssid guest-mode &lt;br /&gt;
  ap(config-ssid)#exit&lt;br /&gt;
  ap(config)#Interface dot11radio0&lt;br /&gt;
  ap(config)#ssid tomate&lt;br /&gt;
  ap(config-ssid)#no shutdown&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 mode wep mandatory&lt;br /&gt;
  ap(config-ssid)#Encryption vlan 8 key 1 size 128bit 05050505050505050505050505&lt;br /&gt;
  ap(config-ssid)#End&lt;br /&gt;
Écrire les modifications:&lt;br /&gt;
  ap#write memory&lt;br /&gt;
Configurer le sous interface pour Dot11 radio 0 et Ethernet.&lt;br /&gt;
  ap#configure terminal&lt;br /&gt;
  ap(config)#interface Dot11Radio0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#interface GigabitEthernet0.8&lt;br /&gt;
  ap(config-subif)#encapsulation dot1Q 8&lt;br /&gt;
  ap(config-subif)#bridge-group 8&lt;br /&gt;
  ap(config-subif)#end&lt;br /&gt;
  ap#write memory&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45684</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45684"/>
				<updated>2017-10-17T08:09:50Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Configuration d'un point d'accès */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
toujours commencer par:&lt;br /&gt;
  ap#enable&lt;br /&gt;
  ap#conf t&lt;br /&gt;
&lt;br /&gt;
et pour écrire les modifications:&lt;br /&gt;
&lt;br /&gt;
  ap#write&lt;br /&gt;
&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
&lt;br /&gt;
  ap(config)#dot11 ssid &amp;lt;nom ssid&amp;gt;&lt;br /&gt;
   ap(config-ssid)#authentication open&lt;br /&gt;
   ap(config-ssid)#mbssid guest-mode&lt;br /&gt;
&lt;br /&gt;
  ap(config)#interface dot11Radio0 &lt;br /&gt;
   ap(config-if)#ssid &amp;lt;nom ssid&amp;gt;&lt;br /&gt;
   ap(config-if)#encryption vlan X mode wep mandatory&lt;br /&gt;
   ap(config-if)#encryption vlan X key 1 size 128bit &amp;lt;26bit key&amp;gt;&lt;br /&gt;
   ap(config-if)#no shutdown&lt;br /&gt;
&lt;br /&gt;
Il faut aussi rajouter des sous-interfaces dot11Radio0.X et Gigabyte0.X:&lt;br /&gt;
&lt;br /&gt;
  ap(config)#interface dot11Radio0.1&lt;br /&gt;
  ap(config-subif)# encapsulation dot1Q 1 native&lt;br /&gt;
  ap(config-subif)#bridge group 1&lt;br /&gt;
  ap(config-subif)# interface FastEthernet0.1&lt;br /&gt;
  ap(config-subif)#bridge group 1&lt;br /&gt;
  ap(config-subif)# encapsulation dot1Q 1 native&lt;br /&gt;
  ap(config-subif)# end&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45683</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45683"/>
				<updated>2017-10-17T08:05:16Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Configuration d'un point d'accès pour le WEP */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès===&lt;br /&gt;
&lt;br /&gt;
toujours commencer par:&lt;br /&gt;
  ap#enable&lt;br /&gt;
  ap#conf t&lt;br /&gt;
&lt;br /&gt;
et pour écrire les modifications:&lt;br /&gt;
&lt;br /&gt;
  ap#write&lt;br /&gt;
&lt;br /&gt;
La configuration pour un point d'accès pour une sécurisation WEP est donc:&lt;br /&gt;
&lt;br /&gt;
  ap(config)#dot11 ssid &amp;lt;nom ssid&amp;gt;&lt;br /&gt;
   ap(config-ssid)#authentication open&lt;br /&gt;
   ap(config-ssid)#mbssid guest-mode&lt;br /&gt;
&lt;br /&gt;
  ap(config)#interface dot11Radio0 &lt;br /&gt;
   ap(config-if)#ssid &amp;lt;nom ssid&amp;gt;&lt;br /&gt;
   ap(config-if)#encryption vlan X mode wep mandatory&lt;br /&gt;
   ap(config-if)#encryption vlan X key 1 size 128bit &amp;lt;26bit key&amp;gt;&lt;br /&gt;
   ap(config-if)#no shutdown&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45682</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45682"/>
				<updated>2017-10-17T07:56:08Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
=== Configuration d'un point d'accès pour le WEP===&lt;br /&gt;
&lt;br /&gt;
  ap(config)#dot11 ssid &amp;lt;nom ssid&amp;gt;&lt;br /&gt;
   ap(config-ssid)#authentication open&lt;br /&gt;
   ap(config-ssid)#mbssid guest-mode&lt;br /&gt;
&lt;br /&gt;
  ap(config)#interface dot11Radio0 &lt;br /&gt;
   ap(config-if)#ssid &amp;lt;nom ssid&amp;gt;&lt;br /&gt;
   ap(config-if)#encryption vlan X mode wep mandatory&lt;br /&gt;
   ap(config-if)#encryption vlan X key 1 size 128bit &amp;lt;26bit key&amp;gt;&lt;br /&gt;
   ap(config-if)#no shutdown&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45681</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45681"/>
				<updated>2017-10-17T07:49:56Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
* Explication du projet&lt;br /&gt;
* Répartition du travail dans les différents groupes&lt;br /&gt;
* Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
*Exploration des locaux techniques de Polytech&lt;br /&gt;
*Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
*installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
*Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
*Mise en place des 2 premiers points d'accès wifi.&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45680</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45680"/>
				<updated>2017-10-17T07:48:58Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;br /&gt;
&lt;br /&gt;
=== avancement du travail ===&lt;br /&gt;
&lt;br /&gt;
==== séance 1 ====&lt;br /&gt;
&lt;br /&gt;
- Explication du projet&lt;br /&gt;
- Répartition du travail dans les différents groupes&lt;br /&gt;
- Gestion des adresses ip de chacun&lt;br /&gt;
&lt;br /&gt;
==== séance 2 ====&lt;br /&gt;
&lt;br /&gt;
- Exploration des locaux techniques de Polytech&lt;br /&gt;
- Création de la VM Xen sur le serveur Cordouan&lt;br /&gt;
- installation des paquetages nécessaires pour ssh, serveur WEB apache2 et le serveur DNS Bind&lt;br /&gt;
- Achat du domaine : &lt;br /&gt;
&lt;br /&gt;
==== séance 3 ====&lt;br /&gt;
&lt;br /&gt;
- Mise en place des 2 premiers points d'accès wifi.&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45674</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45674"/>
				<updated>2017-10-17T07:36:37Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* présentation */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg|800 px|thumb|center|Schéma du réseau du projet]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Fichier:Schema_PRA_2017.jpg&amp;diff=45672</id>
		<title>Fichier:Schema PRA 2017.jpg</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Fichier:Schema_PRA_2017.jpg&amp;diff=45672"/>
				<updated>2017-10-17T07:35:17Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : schema PRA 2017/2018&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;schema PRA 2017/2018&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45670</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45670"/>
				<updated>2017-10-17T07:34:29Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Configuration des points d'accès wifi ==&lt;br /&gt;
&lt;br /&gt;
=== présentation ===&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45669</id>
		<title>Cahier 2017 groupe n°3</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Cahier_2017_groupe_n%C2%B03&amp;diff=45669"/>
				<updated>2017-10-17T07:34:11Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : Page créée avec « = Configuration des points d'accès wifi =  == présentation ==  Schéma du réseau:   Fichier:schema_PRA_2017.jpg  Notre objectif est de mettre en place une VM sur le se... »&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;= Configuration des points d'accès wifi =&lt;br /&gt;
&lt;br /&gt;
== présentation ==&lt;br /&gt;
&lt;br /&gt;
Schéma du réseau:&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Fichier:schema_PRA_2017.jpg]]&lt;br /&gt;
&lt;br /&gt;
Notre objectif est de mettre en place une VM sur le serveur Cordouan et &lt;br /&gt;
d'installer les points d'accès wifi pour les autres groupes. On cherchera à faire&lt;br /&gt;
un banc de test et de tester la sécurité des chiffrements WEP et WPA.&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=TP_sysres_IMA5sc_2017/2018&amp;diff=45663</id>
		<title>TP sysres IMA5sc 2017/2018</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=TP_sysres_IMA5sc_2017/2018&amp;diff=45663"/>
				<updated>2017-10-17T07:17:21Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;== Répartition des binômes ==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;table border=&amp;quot;1&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;tr&amp;gt;&lt;br /&gt;
  &amp;lt;th&amp;gt;Cahier&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;Tâche particulière&amp;lt;/th&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;[[Cahier 2017 groupe n°1]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;td&amp;gt; Marius TRIMBUR Loïc TOMBAZZI &amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;td&amp;gt; Configuration Routeurs &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;[[Cahier 2017 groupe n°2]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;td&amp;gt; Antoine ARNAUDET Vivian SENAFFE&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;td&amp;gt; Configuration commutateur &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;[[Cahier 2017 groupe n°3]]&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;td&amp;gt; Bacem HAGUI Alexandre HUET&amp;lt;/td&amp;gt;&lt;br /&gt;
  &amp;lt;td&amp;gt; Configuration point d'accès&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;[[Cahier 2017 groupe n°4]]&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;[[Cahier 2017 groupe n°5]]&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;[[Cahier 2017 groupe n°6]]&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;[[Cahier 2017 groupe n°7]]&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;[[Cahier 2017 groupe n°8]]&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>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41617</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41617"/>
				<updated>2017-05-01T15:15:31Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Feuille d'heures */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Feuille d'heures===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
| '''24/04'''&lt;br /&gt;
*Modification de la présentation du wiki&lt;br /&gt;
*Modification de la fonctionnalité du bouton actualiser en changement d'activité&lt;br /&gt;
&lt;br /&gt;
| '''26/04'''&lt;br /&gt;
*Ajout de la page liste recette&lt;br /&gt;
&lt;br /&gt;
| '''27/04'''&lt;br /&gt;
*Ajout des listes recettes dans ListeRecette&lt;br /&gt;
*Soudure des derniers composants pour terminer le PCB. Tout est soudé sauf le bouton poussoir qui devait permettre un reset du RFduino. En cherchant d'ailleurs à souder ce bouton, nous avons retiré malencontreusement la piste de cuivre permettant de répartir le 3.3V du RFduino sur notre PCB. Notre accéléromètre qui ne marchait déjà pas vraiment n'est plus alimenté. Nous ferons sans notre accéléromètre pour le rendu final. &lt;br /&gt;
|-&lt;br /&gt;
|Semaine 15&lt;br /&gt;
| '''27/04''' (3 heures)&lt;br /&gt;
*Ajout des requêtes des recettes sur ListeRecette.java&lt;br /&gt;
*Création du fichier listeRecette.php sur le serveur pour faire la requête SQL et envoyer sur l'application.&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41616</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41616"/>
				<updated>2017-05-01T15:14:45Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Feuille d'heures */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Feuille d'heures===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
| '''24/04'''&lt;br /&gt;
*Modification de la présentation du wiki&lt;br /&gt;
*Modification de la fonctionnalité du bouton actualiser en changement d'activité&lt;br /&gt;
&lt;br /&gt;
| '''26/04'''&lt;br /&gt;
*Ajout de la page liste recette&lt;br /&gt;
&lt;br /&gt;
| '''27/04'''&lt;br /&gt;
*Ajout des listes recettes dans ListeRecette&lt;br /&gt;
*Soudure des derniers composants pour terminer le PCB. Tout est soudé sauf le bouton poussoir qui devait permettre un reset du RFduino. En cherchant d'ailleurs à souder ce bouton, nous avons retiré malencontreusement la piste de cuivre permettant de répartir le 3.3V du RFduino sur notre PCB. Notre accéléromètre qui ne marchait déjà pas vraiment n'est plus alimenté. Nous ferons sans notre accéléromètre pour le rendu final. &lt;br /&gt;
|-&lt;br /&gt;
| '''27/04''' (3 heures)&lt;br /&gt;
*Ajout des requêtes des recettes sur ListeRecette.java&lt;br /&gt;
*Création du fichier listeRecette.php sur le serveur pour faire la requête SQL et envoyer sur l'application.&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41534</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41534"/>
				<updated>2017-04-27T14:40:17Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Feuille d'heures */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Feuille d'heures===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
| '''24/04'''&lt;br /&gt;
*Modification de la présentation du wiki&lt;br /&gt;
*Modification de la fonctionnalité du bouton actualiser en changement d'activité&lt;br /&gt;
&lt;br /&gt;
| '''26/04'''&lt;br /&gt;
*Ajout de la page liste recette&lt;br /&gt;
&lt;br /&gt;
| '''25/04'''&lt;br /&gt;
*Ajout des listes recettes dans ListeRecette&lt;br /&gt;
&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41401</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41401"/>
				<updated>2017-04-24T15:46:32Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Feuille d'heures */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Feuille d'heures===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
| '''24/04'''&lt;br /&gt;
*Modification de la présentation du wiki&lt;br /&gt;
*Modification de la fonctionnalité du bouton actualiser en changement d'activité&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41400</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41400"/>
				<updated>2017-04-24T15:46:03Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Feuille d'heures */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Feuille d'heures===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
| '''24/04 (4 heures)'''&lt;br /&gt;
*Modification de la présentation du wiki&lt;br /&gt;
*Modification de la fonctionnalité du bouton actualiser en changement d'activité&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41399</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41399"/>
				<updated>2017-04-24T15:21:20Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Résumé */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Feuille d'heures===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41398</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41398"/>
				<updated>2017-04-24T15:20:35Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Résumé */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
 |}&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41397</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41397"/>
				<updated>2017-04-24T15:18:47Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Résumé */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
 |-&lt;br /&gt;
 !  !! Lundi 16-18h !! Mercredi 14-18h !! Jeudi 8-10h&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 1&lt;br /&gt;
&lt;br /&gt;
 | '''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
 | '''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
 | '''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 2&lt;br /&gt;
&lt;br /&gt;
 | '''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
 | '''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 3&lt;br /&gt;
&lt;br /&gt;
 | '''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
 | '''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
 |&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 4&lt;br /&gt;
&lt;br /&gt;
 | '''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
 | '''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
 | '''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
 | '''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
 | '''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 6&lt;br /&gt;
 | '''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
 | '''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 7&lt;br /&gt;
 | '''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
 | '''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
 | '''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 8&lt;br /&gt;
 | '''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
 | '''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
 | '''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 9&lt;br /&gt;
 | '''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
 | '''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
 | '''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 10&lt;br /&gt;
 | '''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
 | '''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 11&lt;br /&gt;
&lt;br /&gt;
 | '''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
 | '''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 | '''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 12 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''11/04''' (3 heures)&lt;br /&gt;
*Après avoir remarqué que le code de l'accéléro ne fonctionnait pas alors qu'il paraît correct, nous avons décidez de vérifier les propriétés électriques de notre montage.&lt;br /&gt;
En observant à l'analyseur logique, il semblerait que l'horloge de la liaison i2C n'est en fait qu'un signal bruité. Il faudra donc retenter de souder le composant quand cela sera possible.&lt;br /&gt;
&lt;br /&gt;
 | '''13/04''' (6 heures)&lt;br /&gt;
*Terminaison du programme RFduino qui fonctionne théoriquement, nous attendons de terminer les dernières soudures pour pouvoir le tester physiquement.&lt;br /&gt;
*En attendant de pouvoir réaliser des soudures, nous avons repris la partie communication bluetooth entre le RFduino et l'appli. Après avoir tenté d'utiliser un programme permettant de gérer le protocole GATT sans savoir envoyer ou recevoir de données, nous nous sommes orientés sur une communication plus basique basée sur de nombreux exemples que l'on peut voir sur le web.&lt;br /&gt;
&lt;br /&gt;
 | '''15/04''' (6 heures)&lt;br /&gt;
*Après s'être rendu compte que la communication plus &amp;quot;basique&amp;quot; que nous voulions utiliser n'était pas compatible avec le BLE, nous sommes une fois de plus repartis de zéro pour cette partie.&lt;br /&gt;
*Après quelques recherches, nous avons trouvé un programme réalisant la gestion d'un socket BLE sur le principe du protocole GATT. Grâce à celui-ci, il nous est possible de recevoir et d'envoyer des données via BLE sur RFduino ainsi que sur l'appli mobile.&lt;br /&gt;
&lt;br /&gt;
 |- &lt;br /&gt;
|Semaine 13 (Interruption pédagogique)&lt;br /&gt;
&lt;br /&gt;
 | '''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
|&lt;br /&gt;
|-&lt;br /&gt;
|Semaine 14&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
|&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41252</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41252"/>
				<updated>2017-04-17T16:03:22Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 12 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
'''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
====Semaine 10====&lt;br /&gt;
'''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
'''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
====Semaine 11====&lt;br /&gt;
&lt;br /&gt;
'''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
'''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
====Semaine 12====&lt;br /&gt;
&lt;br /&gt;
'''17/04 (4 heures)'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
*Actualisation automatique des données sur la page principale.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41251</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41251"/>
				<updated>2017-04-17T13:21:16Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 11 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
'''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
====Semaine 10====&lt;br /&gt;
'''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
'''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
====Semaine 11====&lt;br /&gt;
&lt;br /&gt;
'''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
'''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''06/04'''&lt;br /&gt;
*Problème pour faire fonctionner le code de l'accéléro. Il faudra le tester électriquement.&lt;br /&gt;
*Implantation du logo de l'appli &lt;br /&gt;
*Debuggage d'une requête de la page 'list'&lt;br /&gt;
*Documentation sur les listes déroulantes sous les EditTexts.&lt;br /&gt;
&lt;br /&gt;
====Semaine 12====&lt;br /&gt;
&lt;br /&gt;
'''17/04'''&lt;br /&gt;
*Ajout du singleton Etat pour partager l'état des aliments dans la réserve alimentaire&lt;br /&gt;
*Transfert des requêtes de la base de donnée vers le singleton pour optimiser l'actualisation et le partage des données.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41176</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41176"/>
				<updated>2017-04-05T15:54:50Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 10 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
'''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
====Semaine 10====&lt;br /&gt;
'''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
'''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
====Semaine 11====&lt;br /&gt;
&lt;br /&gt;
'''03/04'''&lt;br /&gt;
*Dé-soudage et resoudage de l'accéléromètre.&lt;br /&gt;
*Soudure des composants&lt;br /&gt;
&lt;br /&gt;
'''05/04'''&lt;br /&gt;
*Test du Buzzer&lt;br /&gt;
*Code de l'accéléromètre&lt;br /&gt;
*Création de l'Optali box (la boite qui contient le RFduino fixé au frigo)&lt;br /&gt;
*Finition de la fonction 'delete'&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41002</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=41002"/>
				<updated>2017-03-29T15:49:41Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 10 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
'''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
====Semaine 10====&lt;br /&gt;
'''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki pour la partie Altium.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
*Récupération de la carte PCB au service EEI.&lt;br /&gt;
&lt;br /&gt;
'''29/03'''&lt;br /&gt;
*Mise en place du tri des Produits avec un critère d'ordonnabilité variable&lt;br /&gt;
*Implémentation du champs recherche et action sur la liste&lt;br /&gt;
*Écriture des pages Php consume.php et delete.php pour décrémenter le nombre d'aliment dans le frigo ou le supprimer&lt;br /&gt;
*Récupération des composants&lt;br /&gt;
*Passage au four pour souder les premiers composants en CMS&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40802</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40802"/>
				<updated>2017-03-27T15:31:40Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 9 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
'''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
*Connexion possible entre le RFduino et notre appli mobile. Il faut maintenant pouvoir assurer un échange de données via du GATT.&lt;br /&gt;
&lt;br /&gt;
====Semaine 10====&lt;br /&gt;
'''27/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity (suite). Utilisation de la solution postman.&lt;br /&gt;
*Mise à jour du wiki.&lt;br /&gt;
*Gestion du dépôt git.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Nous avons envoyé nos fichiers Altium au service EEI afin qu'il puisse réaliser physiquement notre carte. Nous nous retrouvons donc avec notre carte PCB récupérée auprès du service EEI. Voici le rendu :&lt;br /&gt;
&lt;br /&gt;
[[Fichier:P46_carte.jpg|400px|thumb|center|Fabrication de notre carte PCB]]&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40714</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40714"/>
				<updated>2017-03-22T17:28:39Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 9 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''22/03'''&lt;br /&gt;
*Debuggage de la requête get de l'activité ListActivity&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40669</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40669"/>
				<updated>2017-03-22T14:25:46Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Page get.php */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui envoie la liste des aliments avec leur nom, leur date, leur quantité dans le frigo, la quantité d'exemplaires acheté en tout depuis la mise en place de l'appareil. Le tri se fera directement dans l'application mobile. &amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40668</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40668"/>
				<updated>2017-03-22T14:20:55Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Application Mobile */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 9====&lt;br /&gt;
'''20/03'''&lt;br /&gt;
*Réalisation de différents réglages pour pouvoir utiliser l'application Optali sur l'Android phone fourni par notre professeur (LG G4c)&lt;br /&gt;
*Recherche de docs concernant la partie java responsable de la communication Bluetooth.&lt;br /&gt;
*Reprise de la solution Tesseract pour la lecture de caractères.&lt;br /&gt;
&lt;br /&gt;
'''21/03''' (séance supplémentaire de 3 heures)&lt;br /&gt;
*Début du développement de la partie communication entre RFDuino et l'appli mobile. Nous pouvons détecter le RFduino à partir de Android Studio mais nous n'arrivons pas encore à nous connecter dessus directement.&lt;br /&gt;
*Finition de la fonctionnalité tesseract. La lecture de caractères est donc maintenant possible.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui récupère un nombre qui défini selon quoi la liste est trié (0=par nom, 1=par date, 2=nombre dans le frigo, 3= par nombre en tout). Elle récupère aussi un mot ou un début de mot ou rien pour faire une recherche dans la base. On utilisera la syntaxe:&amp;lt;br&amp;gt;&lt;br /&gt;
    Product.product='&amp;quot;.$Search.&amp;quot;%'&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté. Pour la lecture de caractère, nous utilisons la librairie tesseract.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Discussion:Projets_IMA4_SC_%26_SA_2016/2017&amp;diff=40666</id>
		<title>Discussion:Projets IMA4 SC &amp; SA 2016/2017</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Discussion:Projets_IMA4_SC_%26_SA_2016/2017&amp;diff=40666"/>
				<updated>2017-03-22T14:18:41Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Fiche de présence */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==  Notes sur les projets ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| Projet || Mini-cahier des charges || Mi-parcours || Fin de parcours || Wiki terminé || Rapport || Vidéo&lt;br /&gt;
|-&lt;br /&gt;
| P1 [[IMA4 2016/2017 P1|Climatisation du pauvre]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges conforme à la discussion avec l'encadrant. Présentation propre avec un effort d'illustration. Pas de liste des tâches ou de calendrier prévisionnel. Quelques coquilles corrigées.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Abandon constaté&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P2 [[IMA4 2016/2017 P2|Réseau de capteurs sur smartphone]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges succinct. Attention à la rédaction en français. Un effort d'illustration avec un schéma global. Une liste des tâches, sans chiffrage pour l'instant.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;De gros problèmes de rédaction en français bien compréhensibles.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un Wiki très bien tenu et très bien illustré, une avancée du travail parfaitement expliquée, continuez ainsi !&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P10 [[IMA4 2016/2017 P10|Application de suivi de prise de médicaments]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges assez précis. Pas trop de coquilles. Une liste des tâches un peu succincte. Réfléchissez bien à la structure du programme pour la mise à jour simplifiée des fiches sur l'application.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Feuille d'heures non utilisée, Wiki non mis à jour.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Pour les 4 premières semaine, des paragraphes correctement rédigés et bien illustré, il était possible de se faire une idée de l'avancée du projet.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P11 [[IMA4 2016/2017 P11|Amélioration de l'accueil d'enfants hospitalisés]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges précis. Forme très correcte. Une liste des tâches réfléchie. Il y a même un calendrier prévisionnel.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Aucune utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un excellent Wiki, très complet, très bien illustré, le travail est parfaitement décrit !&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P14 [[IMA4 2016/2017 P14|Sex toy connecté]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges très précis. De même pour la liste des tâches. L'utilisation de bioloïds ne semble pas justifiée. Pourquoi ne parlez-vous de capteurs que dans le cadre d'un seul des deux appareils ?&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Feuille d'heures très bien exploitée.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Wiki très bien rédigé mais absolument pas illustré, un peu court peut être.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P18 [[IMA4 2016/2017 P18|Education de la position de tête]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Pas mal de coquilles corrigées. Une certaine imprécision (confusion Arduino Mega et ATMEGA, flou dans la liste des tâches). Cela dit un cahier des charges et une liste des tâches sont présentés. Pensez aux problèmes de calibration du système et à la transmission des données vers un smartphone par exemple.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Quelques coquilles, le Wiki est un peu vide, pas totalement à jour, dommage que le cahier des charges joint ne soit pas intégré directement au Wiki.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P19 [[IMA4 2016/2017 P19|Orchestre électronique]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Synthèse correcte de l'entretien avec l'encadrant. Le cahier des charges est correct mais moins précis que le sujet. Le découpage en tâche est un peu rapide : l'analyse des fichiers MIDI devrait être sous-découpée. Presque pas de coquilles.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Très bonne utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Wiki très synthétique dans un français très correct, à jour, travail sur l'imprimante bien décrit, pas beaucoup d'information sur l'analyse du fichier MIDI.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P20 [[IMA4 2016/2017 P20|Création d’un environnement virtuel de test]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Très bonne prise en main du sujet. Cahier des charges très précis. Liste des tâches bien détaillée. Orthographe irréprochable.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Feuille d'heures bien exploitée, Wiki très bien rédigé, illustré, l'avancé du travail est bien présenté.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P21 [[IMA4 2016/2017 P21|Conception d’une MPS Polyvalente]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Une grande partie du cahier des charges est une copie du sujet. Définissez ce qu'est une Referee Box. D'un autre coté, le cahier des charges est précis. La liste des tâches est correcte. Cependant elle semble omettre la partie mécanique de la MPS ? Pas de coquilles.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Wiki bien rédigé et très bien illustré, le travail effectué est présenté. Il serait bien d'avoir une carte rapidement.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P25 [[IMA4 2016/2017 P25|Robot mobile Polytech'Lille]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Des imprécisions dans la transcription de la réunion avec l'encadrant. Voire des contre-sens. Le cahier des charges est assez complet. Pas de liste des tâches. Vous avez vraiment passé 3h sur la rédaction du cahier des charges ? (edit d'Alex : certainement pas)&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Une liste des tâches ajoutée.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le Wiki est principalement constitué des schématiques et des PCB des différentes cartes. Après tout c'est un point important de votre travail mais le soin apporté à ces productions, s'il s'améliore était initialement assez faible. La rédaction est presque absente ou d'un niveau faible. Vous devriez déjà avoir des cartes en production.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P26 [[IMA4 2016/2017 P26|Train de véhicules]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Le texte a été modifié pour être compréhensible mais le problème n'est pas là. Vous n'avez pas du tout transcrit les demandes de l'encadrant mais donné le sujet du projet de l'an passé. Cette année vous devez améliorer l'aspect esthétique des robots, construire le quatrième robot et améliorer la détection infra-rouge en utilisant le protocole utilisé par les télécommandes infra-rouges classiques. Vous n'avez pas, non plus, donné une liste précise des tâches à réaliser.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges révisé avec l'encadrant. La listes des tâches à réaliser est à préciser.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Wiki assez vide, le seul élément probant est la présentation de la nouvelle version de la carte des robots suiveurs. Des coquilles, ce que l'on peut difficilement vous reprocher. Il faudrait maintenant avoir un code pour le protocole RC5, utilisez deux Arduinos pour avoir un prototype de démonstration.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P27 [[IMA4 2016/2017 P27|Sonde atmosphérique]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;La restitution de la discussion avec l'encadrant est très correcte et le cahier des charge est précisément décrit. Par contre la liste des tâches à effectuer n'est pas dressée en commençant par l'étude des conditions à respecter pour lancer un tel ballon.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pratiquement pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Wiki un peu rapide, illustré, quelques coquilles. Peu de résultats à ce jour, vous devriez avoir votre carte et avoir conduit un test de communication avec les capteurs et les modules LoRa.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P28 [[IMA4 2016/2017 P28|Adaptation d'un émulateur de calculatrices TI]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Assimilation très correcte des demandes faites par les encadrants. Un cahier des charges précis. De même pour la liste des tâches. Un effort de présentation sans trop de coquilles. Cependant quelques erreurs relevées par M. Dhaussy, merci de corriger le CdC au vu des remarques transmises.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Wiki à l'abandon, impossible de savoir où vous en êtes dans le travail. Réagissez immédiatement !&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P29 [[IMA4 2016/2017 P29|Conteneurs pour site Web]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le cahier des charges est une recopie du sujet, avec des passages soulignés, certes. Une liste des tâches très précise mais uniquement orientée développement Web. Il manque toute la partie étude et utilisation des éco-systèmes d'isolation.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges plus précis, vous pouvez vous lancer.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Partie travail du Wiki presque vide, pas d'illustration, il est à craindre que le travail ne soit pas plus avancé que le Wiki.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P30 [[IMA4 2016/2017 P30|Voiture radiocommandée controlée par gant]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges très précis avec déjà des idées pour la réalisation. Liste des tâches à effectuer très détaillée.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Très bon Wiki, bien illustré, travail bien décrit.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P31 [[IMA4 2016/2017 P31|Accueil personnalisé par drone]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Très peu d'apport par rapport au sujet qui est lui même assez bref. Il ne semble pas y avoir eu de rencontre avec l'encadrant dans les temps impartis ? Pas de liste des tâches.&amp;lt;/font&amp;gt; &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges révisés sous la direction de deux encadrants.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Wiki vide, rien de concret semble avoir été réalisé, aucune illustration. Il va falloir mettre les bouchées quadruples ...&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P32 [[IMA4 2016/2017 P32|Sécurité: brouilleur d'ondes]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le cahier des charges est une paraphrase du sujet. Dans la liste des tâches il semble curieux de ne pas commencer par l'étude des brouilleurs. Avez-vous échangé avec vos encadrants ?&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen&amp;quot;&amp;gt;Cahier des charges plus précis.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Tentative d'utilisation de la feuille d'heures, definissez au préalable les lignes dans ce tableau.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Un Wiki trop rapidement rédigé en style télégraphique avec des coquilles, à la lecture du Wiki il est difficile de croire que vous avez passé le nombre d'heures annoncées pour si peu de résultats.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P33 [[IMA4 2016/2017 P33|Sécurité: ingénierie inverse de protocole réseau]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Une simple paraphrase du sujet. Pas de liste des tâches à réaliser. Il semble que vous n'avez pas réussi à échanger avec vos encadrants dans les temps impartis. Des coquilles (corrigées).&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Wiki pratiquement vide, l'image n'apporte rien, le Wiki ne reflète que peu de travail.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P34 [[IMA4 2016/2017 P34|Interface Haptique, simulateur de formes et de textures]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Une rencontre avec les encadrants. Un cahier des charges assez précis. Pas de section &amp;quot;tâches à réaliser&amp;quot; mais une section &amp;quot;notre travail&amp;quot; qui pourrait en tenir lieu avec un effort de structuration.&amp;lt;/font&amp;gt;&lt;br /&gt;
|  &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Utilisation de la feuille d'heure.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Un Wiki trop synthétique, des illustrations à venir ?&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P37 [[IMA4 2016/2017 P37|Gamelle connectée]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Présentez les objectifs généraux pour commencer. Un cahier des charges très précis mais il manque la liste des tâches à effectuer. Débutez la par l'état de l'art sur les produits déjà commercialisés.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Bonne utilisation de la fichier d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Excellent Wiki mais non mis à jour ; il s'arrête à la semaine 4.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P38 [[IMA4 2016/2017 P38|Veilleuse enfant connectée]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le sujet du projet à été recopié. Les deux sections personnelles sont assez mal rédigées. Un contre-sens sur le mode de connexion du prototype actuel : la veilleuse est configurée en point d'accès. Parlez plutôt de &amp;quot;Précisions sur le cahier des charges&amp;quot; plutôt que de &amp;quot;Problèmes rencontrés sur l'étude du projet&amp;quot;. Renommez aussi &amp;quot;Nouveau cahier des charges&amp;quot; en &amp;quot;Tâches à réaliser&amp;quot; et ajouter les autres tâches demandées dans le sujet.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges et listes des tâches finalement validés par deux encadrants.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Bonne utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Bon Wiki, correctement illustré. Par contre faudrait arriver à présenter une réalisation, vous prenez du retard.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P39 [[IMA4 2016/2017 P39|Projecteur laser]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: firebrick;&amp;quot;&amp;gt;Uniquement une recopie du sujet.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un cahier des charges et une liste de tâches corrects après discussion avec deux encadrants.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Le Wiki n'est pas à jour, il s'arrête à la semaine 4. Bien illustré. Le travail se concentre sur la partie logicielle, en particulier avec un traitement d'image non demandé mais intéressant. Il faudrait se pencher très vite sur le contrôle des lasers.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P44 [[IMA4 2016/2017 P44|3615 Facebook]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un très bon cahier des charges. Le sujet semble être bien assimilé. Une liste des tâches correcte (il faudrait peut-être détailler la programmation du proxy).&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un Wiki tout simplement parfait.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P46 [[IMA4 2016/2017 P46|Aide anti-gaspillage alimentaire ]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un excellent cahier des charges. Liste des tâches très détaillée. Parfait.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Wiki très détaillé, correctement illustré, le travail effectué est présenté correctement.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P47 [[IMA4 2016/2017 P47|Modélisation d’un robot mobile]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Vous n'avez pas su vous adapter à la syntaxe mediawiki. Correction pour obtenir un CdC lisible. Une recopie intégrale du sujet. Un cahier des charges qui ressemble plus à une liste des tâches à effectuer.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Vous utilisez bien la syntaxe mediawiki maintenant. Par contre il n'y a toujours pas de cahier des charges.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Feuille d'heures utilisée. Un Wiki mis à jour. Il est très difficile de se faire une idée de votre travail. Il semble que vous soyez actuellement plutôt en TP qu'en projet ?&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P48 [[IMA4 2016/2017 P48|Surveillance d'un robot mobile]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Un cahier des charges en 4 lignes, c'est trop court. En particulier rien sur le contexte du projet à savoir le matériel ou le simulateur sur lequel les tests seront effectués. Une liste des tâches, cette liste est-elle avalisé par l'encadrant ?&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Toujours pas de cahier des charges.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Feuille d'heures correctement remplie. Wiki plutôt vide. Il est difficile de se faire une idée du travail réalisé, vous semblez bloqué à l'étape bibliographie.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Fiche de présence ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Projet !! Elèves !! Séance 1 (25/01) !! Séance 2 (01/02) !! Séance 3 (08/02) !! Séance 4 (15/02) !! Séance 5 (01/03) !! Séance 6 (08/03) !! Séance 7 !! Séance 8 !! Séance 9 !! Séance 10&lt;br /&gt;
|-&lt;br /&gt;
| P1 [[IMA4 2016/2017 P1|Climatisation du pauvre]]&lt;br /&gt;
| Haroun Abdelali&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| D317 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D309 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D309 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P2 [[IMA4 2016/2017 P2|Réseau de capteurs sur smartphone]]&lt;br /&gt;
| Wenyu sun / Xinyue xu&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Presentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| C201 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| C201&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| C201&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;amp;C201&lt;br /&gt;
| E304&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P10 [[IMA4 2016/2017 P10|Application de suivi de prise de médicaments]]&lt;br /&gt;
| Martin Rohmer / Kévin Godesence&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P11 [[IMA4 2016/2017 P11|Amélioration de l'accueil d'enfants hospitalisés]]&lt;br /&gt;
| Robin Cavalieri / Edmur Lopes&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P14 [[IMA4 2016/2017 P14|Sex toy connecté]]&lt;br /&gt;
| Cedric Roussel / Thomas Stievenard&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P18 [[IMA4 2016/2017 P18|Education de la position de tête]]&lt;br /&gt;
| Mame Arame Diop / Amina Fahem&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P19 [[IMA4 2016/2017 P19|Orchestre électronique]]&lt;br /&gt;
| Antoine Arnaudet / Vivian Senaffe&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Arnaudet présent&amp;lt;/font&amp;gt;&amp;lt;br /&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Senaffe absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P20 [[IMA4 2016/2017 P20|Création d’un environnement virtuel de test]]&lt;br /&gt;
| Butaye Marianne / François Duport&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P21 [[IMA4 2016/2017 P21|Conception d’une MPS Polyvalente]]&lt;br /&gt;
| Samy Belhouachi / François Xavier Cockenpot&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 et E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 et E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P25 [[IMA4 2016/2017 P25|Robot mobile Polytech'Lille]]&lt;br /&gt;
| Cheikh Said Ahmed / Khadija El Messnaoui&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Said-Ahmed présent&amp;lt;/font&amp;gt;&amp;lt;br /&amp;gt;&amp;lt;font style=&amp;quot;color: red&amp;quot;&amp;gt;El Messnaoui absente&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P26 [[IMA4 2016/2017 P26|Train de véhicules]]&lt;br /&gt;
| Manlu Luo / Xinyi Wang&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P27 [[IMA4 2016/2017 P27|Sonde atmosphérique]]&lt;br /&gt;
| Olivier Mahieux / Grillère Baptiste&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P28 [[IMA4 2016/2017 P28|Adaptation d'un émulateur de calculatrices TI]]&lt;br /&gt;
| Rodolphe Toin&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présent&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305/301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P29 [[IMA4 2016/2017 P29|Conteneurs pour site Web]]&lt;br /&gt;
| | E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Rattrapage DS&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Abs&amp;lt;/font&amp;gt;&lt;br /&gt;
| Malade&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| Malade&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| Malade&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P30 [[IMA4 2016/2017 P30|Voiture radiocommandée controlée par gant]]&lt;br /&gt;
| Thomas Gosse / Bacem Hagui&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Gosse présent&amp;lt;/font&amp;gt;&amp;lt;br /&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Hagui absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P31 [[IMA4 2016/2017 P31|Accueil personnalisé par drone]]&lt;br /&gt;
| Tristan Hart / Etienne Profit&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P32 [[IMA4 2016/2017 P32|Sécurité: brouilleur d'ondes]]&lt;br /&gt;
| Nicky Ung / Alexis Macherez&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304/301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304/C205&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P33 [[IMA4 2016/2017 P33|Sécurité: ingénierie inverse de protocole réseau]]&lt;br /&gt;
| Oumaima Naanaa&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Absente&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présente&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P34 [[IMA4 2016/2017 P34|Interface Haptique, simulateur de formes et de textures]]&lt;br /&gt;
| Alice Coffin / Diana Marrucho&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P37 [[IMA4 2016/2017 P37|Gamelle connectée]]&lt;br /&gt;
| Lutecia Damiens / Alexis Dorian&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| Fabricarium&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P38 [[IMA4 2016/2017 P38|Veilleuse enfant connectée]]&lt;br /&gt;
| Hugo Delatte&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P39 [[IMA4 2016/2017 P39|Projecteur laser]]&lt;br /&gt;
| Loïc Tombazzi / Marius Trimbur&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P44 [[IMA4 2016/2017 P44|3615 Facebook]]&lt;br /&gt;
| Marouan Mcharfi / Tristan lopez&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P46 [[IMA4 2016/2017 P46|Aide anti-gaspillage alimentaire ]]&lt;br /&gt;
| Alexandre Huet / François Lefevre&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P47 [[IMA4 2016/2017 P47|Modélisation d’un robot mobile]]&lt;br /&gt;
| Djamil Mohamed / Hamza Kerroum&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P48 [[IMA4 2016/2017 P48|Surveillance d'un robot mobile]]&lt;br /&gt;
| Jean-Baptiste Saison&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présent&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présent&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A/C305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A/D322 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A/D322 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40435</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40435"/>
				<updated>2017-03-16T09:05:54Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 8 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
'''15/03'''&lt;br /&gt;
*Ajout de la JsonArrayRequest dans la page ListActivity.&lt;br /&gt;
*Nous nous sommes rendus compte au moment de programmer la liaison I2C de l'accéléromètre avec la RFDuino que nous avions oublié de mettre des résistances pull-up entre l'alimentation du composant et les broches SDA et SCL. Les modifications ont donc été faites puis nous avons envoyé finalement notre PCB à la fabrication.&lt;br /&gt;
&lt;br /&gt;
'''16/03'''&lt;br /&gt;
*Changement de stratégie au niveau de la requête JsonArrayRequest. On récupère toute la base et ensuite le traitement sera effectuer dans l'application mobile.&lt;br /&gt;
*Rédaction de la partie Altium du wiki.&lt;br /&gt;
*Recherche de docs sur le système bluetooth du RFduino.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui récupère un nombre qui défini selon quoi la liste est trié (0=par nom, 1=par date, 2=nombre dans le frigo, 3= par nombre en tout). Elle récupère aussi un mot ou un début de mot ou rien pour faire une recherche dans la base. On utilisera la syntaxe:&amp;lt;br&amp;gt;&lt;br /&gt;
    Product.product='&amp;quot;.$Search.&amp;quot;%'&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Après quelques modifications sur le montage prévu initialement, c'est-à-dire en enlevant une résistance entre un GPIO et l'alimentation de l'accéléromètre ainsi qu'en rajoutant des résistances pull-up sur les broches de notre liaison i2C (SDA et SCL) et un bouton poussoir en plus pour permettre un reset du RFDuino, nous avons pu créer notre schematic global pour en faire un PCB et l'exporter au format Gerber. De ce fait, le service EEI de Polytech pourra réaliser la gravure de notre carte PCB.&lt;br /&gt;
&lt;br /&gt;
Voici quelques photos pour illustrer notre projet sur Altium : &lt;br /&gt;
&lt;br /&gt;
[[Fichier:Finalproto_sch.PNG|400px|thumb|left|Schematic du montage final]]&lt;br /&gt;
[[Fichier:Finalproto_pcb.PNG|400px|thumb|center|PCB du montage final]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
On retrouve sur notre PCB final les headers, respectivement de 8 et 5 pins, de part et d'autre de la carte, qui représentent le RFDuino, où nous souderons des broches pour qu'elles puissent être intégrées au RFDuino. On note la présence de 5 autres headers de 2 pins, dont 3 pour des LEDs puis les 2 autres pour le buzzer et le bouton poussoir. Ce qui reste sont les composants CMS avec plusieurs composants à 2 pattes qui sont toutes les résistances de notre montage, celles de protection pour les LEDs et les pull-ups pour l'accéléromètre. Le dernier composant à 8 pattes est donc bien l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Quelques difficultés ont été rencontrées durant ce travail notamment concernant les contraintes de construction sur le PCB final. En effet, les composants CMS choisis (surtout l'accéléromètre) étant parfois très petits, Altium n'accepte pas forcément le faible espacement entre les différentes pattes des composants, ce qui pose problème lors de la compilation. De plus, le plan de masse ne prenait pas en compte tous les éléments devant être rattachés à la masse. Il a fallu légèrement déplacer les headers représentant le RFDuino pour que cela soit possible. Il faudra alors peut-être légèrement plier les broches qui viendront s'intégrer sur le RFDuino pour ajouter notre PCB sur le RFDuino.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40338</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40338"/>
				<updated>2017-03-15T13:59:29Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Web service */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
Page qui récupère un nombre qui défini selon quoi la liste est trié (0=par nom, 1=par date, 2=nombre dans le frigo, 3= par nombre en tout). Elle récupère aussi un mot ou un début de mot ou rien pour faire une recherche dans la base. On utilisera la syntaxe:&amp;lt;br&amp;gt;&lt;br /&gt;
    Product.product='&amp;quot;.$Search.&amp;quot;%'&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40334</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40334"/>
				<updated>2017-03-15T13:51:20Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Web service */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page init.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet d'initier l'accès à la base de donnée sur le serveur. Elle est requise pour les pages qui suivent.&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
====Page get.php====&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40332</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40332"/>
				<updated>2017-03-15T13:46:55Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 8 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''08/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
'''09/03'''&lt;br /&gt;
*Nous nous sommes rendus compte qu'il était nécessaire de rajouter un bouton poussoir sur notre montage afin de permettre la réinitialisation de notre RFDuino si nécessaire. Nous devons également faire en sorte de pouvoir poser notre carte PCB directement sur notre RFDuino en utilisant des broches. Nous devons donc rajouter ces éléments-ci.&lt;br /&gt;
*Ecriture de la page get.php&lt;br /&gt;
*Premiers tests sur la ListView de l'activité ListActivity.&lt;br /&gt;
&lt;br /&gt;
====Semaine 8====&lt;br /&gt;
'''13/03'''&lt;br /&gt;
*Recherche de pistes concernant la programmation RFDuino. Nous pouvons la détecter en bluetooth via un smartphone Android.&lt;br /&gt;
*Finition du Tablelayout et du code java associé sur la page ListActivity.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=Discussion:Projets_IMA4_SC_%26_SA_2016/2017&amp;diff=40329</id>
		<title>Discussion:Projets IMA4 SC &amp; SA 2016/2017</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=Discussion:Projets_IMA4_SC_%26_SA_2016/2017&amp;diff=40329"/>
				<updated>2017-03-15T13:43:09Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Fiche de présence */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==  Notes sur les projets ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
| Projet || Mini-cahier des charges || Mi-parcours || Fin de parcours || Wiki terminé || Rapport || Vidéo&lt;br /&gt;
|-&lt;br /&gt;
| P1 [[IMA4 2016/2017 P1|Climatisation du pauvre]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges conforme à la discussion avec l'encadrant. Présentation propre avec un effort d'illustration. Pas de liste des tâches ou de calendrier prévisionnel. Quelques coquilles corrigées.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Abandon constaté&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P2 [[IMA4 2016/2017 P2|Réseau de capteurs sur smartphone]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges succinct. Attention à la rédaction en français. Un effort d'illustration avec un schéma global. Une liste des tâches, sans chiffrage pour l'instant.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;De gros problèmes de rédaction en français bien compréhensibles.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un Wiki très bien tenu et très bien illustré, une avancée du travail parfaitement expliquée, continuez ainsi !&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P10 [[IMA4 2016/2017 P10|Application de suivi de prise de médicaments]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges assez précis. Pas trop de coquilles. Une liste des tâches un peu succincte. Réfléchissez bien à la structure du programme pour la mise à jour simplifiée des fiches sur l'application.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Feuille d'heures non utilisée, Wiki non mis à jour.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Pour les 4 premières semaine, des paragraphes correctement rédigés et bien illustré, il était possible de se faire une idée de l'avancée du projet.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P11 [[IMA4 2016/2017 P11|Amélioration de l'accueil d'enfants hospitalisés]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges précis. Forme très correcte. Une liste des tâches réfléchie. Il y a même un calendrier prévisionnel.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Aucune utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un excellent Wiki, très complet, très bien illustré, le travail est parfaitement décrit !&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P14 [[IMA4 2016/2017 P14|Sex toy connecté]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges très précis. De même pour la liste des tâches. L'utilisation de bioloïds ne semble pas justifiée. Pourquoi ne parlez-vous de capteurs que dans le cadre d'un seul des deux appareils ?&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Feuille d'heures très bien exploitée.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Wiki très bien rédigé mais absolument pas illustré, un peu court peut être.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P18 [[IMA4 2016/2017 P18|Education de la position de tête]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Pas mal de coquilles corrigées. Une certaine imprécision (confusion Arduino Mega et ATMEGA, flou dans la liste des tâches). Cela dit un cahier des charges et une liste des tâches sont présentés. Pensez aux problèmes de calibration du système et à la transmission des données vers un smartphone par exemple.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Quelques coquilles, le Wiki est un peu vide, pas totalement à jour, dommage que le cahier des charges joint ne soit pas intégré directement au Wiki.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P19 [[IMA4 2016/2017 P19|Orchestre électronique]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Synthèse correcte de l'entretien avec l'encadrant. Le cahier des charges est correct mais moins précis que le sujet. Le découpage en tâche est un peu rapide : l'analyse des fichiers MIDI devrait être sous-découpée. Presque pas de coquilles.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Très bonne utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Wiki très synthétique dans un français très correct, à jour, travail sur l'imprimante bien décrit, pas beaucoup d'information sur l'analyse du fichier MIDI.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P20 [[IMA4 2016/2017 P20|Création d’un environnement virtuel de test]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Très bonne prise en main du sujet. Cahier des charges très précis. Liste des tâches bien détaillée. Orthographe irréprochable.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Feuille d'heures bien exploitée, Wiki très bien rédigé, illustré, l'avancé du travail est bien présenté.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P21 [[IMA4 2016/2017 P21|Conception d’une MPS Polyvalente]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Une grande partie du cahier des charges est une copie du sujet. Définissez ce qu'est une Referee Box. D'un autre coté, le cahier des charges est précis. La liste des tâches est correcte. Cependant elle semble omettre la partie mécanique de la MPS ? Pas de coquilles.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Wiki bien rédigé et très bien illustré, le travail effectué est présenté. Il serait bien d'avoir une carte rapidement.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P25 [[IMA4 2016/2017 P25|Robot mobile Polytech'Lille]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Des imprécisions dans la transcription de la réunion avec l'encadrant. Voire des contre-sens. Le cahier des charges est assez complet. Pas de liste des tâches. Vous avez vraiment passé 3h sur la rédaction du cahier des charges ? (edit d'Alex : certainement pas)&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Une liste des tâches ajoutée.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le Wiki est principalement constitué des schématiques et des PCB des différentes cartes. Après tout c'est un point important de votre travail mais le soin apporté à ces productions, s'il s'améliore était initialement assez faible. La rédaction est presque absente ou d'un niveau faible. Vous devriez déjà avoir des cartes en production.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P26 [[IMA4 2016/2017 P26|Train de véhicules]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Le texte a été modifié pour être compréhensible mais le problème n'est pas là. Vous n'avez pas du tout transcrit les demandes de l'encadrant mais donné le sujet du projet de l'an passé. Cette année vous devez améliorer l'aspect esthétique des robots, construire le quatrième robot et améliorer la détection infra-rouge en utilisant le protocole utilisé par les télécommandes infra-rouges classiques. Vous n'avez pas, non plus, donné une liste précise des tâches à réaliser.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges révisé avec l'encadrant. La listes des tâches à réaliser est à préciser.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Wiki assez vide, le seul élément probant est la présentation de la nouvelle version de la carte des robots suiveurs. Des coquilles, ce que l'on peut difficilement vous reprocher. Il faudrait maintenant avoir un code pour le protocole RC5, utilisez deux Arduinos pour avoir un prototype de démonstration.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P27 [[IMA4 2016/2017 P27|Sonde atmosphérique]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;La restitution de la discussion avec l'encadrant est très correcte et le cahier des charge est précisément décrit. Par contre la liste des tâches à effectuer n'est pas dressée en commençant par l'étude des conditions à respecter pour lancer un tel ballon.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pratiquement pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Wiki un peu rapide, illustré, quelques coquilles. Peu de résultats à ce jour, vous devriez avoir votre carte et avoir conduit un test de communication avec les capteurs et les modules LoRa.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P28 [[IMA4 2016/2017 P28|Adaptation d'un émulateur de calculatrices TI]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Assimilation très correcte des demandes faites par les encadrants. Un cahier des charges précis. De même pour la liste des tâches. Un effort de présentation sans trop de coquilles. Cependant quelques erreurs relevées par M. Dhaussy, merci de corriger le CdC au vu des remarques transmises.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Wiki à l'abandon, impossible de savoir où vous en êtes dans le travail. Réagissez immédiatement !&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P29 [[IMA4 2016/2017 P29|Conteneurs pour site Web]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le cahier des charges est une recopie du sujet, avec des passages soulignés, certes. Une liste des tâches très précise mais uniquement orientée développement Web. Il manque toute la partie étude et utilisation des éco-systèmes d'isolation.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges plus précis, vous pouvez vous lancer.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Partie travail du Wiki presque vide, pas d'illustration, il est à craindre que le travail ne soit pas plus avancé que le Wiki.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P30 [[IMA4 2016/2017 P30|Voiture radiocommandée controlée par gant]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Cahier des charges très précis avec déjà des idées pour la réalisation. Liste des tâches à effectuer très détaillée.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Pas d'utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Très bon Wiki, bien illustré, travail bien décrit.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P31 [[IMA4 2016/2017 P31|Accueil personnalisé par drone]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Très peu d'apport par rapport au sujet qui est lui même assez bref. Il ne semble pas y avoir eu de rencontre avec l'encadrant dans les temps impartis ? Pas de liste des tâches.&amp;lt;/font&amp;gt; &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges révisés sous la direction de deux encadrants.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Wiki vide, rien de concret semble avoir été réalisé, aucune illustration. Il va falloir mettre les bouchées quadruples ...&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P32 [[IMA4 2016/2017 P32|Sécurité: brouilleur d'ondes]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le cahier des charges est une paraphrase du sujet. Dans la liste des tâches il semble curieux de ne pas commencer par l'étude des brouilleurs. Avez-vous échangé avec vos encadrants ?&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen&amp;quot;&amp;gt;Cahier des charges plus précis.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Tentative d'utilisation de la feuille d'heures, definissez au préalable les lignes dans ce tableau.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Un Wiki trop rapidement rédigé en style télégraphique avec des coquilles, à la lecture du Wiki il est difficile de croire que vous avez passé le nombre d'heures annoncées pour si peu de résultats.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P33 [[IMA4 2016/2017 P33|Sécurité: ingénierie inverse de protocole réseau]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Une simple paraphrase du sujet. Pas de liste des tâches à réaliser. Il semble que vous n'avez pas réussi à échanger avec vos encadrants dans les temps impartis. Des coquilles (corrigées).&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Mauvaise utilisation de la feuille d'heures.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Wiki pratiquement vide, l'image n'apporte rien, le Wiki ne reflète que peu de travail.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P34 [[IMA4 2016/2017 P34|Interface Haptique, simulateur de formes et de textures]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Une rencontre avec les encadrants. Un cahier des charges assez précis. Pas de section &amp;quot;tâches à réaliser&amp;quot; mais une section &amp;quot;notre travail&amp;quot; qui pourrait en tenir lieu avec un effort de structuration.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P37 [[IMA4 2016/2017 P37|Gamelle connectée]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Présentez les objectifs généraux pour commencer. Un cahier des charges très précis mais il manque la liste des tâches à effectuer. Débutez la par l'état de l'art sur les produits déjà commercialisés.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P38 [[IMA4 2016/2017 P38|Veilleuse enfant connectée]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: yellow;&amp;quot;&amp;gt;Le sujet du projet à été recopié. Les deux sections personnelles sont assez mal rédigées. Un contre-sens sur le mode de connexion du prototype actuel : la veilleuse est configurée en point d'accès. Parlez plutôt de &amp;quot;Précisions sur le cahier des charges&amp;quot; plutôt que de &amp;quot;Problèmes rencontrés sur l'étude du projet&amp;quot;. Renommez aussi &amp;quot;Nouveau cahier des charges&amp;quot; en &amp;quot;Tâches à réaliser&amp;quot; et ajouter les autres tâches demandées dans le sujet.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: lightgreen;&amp;quot;&amp;gt;Cahier des charges et listes des tâches finalement validés par deux encadrants.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P39 [[IMA4 2016/2017 P39|Projecteur laser]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: firebrick;&amp;quot;&amp;gt;Uniquement une recopie du sujet.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un cahier des charges et une liste de tâches corrects après discussion avec deux encadrants.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P44 [[IMA4 2016/2017 P44|3615 Facebook]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un très bon cahier des charges. Le sujet semble être bien assimilé. Une liste des tâches correcte (il faudrait peut-être détailler la programmation du proxy).&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P46 [[IMA4 2016/2017 P46|Aide anti-gaspillage alimentaire ]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Un excellent cahier des charges. Liste des tâches très détaillée. Parfait.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P47 [[IMA4 2016/2017 P47|Modélisation d’un robot mobile]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Vous n'avez pas su vous adapter à la syntaxe mediawiki. Correction pour obtenir un CdC lisible. Une recopie intégrale du sujet. Un cahier des charges qui ressemble plus à une liste des tâches à effectuer.&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Vous utilisez bien la syntaxe mediawiki maintenant. Par contre il n'y a toujours pas de cahier des charges.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P48 [[IMA4 2016/2017 P48|Surveillance d'un robot mobile]]&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Un cahier des charges en 4 lignes, c'est trop court. En particulier rien sur le contexte du projet à savoir le matériel ou le simulateur sur lequel les tests seront effectués. Une liste des tâches, cette liste est-elle avalisé par l'encadrant ?&amp;lt;/font&amp;gt;&amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Toujours pas de cahier des charges.&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Fiche de présence ==&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Projet !! Elèves !! Séance 1 (25/01) !! Séance 2 (01/02) !! Séance 3 (08/02) !! Séance 4 (15/02) !! Séance 5 (01/03) !! Séance 6 (08/03) !! Séance 7 !! Séance 8 !! Séance 9 !! Séance 10&lt;br /&gt;
|-&lt;br /&gt;
| P1 [[IMA4 2016/2017 P1|Climatisation du pauvre]]&lt;br /&gt;
| Haroun Abdelali&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| D317 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D309 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D309 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P2 [[IMA4 2016/2017 P2|Réseau de capteurs sur smartphone]]&lt;br /&gt;
| Wenyu sun / Xinyue xu&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Presentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| C201 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| C201&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| C201&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;amp;C201&lt;br /&gt;
| E304&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P10 [[IMA4 2016/2017 P10|Application de suivi de prise de médicaments]]&lt;br /&gt;
| Martin Rohmer / Kévin Godesence&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P11 [[IMA4 2016/2017 P11|Amélioration de l'accueil d'enfants hospitalisés]]&lt;br /&gt;
| Robin Cavalieri / Edmur Lopes&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P14 [[IMA4 2016/2017 P14|Sex toy connecté]]&lt;br /&gt;
| Cedric Roussel / Thomas Stievenard&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P18 [[IMA4 2016/2017 P18|Education de la position de tête]]&lt;br /&gt;
| Mame Arame Diop / Amina Fahem&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P19 [[IMA4 2016/2017 P19|Orchestre électronique]]&lt;br /&gt;
| Antoine Arnaudet / Vivian Senaffe&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Arnaudet présent&amp;lt;/font&amp;gt;&amp;lt;br /&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Senaffe absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P20 [[IMA4 2016/2017 P20|Création d’un environnement virtuel de test]]&lt;br /&gt;
| Butaye Marianne / François Duport&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P21 [[IMA4 2016/2017 P21|Conception d’une MPS Polyvalente]]&lt;br /&gt;
| Samy Belhouachi / François Xavier Cockenpot&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 et E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 et E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P25 [[IMA4 2016/2017 P25|Robot mobile Polytech'Lille]]&lt;br /&gt;
| Cheikh Said Ahmed / Khadija El Messnaoui&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Said-Ahmed présent&amp;lt;/font&amp;gt;&amp;lt;br /&amp;gt;&amp;lt;font style=&amp;quot;color: red&amp;quot;&amp;gt;El Messnaoui absente&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P26 [[IMA4 2016/2017 P26|Train de véhicules]]&lt;br /&gt;
| Manlu Luo / Xinyi Wang&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présentes&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P27 [[IMA4 2016/2017 P27|Sonde atmosphérique]]&lt;br /&gt;
| Olivier Mahieux / Grillère Baptiste&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P28 [[IMA4 2016/2017 P28|Adaptation d'un émulateur de calculatrices TI]]&lt;br /&gt;
| Rodolphe Toin&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présent&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305/301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P29 [[IMA4 2016/2017 P29|Conteneurs pour site Web]]&lt;br /&gt;
| | E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: orange;&amp;quot;&amp;gt;Rattrapage DS&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Abs&amp;lt;/font&amp;gt;&lt;br /&gt;
| Malade&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| Malade&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| Malade&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P30 [[IMA4 2016/2017 P30|Voiture radiocommandée controlée par gant]]&lt;br /&gt;
| Thomas Gosse / Bacem Hagui&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Gosse présent&amp;lt;/font&amp;gt;&amp;lt;br /&amp;gt;&amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Hagui absent&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P31 [[IMA4 2016/2017 P31|Accueil personnalisé par drone]]&lt;br /&gt;
| Tristan Hart / Etienne Profit&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P32 [[IMA4 2016/2017 P32|Sécurité: brouilleur d'ondes]]&lt;br /&gt;
| Nicky Ung / Alexis Macherez&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304/301 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E305&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P33 [[IMA4 2016/2017 P33|Sécurité: ingénierie inverse de protocole réseau]]&lt;br /&gt;
| Oumaima Naanaa&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: red;&amp;quot;&amp;gt;Absente&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présente&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E301&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P34 [[IMA4 2016/2017 P34|Interface Haptique, simulateur de formes et de textures]]&lt;br /&gt;
| Alice Coffin / Diana Marrucho&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| IRCICA labo&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P37 [[IMA4 2016/2017 P37|Gamelle connectée]]&lt;br /&gt;
| Lutecia Damiens / Alexis Dorian&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| Fabricarium&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P38 [[IMA4 2016/2017 P38|Veilleuse enfant connectée]]&lt;br /&gt;
| Hugo Delatte&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P39 [[IMA4 2016/2017 P39|Projecteur laser]]&lt;br /&gt;
| Loïc Tombazzi / Marius Trimbur&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E303 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P44 [[IMA4 2016/2017 P44|3615 Facebook]]&lt;br /&gt;
| Marouan Mcharfi / Tristan lopez&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P46 [[IMA4 2016/2017 P46|Aide anti-gaspillage alimentaire ]]&lt;br /&gt;
| Alexandre Huet / François Lefevre&lt;br /&gt;
| E306&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E306 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| E304&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P47 [[IMA4 2016/2017 P47|Modélisation d’un robot mobile]]&lt;br /&gt;
| Djamil Mohamed / Hamza Kerroum&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présents&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A&amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|-&lt;br /&gt;
| P48 [[IMA4 2016/2017 P48|Surveillance d'un robot mobile]]&lt;br /&gt;
| Jean-Baptiste Saison&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| C305/D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présent&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;Présent&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A/C305 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A/D322 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A/D322 &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| D306A &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
| &amp;lt;font style=&amp;quot;color: green;&amp;quot;&amp;gt;&amp;lt;/font&amp;gt;&lt;br /&gt;
|}&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40085</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40085"/>
				<updated>2017-03-08T17:23:45Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Base de donnée */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''07/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Web service===&lt;br /&gt;
&lt;br /&gt;
====Page post.php====&lt;br /&gt;
&lt;br /&gt;
Page qui permet l'insertion d'un produit et d'une date via l'application mobile. Elle prend donc ces deux arguments et les insère dans les tables Unity, Product et Date.&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40084</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40084"/>
				<updated>2017-03-08T17:10:20Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Application Mobile */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''07/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
Page d'accueil permettant d'accéder aux pages d'ajout et de liste des produits disponibles. &amp;lt;br&amp;gt;&lt;br /&gt;
La page permet aussi d'effectuer la connexion entre la rfduino et l'application mobile. Elle montre les alertes (signaux) à l'utilisateur &lt;br /&gt;
et écrit leur signification.&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilise un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implémenté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps d'autant plus qu'il faut questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous avons donc prit la décision d'utiliser uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoi, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
Permet de lister les produits dans la base de donnée. Une série de boutons radio permettent de trier les produits par ordre alphabétique, par date de péremption, par nombre d’occurrence dans la réserve alimentaire, par nombre d'achat depuis la mise en place du système.&amp;lt;br&amp;gt;&lt;br /&gt;
Une colonne permet de sélectionner les aliments désirés (par checkBox) pour ensuite les supprimer via un button &amp;quot;suppr&amp;quot; ou les choisir pour trouver des recettes qui les utilisent.&amp;lt;br&amp;gt;&lt;br /&gt;
Un EditText permet d'effectuer une recherche sur la base de donnée.&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40078</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40078"/>
				<updated>2017-03-08T16:55:41Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 7 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
'''07/03'''&lt;br /&gt;
*Implémentation de la page ListeIngredient.xml et de l'activité listActivity.java.&lt;br /&gt;
*Documentation sur la procédure de communication bluetooth entre la Rfduino et l'application mobile.&lt;br /&gt;
*Obtention de librairie en lien avec cela.&lt;br /&gt;
*Prise en main de programmation rfduino.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40030</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40030"/>
				<updated>2017-03-06T17:26:23Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 7 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*Finition du protocole d'ajout d'aliment sur la base de donnée. (Code php et page ajout terminée).&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40029</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=40029"/>
				<updated>2017-03-06T17:00:37Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 6 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Semaine 7====&lt;br /&gt;
'''06/03'''&lt;br /&gt;
*Correction du fichier post.php&lt;br /&gt;
*PCB terminé.&lt;br /&gt;
*Installation d'arduino IDE, doc arduino collecté.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39914</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39914"/>
				<updated>2017-03-02T14:51:23Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 5 (interruption pédagogique) */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server, php5-mysql.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39889</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39889"/>
				<updated>2017-03-01T16:11:55Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Page d'ajout */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&amp;lt;br&amp;gt;&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39888</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39888"/>
				<updated>2017-03-01T16:11:39Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Page d'ajout */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39887</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39887"/>
				<updated>2017-03-01T16:11:08Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 6 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
*Après avoir vu avec un professeur, nous avons remarqué que le routage n'était pas adéquat et la disposition des composants n'était pas optimal. Du travail reste donc encore à effectuer.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39886</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39886"/>
				<updated>2017-03-01T16:08:31Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Base de donnée */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Application Mobile===&lt;br /&gt;
&lt;br /&gt;
====Home page====&lt;br /&gt;
&lt;br /&gt;
====Page d'ajout====&lt;br /&gt;
&lt;br /&gt;
Pour ajouter un produit et lire une date on utilisera un champ editText pour permettre à l'utilisateur d'écrire &amp;quot;Manuellement&amp;quot; dedans grâce au clavier du smartphone.&lt;br /&gt;
De plus on utilisera un bouton qui appellera la caméra pour détecter les caractères d'un produit ou d'une date. Au début nous voulions utiliser un détecteur de code barre, nous l'avons implanté mais nous avons remarqué que la mise au point sur une surface non plane prend du temps surtout qu'après il fallait questionner une base de donnée contenant tous les numéro de codes barres utilisés. Nous nous sommes donc dit que nous utiliserions uniquement la lecture de caractère et nous créerons une liste déroulante sous l'editText pour faciliter l'insertion d'un produit qui a déjà été ajouté.&lt;br /&gt;
&amp;lt;br&amp;gt;&lt;br /&gt;
Pour l'envoie, nous utilisons la librairie Volley développé par google.&lt;br /&gt;
&lt;br /&gt;
====Page Liste====&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39880</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39880"/>
				<updated>2017-03-01T15:54:30Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Base de donnée */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	<entry>
		<id>https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39879</id>
		<title>IMA4 2016/2017 P46 : Aide anti-gaspillage alimentaire</title>
		<link rel="alternate" type="text/html" href="https://projets-ima.plil.fr/mediawiki/index.php?title=IMA4_2016/2017_P46_:_Aide_anti-gaspillage_alimentaire&amp;diff=39879"/>
				<updated>2017-03-01T15:53:41Z</updated>
		
		<summary type="html">&lt;p&gt;Ahuet : /* Semaine 6 */&lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;==Cahier des charges==&lt;br /&gt;
&lt;br /&gt;
===Présentation générale du projet=== &lt;br /&gt;
&lt;br /&gt;
====Contexte====&lt;br /&gt;
&lt;br /&gt;
En France, nous jetons en moyenne 21% des aliments que nous achetons, ce qui représente une perte de 100 à 160 euros par an par habitant. Cela est en partie dû à la date limite de consommation associée à chaque produit. En effet, à partir du moment où cette date sera dépassée le consommateur jettera les produits concernés sans réfléchir, même si ceux-ci peuvent parfois être encore mangeables. Plutôt que d'essayer de les convaincre du contraire, il serait judicieux de proposer aux adeptes du gaspillage une aide permettant de gérer tous les aliments dont ils disposent chez eux afin d'éviter la surprise de tomber sur plusieurs produits périmés lorsqu'ils ouvrent la porte de leur frigo. &lt;br /&gt;
&lt;br /&gt;
====Objectif du projet====&lt;br /&gt;
&lt;br /&gt;
Ce projet permet d'aider les utilisateurs d'une part à mémoriser les denrées périssables qu'ils disposent dans leur réserve alimentaire et d'autre part d'avertir l'utilisateur qu'un événement important a lieu. Ceci peut être une notification qu'un aliment va bientôt dépasser sa date de péremption, que la porte du frigidaire est restée ouverte ou encore que le nombre d'aliments dans la réserve devient critique et qu'il faudra de nouveau l'alimenter. Enfin, le système aidera l'utilisateur à trouver des idées de repas pouvant permettre de consommer les aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Notre prototype permettra d'éviter le gaspillage alimentaire ainsi que d'aider l'utilisateur dans sa gestion du stockage d'aliments.&lt;br /&gt;
&lt;br /&gt;
====Description du projet====&lt;br /&gt;
&lt;br /&gt;
Notre système sera composé de 3 éléments. &lt;br /&gt;
&lt;br /&gt;
Premièrement, un ou des smartphones appartenant aux utilisateurs. Ces derniers permettront de scanner grâce à son appareil photo, le code barre du produit ainsi que sa date de péremption. Il servira aussi d'interface utilisateur pour notre système. En effet, c'est par cet outil que l'utilisateur pourra lister tous les aliments que l'utilisateur a dans sa base et tout ça en les triant par date de péremption, ou encore voir les recettes possibles pour consommer des aliments en fin de vie.&lt;br /&gt;
&lt;br /&gt;
Deuxièmement, un serveur, de type Raspberry, qui permettra de stocker la base de donnée contenant les aliments de la réserve. Ce serveur sera connecté par wifi.&lt;br /&gt;
 &lt;br /&gt;
Troisièmement, un contrôleur (Rfduino) qui comportera une LED pour indiquer la mise sous tension du contrôleur, une LED pour prévenir l'utilisateur qu'un aliment va bientôt passer sa date de péremption et une dernière LED pour prévenir l'utilisateur que son niveau de réserve est critique ainsi qu'un buzzer et un accéléromètre pour buzzer quand la porte du frigo est restée trop longtemps ouverte. Ce dernier sera fixé au frigo par l'intermédiaire d'un dispositif adapté qui sera un système aimanté qui se pose sur le frigo.&lt;br /&gt;
&lt;br /&gt;
Nous implémenterons donc une application mobile Android qui fera le lien entre les 2 autres systèmes.&lt;br /&gt;
&lt;br /&gt;
Pour la partie électronique que nous aurons à réaliser, nous utiliserons une Breadboard pour faire des premiers tests puis nous créerons une carte PCB pour notre montage final.&lt;br /&gt;
&lt;br /&gt;
====Choix techniques : matériel et logiciel====&lt;br /&gt;
&lt;br /&gt;
On utilisera une Raspberry Pi en guise de serveur pour pouvoir s'occuper du stockage de toutes les données dans notre projet puisque notre contrôleur sera incapable de les contenir, ce n'est d'ailleurs pas son but ici.&lt;br /&gt;
&lt;br /&gt;
Notre smartphone fera donc le lien entre notre base de données et notre système embarqué par l'intermédiaire de l'application mobile.&lt;br /&gt;
&lt;br /&gt;
Nous prendrons ici un RFduino puisque celui-ci nous permet d'ajouter des modules comme bon nous semble afin d'adapter le système aux besoins de notre application. Il est également parfaitement compatible avec les applications Android. De plus, nous avons un Bluetooth directement intégré au RFduino pour s'assurer que les liaisons RFduino-application mobile se fassent correctement. &lt;br /&gt;
On notera également que ce contrôleur consomme peu de courant et ne demande qu'une faible tension d'alimentation, critères importants pour ce genre de projet. C'est la raison principale de son utilisation pour être utilisé comme interface physique sur le frigo, en ajoutant également sa taille réduite comparée à la Raspberry Pi.&lt;br /&gt;
&lt;br /&gt;
====Liste de matériel====&lt;br /&gt;
&lt;br /&gt;
Nous avons donc besoin du matériel suivant :&lt;br /&gt;
&lt;br /&gt;
*Raspberry Pi.&lt;br /&gt;
*Clef wifi&lt;br /&gt;
*RFduino (RFD22102 DIP Board, RFD22121 USB Shield, RFD22126 Dual AAA battery shield).&lt;br /&gt;
*2 piles AAA.&lt;br /&gt;
*3 leds tranversantes.&lt;br /&gt;
*3 Résistances 330 Ohm.&lt;br /&gt;
*1 Résistance 10 kOhm.&lt;br /&gt;
*Un buzzer.&lt;br /&gt;
*Accéléromètre.&lt;br /&gt;
*Aimants&lt;br /&gt;
*Un boîtier permettant d'intégrer la RFduino + fixation sur le frigo (modélisation à voir).&lt;br /&gt;
&lt;br /&gt;
Pour le buzzer, l'accéléromètre et les résistances, nous choisirons des composants CMS pour nous permettre d'avoir une carte plus petite.&lt;br /&gt;
&lt;br /&gt;
===Calendrier prévisionnel===&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====Liste des tâches à effectuer====&lt;br /&gt;
&lt;br /&gt;
* Configurer la Raspberry :&lt;br /&gt;
** Installer et configurer le serveur.&lt;br /&gt;
** Créer le diagramme UML de notre future base de données.&lt;br /&gt;
** Créer la base sur le serveur.&lt;br /&gt;
** Configurer la connexion WiFi.&lt;br /&gt;
&lt;br /&gt;
* Monter et programmer la RFduino :&lt;br /&gt;
** Connecter les différents modules au RFduino (accéléromètre, LEDs, buzzer, Batterie, module Bluetooth).&lt;br /&gt;
** Récupérer les consignes du smartphone grâce au Bluetooth.&lt;br /&gt;
** Programmer le comportement du RFduino en fonction des consignes.&lt;br /&gt;
** Construire le boitier final.&lt;br /&gt;
&lt;br /&gt;
* Implémenter l'application mobile Android :&lt;br /&gt;
** Une première activité permettant de se connecter au RFduino et à la Raspberry.&lt;br /&gt;
** Scanner une date et un code barre.&lt;br /&gt;
** Ajout/suppression d'un aliment dans la base de donnée.&lt;br /&gt;
** Envoi d'une consigne au RFduino.&lt;br /&gt;
** Rendre l'interface utilisateur ergonomique (lister aliments, envoyer vers page de recettes avec l'utilisation des aliments bientôt périmés...).&lt;br /&gt;
&lt;br /&gt;
====Calendrier====&lt;br /&gt;
&lt;br /&gt;
Répartition du temps consacré au projet (120h *2) :&lt;br /&gt;
&lt;br /&gt;
*Partie Raspberry : 60h&lt;br /&gt;
*Partie RFduino : 60h&lt;br /&gt;
*Partie développement mobile : 120h&lt;br /&gt;
&lt;br /&gt;
==Avancement du Projet==&lt;br /&gt;
&lt;br /&gt;
===Résumé===&lt;br /&gt;
&lt;br /&gt;
====Semaine 1====&lt;br /&gt;
&lt;br /&gt;
'''23/01''' :  &lt;br /&gt;
* Installation du logiciel Android Studio pour être prêt à commencer l'application mobile.&lt;br /&gt;
* Création du Repository Git sur GitHub : https://github.com/FrancoisLefevre12/Optali.git&lt;br /&gt;
* Réalisation de différents schémas fonctionnels pour se donner une idée du travail à effectuer, aussi bien du software que du hardware.&lt;br /&gt;
* Quelques précisions supplémentaires apportées sur le cahier des charges.&lt;br /&gt;
* Ajout de liens de référence pour la liste de matériel à acheter.&lt;br /&gt;
&lt;br /&gt;
'''25/01''' :  &lt;br /&gt;
* Précision des composants requis (accéléromètre, buzzer, LEDs, résistances).&lt;br /&gt;
* Écriture du montage à la main.&lt;br /&gt;
* Étude du fonctionnement de l'accéléromètre, du buzzer.&lt;br /&gt;
* Écriture de la structure de l'application à la main.&lt;br /&gt;
&lt;br /&gt;
'''26/01''' :&lt;br /&gt;
*Réalisation graphique de la première page de l'application.&lt;br /&gt;
*Conception du schéma électrique pour tous les composants connectés au RFduino.&lt;br /&gt;
&lt;br /&gt;
====Semaine 2====&lt;br /&gt;
&lt;br /&gt;
'''30/01''' :&lt;br /&gt;
*Réalisation du diagramme UML de la base de données qui sera stockée sur la Raspberry Pi&lt;br /&gt;
*Installation de l'outil de développement mobile sur le second PC&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
'''01/02''' :&lt;br /&gt;
*Nous nous sommes d'abord rendus compte que la résistance entre un des GPIO et l'accéléromètre était inutile, nos premiers calculs étaient erronés. Nous ne la garderons donc pas sur notre schéma électrique final.&lt;br /&gt;
*Avancement sur la partie application mobile : réalisation de la page &amp;quot;Ajout&amp;quot; sur laquelle nous tomberons après avoir cliquer sur &amp;quot;ajout&amp;quot; sur la page principale de l'application. Nous avons étendu l'activité principale jusqu'à cette nouvelle activité &amp;quot;Ajout&amp;quot;.&lt;br /&gt;
*Nous avons récupéré notre Raspberry Pi pour commencer à installer notre base de données dessus. Nous avons actuellement quelques problèmes pour nous connecter sur la Raspberry. Nous travaillons sur ce point.&lt;br /&gt;
&lt;br /&gt;
'''02/02''' :&lt;br /&gt;
* Application mobile : Mise en place des LEDs sur la home page et de la zone de notification avec les messages associés.&lt;br /&gt;
&lt;br /&gt;
====Semaine 3====&lt;br /&gt;
&lt;br /&gt;
'''06/02''' :&lt;br /&gt;
*Nous arrivons à accéder à la Raspberry via le port série de celle-ci. Nous avons également configuré sa connexion Ethernet afin de pouvoir télécharger des paquets dessus et installer notre base de données. &lt;br /&gt;
*Nous rencontrions des problèmes sur le second PC de travail pour récupérer le projet Optali sur Android Studio via notre dépôt GIT. Nous avons pu rectifier ce souci.&lt;br /&gt;
&lt;br /&gt;
'''08/02''' :&lt;br /&gt;
*Tentative d'établissement d'un point d'accès WiFi sur notre Raspberry. Nous n'avons pas réussi pour le moment.&lt;br /&gt;
*Restructuration du Repository git.&lt;br /&gt;
*Essai d'importation de la librairie Zxing qui permettra de décoder les code-barres.&lt;br /&gt;
&lt;br /&gt;
====Semaine 4====&lt;br /&gt;
&lt;br /&gt;
'''13/02'''&lt;br /&gt;
*Configuration du wifi de la Raspberry. &lt;br /&gt;
*Étude d'une mise en place d'un service web via php.&lt;br /&gt;
&lt;br /&gt;
'''15/02'''&lt;br /&gt;
*Mise en place d'un lecteur de caractère sur l'application. On utilisera tesseract.&lt;br /&gt;
*Début de la création du PCB via Altium designer. Création d'une librairie pour l'accéléromètre qui est un composant CMS assez spécial. On pourra cependant utiliser des headers classiques pour le buzzer et les LEDs puisque ce sont des composants traversants.&lt;br /&gt;
*Création des premiers fichiers php de connection à la base de donnée et d'insertion d'aliments. Tous ces fichiers seront déposés de la même manière sur le dépôt git.&lt;br /&gt;
&lt;br /&gt;
'''16/02'''&lt;br /&gt;
*Adaptation avec prise en compte des cas du code php d'insertion de produits par requête sur la base de donnée.&lt;br /&gt;
*Ajout du code d'implantation de la base de donnée.&lt;br /&gt;
*Altium: Accéléromètre terminé, mise en place des résistances.&lt;br /&gt;
&lt;br /&gt;
====Semaine 5 (interruption pédagogique)====&lt;br /&gt;
&lt;br /&gt;
'''22/02 (3 heures)'''&lt;br /&gt;
*Installation de l'OS de la raspberry.&lt;br /&gt;
*Installation d'Openssh-server, apache2, php5, iptables, mysql-server.&lt;br /&gt;
*Redirection des ports du routeur vers la raspberry.&lt;br /&gt;
*Configuration de iptables de la raspberry.&lt;br /&gt;
&lt;br /&gt;
'''23/02 (2 heures)'''&lt;br /&gt;
*Implantation de la base de donnée sur la raspberry pi.&lt;br /&gt;
&lt;br /&gt;
====Semaine 6====&lt;br /&gt;
'''27/02'''&lt;br /&gt;
*Vérification de la syntaxe de l'insertion de valeurs dans la base de donnée.&lt;br /&gt;
*Création des premières requêtes sur la base de donnée.&lt;br /&gt;
*Finalisation du PCB de l'Optali Board.&lt;br /&gt;
&lt;br /&gt;
'''01/03'''&lt;br /&gt;
*Étude et ajout de la librairie volley pour communiquer avec le serveur.&lt;br /&gt;
*Implantation de la fonction d'envoi de données jusqu'au serveur.&lt;br /&gt;
&lt;br /&gt;
===Premières idées===&lt;br /&gt;
&lt;br /&gt;
Voici les premières idées de l'application mobile et du composant fixé sur le frigo.&lt;br /&gt;
[[Fichier:Optali_v1.jpg|400px|thumb|left|Optali version 1]]&lt;br /&gt;
[[Fichier:OptaliBox_v1.jpg|400px|thumb|center|OptaliBox version 1]]&lt;br /&gt;
[[Fichier:P46_schema.jpg|400px|thumb|center|Schéma électrique version 1]]&lt;br /&gt;
&lt;br /&gt;
En s'intéressant aux différentes datasheets ou données constructeur des composants que nous voulons utiliser, nous trouvons indispensable d'utiliser des résistances de 330 Ohms pour l'utilisation des LEDs, pour éviter de les griller.&lt;br /&gt;
&lt;br /&gt;
Edit : Retrait de la résistance R2.&lt;br /&gt;
&lt;br /&gt;
Concernant l'accéléromètre, nous avons choisi un modèle qui nous permet de brancher directement ce module sur une broche du RFDuino. On branchera directement les GPIOs de la RFduino sur les ports SDA et SCL de l'accéléromètre qui correspondent à l'interface I2C pour pouvoir communiquer. On utilisera aussi la broche INT1 pour pouvoir générer des interruptions directement depuis l'accéléromètre.&lt;br /&gt;
&lt;br /&gt;
On connectera le buzzer directement à une broche de la RFduino aussi. Concernant celui-ci il reste une incertitude puisqu'on ne trouve aucune information sur le courant à fournir pour l'alimentation de ce composant sur sa datasheet. Après différentes recherches sur Internet, il pourrait être nécessaire d'utiliser un montage amplificateur à transistor comme un émetteur commun pour booster le courant en sortie d'une broche GPIO. Quelques buzzers trouvés avec des données constructeur montrent que ce type de composant nécessite généralement un courant d'environ 30 mA. Nous verrons dans la pratique si cela sera vraiment nécessaire. Par sécurité, on ajoutera un transistor bipolaire dans la liste de matériel.&lt;br /&gt;
&lt;br /&gt;
[[Fichier:screen_LED.png|400px|thumb|left|Données constructeur pour LEDs]]&lt;br /&gt;
[[Fichier:screen_accel.png|400px|thumb|center|Datasheet de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
===Raspberry Pi===&lt;br /&gt;
&lt;br /&gt;
====Configuration école====&lt;br /&gt;
&lt;br /&gt;
*Pour configurer notre Raspberry Pi, nous utilisons son port série et &amp;quot;minicom&amp;quot;. Pour pouvoir télécharger des paquets, il fallait la connecter au réseau. Nous lui avons donc affecté une adresse IP fixe avec le fichier /etc/network/interfaces. Voici les modifications qui ont été apportées : &lt;br /&gt;
&lt;br /&gt;
   auto eth0&lt;br /&gt;
   iface eth0 inet static&lt;br /&gt;
   address 172.26.78.15&lt;br /&gt;
   netmask 255.255.240.0&lt;br /&gt;
   gateway 172.26.79.254&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Il a également fallu ajouter la commande &amp;quot;export http_proxy=http://proxy.polytech-lille.fr:3128&amp;quot; (il faudra effectuer cette commande à chaque démarrage de la Pi) pour pouvoir utiliser le proxy de l'école. &lt;br /&gt;
Nous avons de plus modifier le fichier /etc/resolv.conf avec la ligne suivante :&lt;br /&gt;
&lt;br /&gt;
   nameserver 193.48.57.34&lt;br /&gt;
&lt;br /&gt;
Malgré cela, nous avions des soucis pour nous connecter au réseau. Il y avait en fait un processus dhcp en tâche de fond qui nous empêchait de garder le contenu de resolv.conf. Il a donc fallu trouver ce processus pour le &amp;quot;kill&amp;quot; et pouvoir accéder correctement au réseau.&lt;br /&gt;
&lt;br /&gt;
Nous avons du coup pu installer postgresql pour pouvoir configurer une base de données sur notre Pi.&lt;br /&gt;
&lt;br /&gt;
====Configuration à domicile====&lt;br /&gt;
&lt;br /&gt;
Pour nous mettre dans une situation plus fidèle à notre projet, nous avons configuré la raspberry à domicile.&lt;br /&gt;
&lt;br /&gt;
Nous avons tout d'abords installé Raspbian, puis installé les paquets nécessaire au fonctionnement du serveur.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Openssh-server''': permettre d'accès à distance à la raspberry pour pouvoir y accéder depuis l'école.&amp;lt;br&amp;gt;&lt;br /&gt;
- '''Iptables''': pour sécuriser les ports non utilisé et libérer l'accès aux ports qui nous intéressent (ssh 22,http 80,https 443).&amp;lt;br&amp;gt;&lt;br /&gt;
- '''apache2, php5, mysql-server''' : pour mettre en place notre service web.&amp;lt;br&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ensuite nous avons rediriger les ports 80 et 22 du routeur pour pouvoir accéder à la raspberry de l'extérieur.&lt;br /&gt;
&lt;br /&gt;
Pour finir, nous avons créer un fichier de config iptables permettant de sécuriser un minimum la base de donnée et de permettre d'autoriser la communication des ports 22, 80 et 443 correspondants aux ports ssh, http et https. le fichier de configuration a été déposé dans le dépôt git. Il nous a fallut le rendre exécutable via un chmod. Puis pour l'exécuter à chaque démarrage du system, dans le fichier /etc/init.d/ taper : &lt;br /&gt;
&lt;br /&gt;
    sudo update-rc.d firewall defaults (si notrefichier s'appelle firewall et s'il est dans init.d)&lt;br /&gt;
&lt;br /&gt;
===Base de donnée===&lt;br /&gt;
&lt;br /&gt;
Nos données alimentaires disponibles par toute la famille doivent être stocké sur un serveur de base de donnée externe (tel une Raspberry pi). Nous nous proposons de créer le diagramme UML représentant cette future base de donnée.&lt;br /&gt;
[[Fichier:Optali_UML.jpg|700px|thumb|center|Diagramme UML base de donnée]]&lt;br /&gt;
&lt;br /&gt;
On créera donc 3 entités. Date, Product et Recipe. &lt;br /&gt;
&lt;br /&gt;
- Product rassemble les aliments qui sont ou ont été dans la réserve alimentaire. NbProdIn permet de connaître le nombre de produits identiques (possibilité de date différentes mais pas de doublons et on garde l'information de quantité. NbProdBought donne une information sur le nombre de produits identique ayant été acheté depuis la mise en service de la base de donnée. Ainsi nous pourrons par la suite proposer une liste de course à l'utilisateur en fonction de la fréquence d'achat des produits.&lt;br /&gt;
&lt;br /&gt;
- Recipe contient les recettes que pourra rentrer l'utilisateur sur l'application. L'utilisateur pourra ainsi se voir proposer des recettes en fonction de ce qu'il a dans son frigo et de ses recettes personnelles.&lt;br /&gt;
&lt;br /&gt;
'''''Edit : On ajoutera une valeur entière dans les tables Date et Unity pour gérer le cas où il existe plusieurs produits (différents ou identiques) avec une date de péremption équivalente. On les appellera NbDate la valeur dans la table Date et NbUnity dans la table Unity. On leur ajoutera de même une clef primaire IdUnity et IdListProduct'''''&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
====MySql====&lt;br /&gt;
&lt;br /&gt;
On utilisera MySql pour la gestion de nos bases de données. &lt;br /&gt;
La syntaxe pour l'implanter dans la base de donnée à été jointe au dépôt git.&lt;br /&gt;
&lt;br /&gt;
Pour lancer my SQL, on tapera:&lt;br /&gt;
&lt;br /&gt;
   mysql -h localhost -u root -p&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
===Altium Designer===&lt;br /&gt;
&lt;br /&gt;
Pour permettre au RFDuino de communiquer avec les différents composants, nous aurons besoin de quelques composants électroniques. Afin que cela soit plus esthétique pour la modélisation finale, nous allons créer une carte PCB pour rassembler tous ces composants dessus. On utilisera le logiciel Altium Designer pour cela.&lt;br /&gt;
&lt;br /&gt;
Avant de représenter notre circuit général, nous allons commencer par créer une librairie rassemblant tous les composants que nous utiliserons par la suite, en particulier nos composants CMS (accéléromètre et résistances). Pour ce qui est des LEDs et du buzzer, qui sont traversants, nous pourrons utiliser des headers classiques.&lt;br /&gt;
&lt;br /&gt;
Il a donc fallu créer le schematic ainsi que l'empreinte de nos composants CMS. Voici un exemple avec notre accéléromètre :&lt;br /&gt;
[[Fichier:Accelerosch.PNG|500px|thumb|left|Schematic de l'accéléromètre]]&lt;br /&gt;
[[Fichier:Acceleropcb.PNG|500px|thumb|center|Empreinte PCB de l'accéléromètre]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Tous les fichiers Altium sont disponibles sur notre dépôt GIT. Après cela, nous pouvons maintenant construire notre schematic du montage entier et ensuite le fichier PCB afin de pouvoir graver notre circuit.&lt;br /&gt;
&lt;br /&gt;
== Fichiers Rendus ==&lt;/div&gt;</summary>
		<author><name>Ahuet</name></author>	</entry>

	</feed>