Outils pour utilisateurs

Outils du site


sita_capteurs

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
Prochaine révisionLes deux révisions suivantes
sita_capteurs [2019/04/26 16:53] bigMaxsita_capteurs [2020/02/07 10:39] – ↷ Liens modifiés en raison d'un déplacement. serge
Ligne 1: Ligne 1:
 ====== Page ressource des SITA Capteurs ====== ====== Page ressource des SITA Capteurs ======
 +===== Introduction =====
 +==== Qu'est-ce qu'un capteur ? ====
 +C'est un "truc" qui va transformer une grandeur physique (lumière, chaleur, humidité, taux de tel ou tel composant chimique, pression acoustique, champ électromagnétique, ...) en une valeur électrique qui pourra ensuite être "numérisée".
 +
 +Il existe tout un florilège de capteurs, du très simple, par exemple une résistance électrique qui varie en fonction de la lumière, à des capteurs très élaborés comme un compteur de particules pour la pollution liée au diesel qui va utiliser un rayon laser et de l'électronique pour estimer ce nombre de particules fines dans l'air.
 +
 +{{ ::sku_452042_1.jpg?direct&700 |}}
 +
 +//Exemples de capteurs prêts à être greffé à une carte Arduino//
 +
 +==== Qu'est-ce que "numériser" ? ====
 +Donc si un capteur nous renvoie une valeur électrique et que l'on veut pouvoir traiter cette valeur avec du code informatique, il va falloir la transformer en 0 et en 1. Cette opération s'appelle la discrétisation du signal (Cf [[http://centenaire-shannon.cnrs.fr/chapter/la-theorie-de-information|Claude Shannon et la théorie de l'information]] et cette opération est réalisée par un ADC Analogic to Digital Converter. Un exemple de ADC est une carte son d'ordi qui va convertir une belle onde sonore continue en suite de 0 et de 1 (pour le CD : 44100 points d'information par seconde).
 +
 +{{ ::audacity-discretisation.png?direct&700 |}}
 +
 +//Ici on voit en gros plan un fichier audio dans Audacity, les points sur la courbe correspondent aux endroits du signal qui sont convertis en 0 1.//
 +
 +
 +==== Qu'est-ce qu'un microcontrôleur Arduino ? ====
 +Un microcontrôleur est une carte électronique qui va permettre de faire l'interface entre le monde physique et le monde des 0 et 1.
 +Un des plus utilisés aujourd'hui dans le monde créatif & Fablab est la carte [[liens_ressources_tutoriaux_arduino|Arduino]]
 +
 +{{  :arduino316.jpg?direct&700 |}}
 +
 +Sortie en 2005 comme un modeste outil pour les étudiants de Massimo Banzi, son créateur, à l’Interaction Design Institute Ivrea (IDII) en Italir, Arduino a initié une révolution DIY dans l’électronique à l’échelle mondiale.
 +
 +Grossièrement, cette carte se branche en USB à un ordinateur, on va pouvoir installer un IDE, un environnement de programmation de la carte pour pouvoir lui injecter un programme. On peut y brancher capteurs et actionneurs (pour piloter un moteur, un relais électrique, ...) et lui conférer un comportement autonome en la débranchant de l'ordi ou au contraire récupérer ses valeurs et lui en envoyer via une diversité de programmes informatiques depuis l'ordi (Processing, Pure Data, ...).
 +
 +On peut aussi greffer à la carte arduino des "shields", des composants supplémentaires comme des briques de lego afin de lui conférer des fonctions supplémentaires (comme un Shield GSM qui va permettre à l'arduino d'envoyer ses valeurs via le réseau téléphonique GSM).
 +
 +{{  ::stacked-shields_large.jpg?direct&600 |}}
 +
 +//Une jolie pile de "shields"//
 +
 +=== Histoire de l'Arduino (à consulter pendant les soirées d'hiver)===
 +{{ vimeo>18539129 }}
 +  * http://www.framablog.org/index.php/post/2011/12/10/arduino-histoire
  
 ===== SITA Capteurs 1 ===== ===== SITA Capteurs 1 =====
  
 ==== Objectifs ==== ==== Objectifs ====
-Acquérir l'intuition nécéssaire pour comprendre et manipuler des capteurs. Nous abordons les themes suivants :+Acquérir l'intuition nécessaire pour comprendre et manipuler des capteurs. Nous abordons les thèmes suivants :
   * Capteurs   * Capteurs
   * Signaux   * Signaux
   * Arduino   * Arduino
   * Programmation / Code   * Programmation / Code
 +
 +==== Ateliers / Exercices ====
 +
 +=== Rappels ===
 +
 +<WRAP center round important 80%>
 +{{ media_06:led.png?nolink|}}
 +
 +Une LED a un sens : pour qu'elle puisse laisser passer le courant électrique et éclairer, il faut relier sa cathode "vers la masse" du circuit. On peut distinguer la cathode de la LED car elle a généralement à une pate plus courte, et surtout, le boitier est toujours aplatie du coté de la cathode.
 +</WRAP>
 +
 +<WRAP center round info 80%>
 +Pour utiliser les ordinateurs portables de la labomedia, veuillez vous référer à [[ laptop_labomedia | la page dédiée à l'utilisation des ordinateurs portables de la labomedia ]].
 +</WRAP>
 +
 +=== 01_Blink ===
 +<WRAP center round info 80%>
 +[[ https://raw.githubusercontent.com/mxbossard/sita/master/sita_capteurs_1/croquis_arduino/01_Blink/01_Blink.ino | Le code arduino de l'exercice est disponible ici ]]
 +</WRAP>
 +
 +Ce croquis fait clignoter la LED embarqué sur l'Arduino. Il utilise un port de sortie spécial de l'Arduino qui dispose d'une LED interne cablé sur ce port (le port digital 13 aussi appelé D13).
 +\\ \\
 +__Objectif de l'exercice :__
 +  * Premier code Arduino et maniement des fonctions setup(), loop()
 +  * Première déclaration de variable (une constante)
 +  * Première déclaration d'entré/sortie d'un port
 +  * Première utilisation d'un port de sortie logique (ou numérique ou digital) avec la fonction digitalWrite()
 +  * Première utilisation d'une temporisation avec la fonction delay()
 +
 +\\
 +__Si la LED clignote déjà alors vous pouvez :__
 +  - Modifier le code avec pour objectif que la LED ne clignote plus
 +  - Téléverser ce code
 +  - Vérifier que la LED ne clignote plus
 +  - Modifier le code pour que la LED clignote de nouveau
 +  - Téléverser ce code
 +  - Vérifier que la LED clignote
 +\\
 +__Instructions découverte pour aller plus loin :__
 +  - Essayer de modifier le code puis de le téléverser pour faire varier la fréquence (vitesse) de clignotement de la LED
 +  - Imaginez des schéma de clignotement différents (exemple: alterner des clignotements rapides et lents pour signaler du code morse), puis faites varier le code et constatez si le montage réagit comme vous l'attendiez.
 +
 +=== 02_Fade ===
 +Ce croquis fait varier la luminosité d'une LED. Il utilise un port de sortie analogique de type PWM. Il faut utiliser la "breadboard" pour câbler une LED sur un port de sortie compatible PWM.
 +
 +<WRAP center round info 80%>
 +[[ https://raw.githubusercontent.com/mxbossard/sita/master/sita_capteurs_1/croquis_arduino/02_Fade/02_Fade.ino | Le code arduino de l'exercice est disponible ici ]]
 +</WRAP>
 +
 +\\ \\
 +__Objectif de l'exercice :__
 +  * Premier montage des composants sur une "breadboard"
 +  * Première utilisation de la sortie analogique "PWM" avec la fonction analogWrite()
 +
 +{{ media_06:02_fade_layout.png?direct&800 |}}
 +
 +\\
 +__Instructions découverte pour aller plus loin :__
 +  - Essayez de modifier le code puis de le téleverser pour changer l'amplitude (la plage) des valeurs de sortie possible pour diminuer l'amplitude de changement de luminosité
 +
 +=== 03_AnalogInOutSerial ===
 +Ce croquis lit la valeur du signal choisi par le potentiomètre et affiche cette valeur dans la console série de l'Arduino.
 +
 +<WRAP center round info 80%>
 +[[ https://raw.githubusercontent.com/mxbossard/sita/master/sita_capteurs_1/croquis_arduino/03_AnalogInOutSerial/03_AnalogInOutSerial.ino | Le code arduino de l'exercice est disponible ici ]]
 +</WRAP>
 +
 +\\ \\
 +__Objectif de l'exercice :__
 +  * Première utilisation de la lecture d'un signal analogique avec analogRead()
 +  * Première utilisation du port série de l'Arduino
 +  * Première utilisation de la fonction map() pour adapter une plage d'entrée à une plage de sortie différente
 +
 +{{ media_02:03_analoginoutserital_layout.png?direct&400 |}}
 +
 +\\
 +__Instructions découverte pour aller plus loin :__
 +  - Modifiez le montage en ajoutant une LDR entre le port A0 et l'alimentation +5V (entre le fil rouge et le fil bleu sur le schéma). Constater que l'on peut faire le lien entre la luminosité capté par la LDR et la valeur indiqué dans la console. Notez les valeurs extrêmes que vous constatez dans la console lorsque la luminosité est maximale et minimale 
 +  - Faites varier le réglage du potentiomètre et constater que cela change les valeurs extrêmes que vous avez noté précédemment.
 +  - Modifiez le code pour allumer la LED uniquement lorsque la luminosité est faible.
 +
 +=== 04_DHTTester ===
 +Ce croquis permet de tester le capteur de température DHT11 ou DHT22. Ce capteur est plus sophistiqué : il retourne 2 informations : la température et l'humidité, et émet ces valeurs avec des signaux numériques.
 +
 +<WRAP center round info 80%>
 +[[ https://github.com/mxbossard/sita/blob/master/sita_capteurs_1/croquis_arduino/04_DHTtester/04_DHTtester.ino | Le code arduino de l'exercice est disponible ici. ]] Vous trouverez les bibliothèques nécéssaires au code dans l'archive téléchargeable [[ https://github.com/mxbossard/sita/archive/master.zip | ici]].
 +</WRAP>
 +
 +\\ \\
 +__Objectif de l'exercice :__
 +  * Manipuler un capteur différent avec un signal numérique
 +  * Manipuler une première librairie Arduino
 +
 +{{ media_06:04_dhttester.png?nolink&800 |}}
 +
 +\\
 +__Instructions découverte pour aller plus loin :__
 +  - Essayez d'augmenter la température de l'air avec un sèche cheveux ou bien un décapeur thermique sans endommager le capteur !
  
 ==== Théorie ==== ==== Théorie ====
-Une partie théorique pour exposer les concepts +Une partie théorique pour exposer les concepts (mais pas trop) 
-===== Capteurs / Sensor =====+=== Capteurs / Sensor ===
   * Grandeurs physiques   * Grandeurs physiques
   * Mesure   * Mesure
Ligne 20: Ligne 155:
   * Caracteristiques: Etendue de mesure, Résolution, Sensibilité, Précision, Rapidité (temps de réponse)   * Caracteristiques: Etendue de mesure, Résolution, Sensibilité, Précision, Rapidité (temps de réponse)
  
-===== Signaux =====+=== Signaux ===
   * Exemples : signal lumineux: 1 voyant rouge, signal sonore: 1 bip, 1 signal électrique, 1 image   * Exemples : signal lumineux: 1 voyant rouge, signal sonore: 1 bip, 1 signal électrique, 1 image
   * Définition : Un signal est une grandeur variable dans le temps et/ou l'espace.    * Définition : Un signal est une grandeur variable dans le temps et/ou l'espace. 
Ligne 28: Ligne 163:
   * Emétteur / Récépteur <=> Sortie / Entrée   * Emétteur / Récépteur <=> Sortie / Entrée
      
-===== Arduino =====+=== Arduino ===
   * Des Entrée / Sortie (Input / Output ou IO) : 2 types d'entrées : Numerique et Analogique. 2 types de sortie : Numerique et Analogique   * Des Entrée / Sortie (Input / Output ou IO) : 2 types d'entrées : Numerique et Analogique. 2 types de sortie : Numerique et Analogique
   * Attention toujours Sortie <=> Entrée   * Attention toujours Sortie <=> Entrée
Ligne 34: Ligne 169:
   * CAN : un composant qui permet de convertir un signal analogique en signal numérique. résolution 10 bits => 1024 valeurs possibles (de 0 à 1023); digitalRead();   * CAN : un composant qui permet de convertir un signal analogique en signal numérique. résolution 10 bits => 1024 valeurs possibles (de 0 à 1023); digitalRead();
   * PWM : Sortie Analogique limité. résolution 8 bits => 256 valeurs possibles (de 0 à 255) ; analogWrite();   * PWM : Sortie Analogique limité. résolution 8 bits => 256 valeurs possibles (de 0 à 255) ; analogWrite();
-  * UI: UI / écran / Led+  * UI: Console / écran / Led 
 +  * setup() & loop()
  
-===== Programmation / Code =====+=== Programmation / Code ===
   * Instruction : Un ordre   * Instruction : Un ordre
-  * Mots clés (keywords) : if, then, else ; for ; const ; int ; void+  * Mots clés (keywords) : if, then, else ; for ; const ; int ; void ; ...
   * Variable : mémoire nommé ; affectation avec le symbole =   * Variable : mémoire nommé ; affectation avec le symbole =
-  * Fonction+  * Fonction : pinMode(), digitalWrite(), delay(), analogWrite(), ...
   * Condition : test avec le symbole ==   * Condition : test avec le symbole ==
   * Boucle   * Boucle
 +  * Commentaires
 +
 +==== Ressources complémentaires ====
 +  * Un manuel en français pour Arduino (un peu daté mais toujours savoureux) https://fr.flossmanuals.net/arduino/historique-du-projet-arduino/
 +  * Le Livret Arduino de Jean-Noël Montagné de Artsens réalisé au Craslab http://www.craslab.org/interaction/files/LivretArduinoCRAS.pdf.
 +
 +==== Retour d'XP ====
 +  * Parler d'algorithme et d'algorigramme. Présenter les codes avec des algorigrammes en français.
 +  * Détailler l'algo qui permet d'allumer la LED avec un seuil sur la LDR.
 +  * Retirer tous les commentaires anglais y compris l'entête pour reduire la verbosité et ne pas effrayer avec tout ce texte.
 +  * Terminer l'exo DHT
 +  * Passer l'Arduino à une version récente pour profiter du lib manager ou bien utiliser platform.io
 +  * Refaire les images des breadboard au plus juste.
 +  * Produire un support papier à distribuer. Quoi mettre dedans ? Un support pour l'atelier et un support pour emporter et méditer à la maison ?
 +
 +==== Support Papier ====
 +https://semestriel.framapad.org/p/d8KENCbxsva?lang=fr
 +
 +* // : Le texte qui suit ces 2 caractères sont des commentaires qui ne sont pas exécutés. Il permettent d'expliquer et de clarifier le code.
 +* void setup() : Fonction d'initialisation de l'Arduino exécuté une seule fois au démarrage.
 +* void loop() : Fonction principale appelée en boucle après la fonction setup().
 +* INPUT : La "direction ENTREE"
 +* OUTPUT : La "direction SORTIE"
 +* LOW: niveau logique BAS (0)
 +* HIGH : niveau logique HAUT (1)
 +* pinMode(port, direction) : Assigne une direction (ENTREE ou SORTIE) sur un port de l'Arduino.
 +* digitalWrite(port, niveau_logique) : Affecte un niveau logique (HAUT ou BAS) sur un port numérique configuré en SORTIE.
 +* analogWrite(port, valeur) : Affecte une valeur "analogique" sur un port analogique configuré en SORTIE.
 +* analogRead(port)
 +* delay(temps_en_ms) : 
 +* int variable1 : Déclare une variable nommée "variable1" de type entière.
 +* float variable2 : Déclare une variable nommée "variable1" de type floatante (rationnelle).
 +* const : Déclare une constante dont le programme ne pourra jamais changer la valeur.
 +* if (condition) : Test une condition, et exécute le bloc de code en { } si la condition est vraie.
 +* condition1 || condition2 : Opère un OU logique entre la condition1 et la condition2.
 +* Serial, Serial.begin, Serial.print, Serial.println : Bibliothèque pour manipuler le port Serie de l'Arduino et y afficher des messages.
 +* map(valeur, entrée_min, entrée_max, sortie_min, sortie_max) : Adapte la valeur située dans une plage d'entrée encadré par entrée_min et entrée_max, vers une plage de sortie encadrée par sortie_min et sortie_max.
  
  
-==== Ateliers / TP ==== 
-  * Blink croquis (Sketchbook) 
-  * PWM: Fade croquis 
-  * Potar 1: croquis AnalogInOutSerial 
-  * Potar 2: croquis AnalogInput (sortie sur une LED PWM) 
-  * LDR 1: capteur -> sortie logique LED avec seuil 
-  * LDR 2: capteur -> sortie console 
-  * LDR 3: potar + LDR -> sortie console 
-  * DHT11 ??: 
  
sita_capteurs.txt · Dernière modification : 2020/12/01 17:43 de serge