Différences entre versions de « Projets:Wi-canne »

De wikilab
(ajout code circuit)
Ligne 7 : Ligne 7 :
 
Des capteurs viennent renseigner sur les aspérités du sol et l'environnement proche pour faciliter les déplacements. Un signal sonore ou vibrant indique l'environnement perçu par les capteurs.  
 
Des capteurs viennent renseigner sur les aspérités du sol et l'environnement proche pour faciliter les déplacements. Un signal sonore ou vibrant indique l'environnement perçu par les capteurs.  
  
 +
== Analyse de l'existant ==
 +
 +
Systèmes existants :
 +
* Tom Pouce
 +
* Mini tact
 +
 
== Cahier des charges ==
 
== Cahier des charges ==
  
Ligne 21 : Ligne 27 :
 
* objet autonome, fonctionne sans canne
 
* objet autonome, fonctionne sans canne
 
* indication de l'état de charge de la batterie par un appui bouton
 
* indication de l'état de charge de la batterie par un appui bouton
 +
 +
== Matériel et outils nécessaires ==
 +
 +
* imprimante 3D
 +
* circuits électroniques et capteurs
 +
 +
== Circuits de test ==
 +
 +
=== distance et mouvement ===
 +
 +
Un circuit test est réalisé, il intègre un accéléromètre analogique, un capteur de distance TFmini et un afficheur LCD pour le retour d'informations.
 +
 +
[[File:arduino_mega_tfmini_adxl335_2lignes.png]]
 +
 +
<nowiki>
 +
// Télémètre Lidar TFmini avec CARTE ARDUINO MEGA 2560
 +
// YLC 16/10/2019
 +
/*---------------------------------------------------
 +
Pour montage sur une carte avec 1 seul port série (UNO, NANO) definir un port série logiciel pour le lidar :
 +
(NB : ralentit les mesures car cela prend des temps de cycle du contrôleur)
 +
  #include<SoftwareSerial.h>  // définit un port série logiciel
 +
  SoftwareSerial Serial1(2,3); // nomme le port logiciel "Serial1" (pin2 = RX, pin3 = TX)
 +
Sur carte Arduino MEGA utiliser directement les ports série Serial et Serial1
 +
brochages MEGA :    18 TX du lidar  19 RX du lidar    20 SDA du LCD  21 SCL du LCD
 +
Format des données reçues du lidar (9 octets) :  (le code d'en-tête est répété dans les 2 premiers octets)
 +
les valeurs distance et force sont fournies sur 2 octets en little endian (poids faible en premier)
 +
  octet0=0x59    octet1=0x59    octet2=Dist_faible    octet3=Dist_fort    octet4=force_faible
 +
  octet5=force_fort    octet6=mode    octet7=0x00      octet8=somme de contrôle
 +
  -----------------------------------------------------*/   
 +
 +
#include <Wire.h>
 +
#include <math.h>
 +
#include <LiquidCrystal_I2C.h>
 +
 +
 +
int      i      = 0;      // index sur la table de stockage
 +
const int entete = 0x59;  // Identifiant du flux de données
 +
const int x_out  = A1;    /* connect x_out of module to A1 of UNO board */
 +
const int y_out  = A2;    /* connect y_out of module to A2 of UNO board */
 +
const int z_out  = A3;    /* connect z_out of module to A3 of UNO board */
 +
 +
int data[9];    // Table de stockage des données fournies par le lidar
 +
int dist;      // valeur de la distance mesurée
 +
int force;      // force du signal reçu
 +
int ctrol;      // somme de controle des données reçues (checksum)
 +
int corr = 5;  // valeur de correction de la mesure lue en cm
 +
int x_adc_value;
 +
int y_adc_value;
 +
int z_adc_value;
 +
 +
double x_g_value;
 +
double y_g_value;
 +
double z_g_value;
 +
double roll, pitch, yaw;
 +
 +
LiquidCrystal_I2C lcd(0x3f,20,4);  // déclaration afficheur LCD série I2C
 +
 +
#define TRACES 1    // 1 pour activer trace sur port série vers ordinateur, 0 pour la désactiver
 +
 +
void setup() {
 +
 
 +
  #if TRACES                // si mise au point activée
 +
    Serial.begin(115200);    // vitesse du port de communication avec l'ordinateur
 +
  #endif 
 +
  Serial1.begin(115200);    // vitesse du port de communication avec le LiDAR
 +
  lcd.init();                // initialize the lcd
 +
  // Print a message to the LCD.
 +
  lcd.backlight();
 +
  lcd.setCursor(0,0);
 +
  lcd.print("Hello, world!");
 +
 +
}
 +
 +
void loop() {
 +
 +
// Accelerometre
 +
x_adc_value = analogRead(x_out); /* Digital value of voltage on x_out pin */
 +
y_adc_value = analogRead(y_out); /* Digital value of voltage on y_out pin */
 +
z_adc_value = analogRead(z_out); /* Digital value of voltage on z_out pin */
 +
x_g_value  = ( ( ( (double)(x_adc_value * 5)/1024) - 1.65 ) / 0.330 ); /* Acceleration in x-direction in g units */
 +
y_g_value  = ( ( ( (double)(y_adc_value * 5)/1024) - 1.65 ) / 0.330 ); /* Acceleration in y-direction in g units */
 +
z_g_value  = ( ( ( (double)(z_adc_value * 5)/1024) - 1.80 ) / 0.330 ); /* Acceleration in z-direction in g units */
 +
roll        = ( ( (atan2(y_g_value,z_g_value) * 180) / 3.14 ) + 180 );
 +
pitch      = ( ( (atan2(z_g_value,x_g_value) * 180) / 3.14 ) + 180 );
 +
 +
// Affichage LCD valeurc accelerometre
 +
lcd.setCursor(0,3);
 +
lcd.print(roll);
 +
lcd.print(" ");
 +
lcd.print(pitch);
 +
 +
if (Serial1.available()) {
 +
  lcd.setCursor(0,0);
 +
  lcd.print("OK    "); // test si données fournies par le lidar
 +
 +
  // Lecture entete  1
 +
  data[0] = Serial1.read();
 +
  if (data[0] == entete) {
 +
    data[1] = Serial1.read();
 +
    if (data[1] == entete) { 
 +
      i=1;
 +
      for(i = 2; i < 9; i++) {      // on lit les 7 octets suivants
 +
        data[i] = Serial1.read();  // on stocke les données lues dans un tableau
 +
      }
 +
      ctrol = data[0]+data[1]+data[2]+data[3]+data[4]+data[5]+data[6]+data[7];
 +
      if(data[8] == (ctrol&0xff)) {
 +
        dist  = data[2]+data[3]*256;
 +
        force = data[4]+data[5]*256;
 +
        if (dist < 1e-5)  {
 +
          dist = 0.0;
 +
        }
 +
        lcd.setCursor(7, 0);    // affichage mesures sur l'écran LCD                             
 +
        lcd.print(dist);             
 +
        lcd.print(" cm    ");
 +
        lcd.setCursor(7, 1);
 +
        lcd.print(force);
 +
        lcd.print("      ");
 +
      }
 +
    }
 +
  }
 +
  else {
 +
  }
 +
}
 +
else  {
 +
  lcd.setCursor(0,0);
 +
  lcd.print("ERREUR"); // test si données fournies par le lidar
 +
}
 +
}
 +
</nowiki>
  
 
== Capteurs testés ==
 
== Capteurs testés ==

Version du 17 octobre 2019 à 09:06

Wi-canne

Description du projet

Projet initié pendant le fabrikarium arianegroup aux Mureaux du 16 au 18 octobre 2019. Ce projet a pour objectif de créer une "canne blanche" augmentée à destination des déficient·e·s visuels. Des capteurs viennent renseigner sur les aspérités du sol et l'environnement proche pour faciliter les déplacements. Un signal sonore ou vibrant indique l'environnement perçu par les capteurs.

Analyse de l'existant

Systèmes existants :

  • Tom Pouce
  • Mini tact

Cahier des charges

  • anticiper le relief au sol dans un intervalle de + ou - 10 cm
  • retour d'informations par vibreur ou message sonore
  • coût de fabrication inférieur à 300 euros
  • autonomie de 6 heures
  • objet équilibré
  • poids maximum : 300g
  • recharge par port USB intégrée dans le manche
  • ambidextre : symétrique pour utilisation de la main gauche ou de la main droite
  • boîtier résistant à la pluie et au soleil
  • indications en relief sur le boîtier
  • objet autonome, fonctionne sans canne
  • indication de l'état de charge de la batterie par un appui bouton

Matériel et outils nécessaires

  • imprimante 3D
  • circuits électroniques et capteurs

Circuits de test

distance et mouvement

Un circuit test est réalisé, il intègre un accéléromètre analogique, un capteur de distance TFmini et un afficheur LCD pour le retour d'informations.

Arduino mega tfmini adxl335 2lignes.png

// Télémètre Lidar TFmini avec CARTE ARDUINO MEGA 2560
// YLC 16/10/2019
/*---------------------------------------------------
 Pour montage sur une carte avec 1 seul port série (UNO, NANO) definir un port série logiciel pour le lidar :
 (NB : ralentit les mesures car cela prend des temps de cycle du contrôleur)
   #include<SoftwareSerial.h>   // définit un port série logiciel
   SoftwareSerial Serial1(2,3); // nomme le port logiciel "Serial1" (pin2 = RX, pin3 = TX)
 Sur carte Arduino MEGA utiliser directement les ports série Serial et Serial1
 brochages MEGA :    18 TX du lidar   19 RX du lidar    20 SDA du LCD   21 SCL du LCD
 Format des données reçues du lidar (9 octets) :  (le code d'en-tête est répété dans les 2 premiers octets)
 les valeurs distance et force sont fournies sur 2 octets en little endian (poids faible en premier)
  octet0=0x59    octet1=0x59    octet2=Dist_faible    octet3=Dist_fort     octet4=force_faible
  octet5=force_fort    octet6=mode     octet7=0x00      octet8=somme de contrôle 
  -----------------------------------------------------*/    

#include <Wire.h>
#include <math.h>
#include <LiquidCrystal_I2C.h>


int       i      = 0;      // index sur la table de stockage
const int entete = 0x59;   // Identifiant du flux de données
const int x_out  = A1;     /* connect x_out of module to A1 of UNO board */
const int y_out  = A2;     /* connect y_out of module to A2 of UNO board */
const int z_out  = A3;     /* connect z_out of module to A3 of UNO board */

int data[9];    // Table de stockage des données fournies par le lidar
int dist;       // valeur de la distance mesurée
int force;      // force du signal reçu
int ctrol;      // somme de controle des données reçues (checksum)
int corr = 5;   // valeur de correction de la mesure lue en cm
int x_adc_value;
int y_adc_value;
int z_adc_value; 

double x_g_value;
double y_g_value;
double z_g_value;
double roll, pitch, yaw;

LiquidCrystal_I2C lcd(0x3f,20,4);   // déclaration afficheur LCD série I2C

#define TRACES 1     // 1 pour activer trace sur port série vers ordinateur, 0 pour la désactiver

void setup() {
  
  #if TRACES                 // si mise au point activée
    Serial.begin(115200);    // vitesse du port de communication avec l'ordinateur 
  #endif  
  Serial1.begin(115200);     // vitesse du port de communication avec le LiDAR
  lcd.init();                // initialize the lcd 
  // Print a message to the LCD.
  lcd.backlight();
  lcd.setCursor(0,0);
  lcd.print("Hello, world!");

}

void loop() {

 // Accelerometre
 x_adc_value = analogRead(x_out); /* Digital value of voltage on x_out pin */ 
 y_adc_value = analogRead(y_out); /* Digital value of voltage on y_out pin */ 
 z_adc_value = analogRead(z_out); /* Digital value of voltage on z_out pin */
 x_g_value   = ( ( ( (double)(x_adc_value * 5)/1024) - 1.65 ) / 0.330 ); /* Acceleration in x-direction in g units */ 
 y_g_value   = ( ( ( (double)(y_adc_value * 5)/1024) - 1.65 ) / 0.330 ); /* Acceleration in y-direction in g units */ 
 z_g_value   = ( ( ( (double)(z_adc_value * 5)/1024) - 1.80 ) / 0.330 ); /* Acceleration in z-direction in g units */ 
 roll        = ( ( (atan2(y_g_value,z_g_value) * 180) / 3.14 ) + 180 ); 
 pitch       = ( ( (atan2(z_g_value,x_g_value) * 180) / 3.14 ) + 180 );

 // Affichage LCD valeurc accelerometre
 lcd.setCursor(0,3);
 lcd.print(roll);
 lcd.print(" ");
 lcd.print(pitch);
 
 if (Serial1.available()) {
  lcd.setCursor(0,0);
  lcd.print("OK     "); // test si données fournies par le lidar

  // Lecture entete  1
  data[0] = Serial1.read();
  if (data[0] == entete) {
    data[1] = Serial1.read();
    if (data[1] == entete) {   
      i=1;
      for(i = 2; i < 9; i++) {      // on lit les 7 octets suivants
        data[i] = Serial1.read();   // on stocke les données lues dans un tableau
      }
      ctrol = data[0]+data[1]+data[2]+data[3]+data[4]+data[5]+data[6]+data[7];
      if(data[8] == (ctrol&0xff)) { 
        dist  = data[2]+data[3]*256; 
        force = data[4]+data[5]*256;
        if (dist < 1e-5)   {
          dist = 0.0;
        }
        lcd.setCursor(7, 0);     // affichage mesures sur l'écran LCD                              
        lcd.print(dist);               
        lcd.print(" cm     ");
        lcd.setCursor(7, 1);
        lcd.print(force);
        lcd.print("       ");
      }
    }
  }
  else {
  }
 }
 else  {
  lcd.setCursor(0,0);
  lcd.print("ERREUR"); // test si données fournies par le lidar
 }
}

Capteurs testés

Capteur Benewake TFmini

caption capteur TFmini

Il s'agit d'un capteur ToF vendu sous l'appellation LiDAR, toutefois il n'utilise pas de laser mais une diode LED infrarouge et une optique adéquate. Ce capteur permet de mesurer une distance comprise entre 30 centimètres et 12 mètres, à une fréquence de 100Hz, soit 100 mesures par seconde. Il fonctionne à une tension de 5v et communique par une interface série (UART).

zone de détection

  • 1 : zone aveugle du capteur, entre 0 et 30cm, la distance mesurée n'est pas fiable
  • 2 : zone de détection en conditions extrêmes (lumière exterieure très forte > 100 kLux et réflexion sur une surface très faiblement réfléchissante)
  • 3 : zone de détection en lumière extérieure (autour de 70 kLux)
  • 4 : zone de détection en intérieur ou par faible lumière extérieure
  • 5 : distance latérale dans laquelle la mesure peut être considérée comme fiable

documentation

ressources externes

Capteur Benewake TFmini Plus

caption capteur TFmini plus

Capteur conçu sur le même principe que le TFmini. Il s'en différencie sur plusieurs points :

  • boîtier IP65, résistant à l'eau et à la poussière
  • suffisamment résistant aux vibrations pour être installé sur un drone
  • trajet de lumière optimisé et algorithme différent pour minimiser l'influence du milieu lumineux, cf. zone de détection ci-dessous
  • fréquence des mesures ajustable jusqu'à 1000 Hz

zone de détection

  • 1 : zone aveugle du capteur entre 0 et 10 cm
  • 2 : zone de détection d'un objet très faiblement réfléchissant (reflectivité de 10%)
  • 3 : zone de détection de d'un objet réfléchissant (réflectivité de 90%)

documentation

Capteur de distance à ultrason HC-SR05 (Velleman VMA306)

capteur de distance à ultrason HC-SR05

Ce capteur permet de mesurer la distance avec un obstacle en mesurant le temps de rebond d'une impulsion ultrasonique. Il est capable de détecter un obstacle à une distance maximum de 4,5m.

zone de détection

Ce schéma correspond au module HC-SR04 qui utilise le même type de transducteur ultrasonique.

zone de détection du capteur ultrasonique

documentation

Lexique

LiDAR (Light Detection and Ranging) : procédé d'estimation de la distance à l'aide d'un faisceau lumineux, en général produit par un laser. cf. https://fr.wikipedia.org/wiki/Lidar

ToF (Time of Flight) : Mesure du temps nécessaire pour parcourir une distance. cf. https://en.wikipedia.org/wiki/Time_of_flight

UART (Universal asynchronous receiver-transmitter) : interface hardware de communication asynchrone, dont le type de données et la vitesse de transmission peut-être définie. cf. https://en.wikipedia.org/wiki/Universal_asynchronous_receiver-transmitter

lux unité de mesure de l'éclairement lumineux. cf. https://fr.wikipedia.org/wiki/Lux_(unit%C3%A9)