Accéder au contenu principal

Détecteur d'ultrasons HC-SR04

J'ai également commandé un détecteur à ultrasons HC-SR04 pour 2 USD chez ITEAD Studio (http://imall.iteadstudio.com/im120628012.html). Après 3 semaines d'attente, j'ai reçu les 2 récepteurs.
Quelles utilisations? Montées sur un véhicule, le détecteur permettra de détecter les obstacles avant de les atteindre. J'ai fait quelques essais avec un RoboSapien, ce qui permet de lui donner un peu plus d'autonomie.
Comme d'habitude, seuls les drivers Arduino sont disponibles par défaut. Pour les drivers C#, il fait donc chercher sur le site de GHI si le driver existe, sinon, se rabattre sur le site Netduino ou le cas échéant, adapter le driver en C++ de l'Arduino en C#. Il peut parfois être nécessaire de lire la spécification du protocole utilisé pour mieux comprendre comment l'équipement fonctionne.
Pour le raccordement à la FEZ Panda 2, j'ai utilisé un cordon Grove avec 4 pin séparées. La carte utilise 2 ports digitaux. Un port pour envoyer le signal et un pour recevoir le retour.

Voici la librairie adaptée de la librairie Netduino équivalente à laquelle j'ai rajouté la mesure en centimètres :
 using System;  
 using Microsoft.SPOT;  
 using System.Threading;  
 using Microsoft.SPOT.Hardware;  
 using GHIElectronics.NETMF.FEZ;  
 namespace ITEADStudio  
 {  
   public class HC_SR04  
   {  
     private OutputPort portOut;  
     private InterruptPort interIn;  
     private long beginTick;  
     private long endTick;  
     private long minTicks;  
     private double inchConversion;  
     private double cmConversion;  
     private double version;  
     public HC_SR04(Cpu.Pin pinTrig, Cpu.Pin pinEcho)  
     {  
       portOut = new OutputPort(pinTrig, false);  
       interIn = new InterruptPort(pinEcho, false, Port.ResistorMode.Disabled, Port.InterruptMode.InterruptEdgeLow);  
       interIn.OnInterrupt += new NativeEventHandler(interIn_OnInterrupt);  
       minTicks = 6200L;  
       inchConversion = 1440.0;  
       cmConversion = 580;  
       version = 1.1;  
     }  
     public double Version  
     {  
       get  
       {  
         return version;  
       }  
     }  
     public long Ping()  
     {  
       // Reset Sensor  
       portOut.Write(true);  
       Thread.Sleep(1);  
       // Start Clock  
       endTick = 0L;  
       beginTick = System.DateTime.Now.Ticks;  
       // Trigger Sonic Pulse  
       portOut.Write(false);  
       Thread.Sleep(50);  
       if (endTick > 0L)  
       {  
         long elapsed = endTick - beginTick;  
         elapsed -= minTicks;  
         if (elapsed < 0L)  
         {  
           elapsed = 0L;  
         }  
         return elapsed;  
       }  
       return -1L;  
     }  
     void interIn_OnInterrupt(uint data1, uint data2, DateTime time)  
     {  
       endTick = time.Ticks;  
     }  
     public double TicksToInches(long ticks)  
     {  
       return (double)ticks / inchConversion;  
     }  
     public double TicksToCm(long ticks)  
     {  
       return (double)ticks / cmConversion;  
     }  
     public double InchCoversionFactor  
     {  
       get  
       {  
         return inchConversion;  
       }  
       set  
       {  
         inchConversion = value;  
       }  
     }  
     public long LatencyTicks  
     {  
       get  
       {  
         return minTicks;  
       }  
       set  
       {  
         minTicks = value;  
       }  
     }  
   }  
 }  

Voici un exemple simple d'utilisation :
 using System;  
 using System.Threading;  
 using Microsoft.SPOT;  
 using Microsoft.SPOT.Hardware;  
 using GHIElectronics.NETMF.FEZ;  
 using ITEADStudio;  
 namespace DemoUltraSonic  
 {  
   public class Program  
   {  
     public static void Main()  
     {  
       HC_SR04 sensor = new HC_SR04((Cpu.Pin)FEZ_Pin.Digital.Di1, (Cpu.Pin)FEZ_Pin.Digital.Di2);  
       while (true)  
       {  
         //Debug.Print("Ping");  
         long ticks = sensor.Ping();  
         if (ticks > 0L)  
         {  
           double centimeters = sensor.TicksToCm(ticks);  
           Debug.Print("Distance " + centimeters);  
         }  
       }  
     }  
   }  
 }  

Il est cependant préférable de prévoir un debouncing. La distance retournée est souvent précise, mais il peut arriver que des valeurs incorrectes soient renvoyées.

Commentaires

Posts les plus consultés de ce blog

Utilisez votre tablette Android comme second écran pour Linux (Raspberry Pi, MK908II)

Les tablettes Android atteignent désormais des prix qui défient toute concurrence. On trouve désormais des modèles à 39 € TTC en super marché, soit à peine plus cher que le Raspberry PI, mais avec un écran. Ces modèles souvent mono-core 1Ghz ou 1,4 Ghz avec 512 ou 1Go de mémoire ne sont très probablement pas utilisables pour une utilisation régulière sur Internet et ne sont en aucun point comparables à leur équivalent de marque (Samsung, Sony, LG, HTC, Lenovo, etc). Plusieurs tutoriels indiquent comment connecter utiliser une tablette Android comme second écran ( http://www.linux-magazine.com/Online/Blogs/Productivity-Sauce/Use-an-Android-Device-as-Screen-and-Input-for-Raspberry-Pi ). Ces méthodes utilisent généralement l'USB Tethering qui n'est malheureusement disponible que sur les téléphones ou tablettes avec un accès mobile (3G ou 4G) inclus. Dans ce billet, je vais vous montrer comment se connecter à une tablette en utilisant le mode Debug adb (Android Debug Bridge

Supprimer les partitions Raspberry sur une carte SD sous Windows avec Diskpart

Si vous souhaitez récupérer une ancienne carte SD utilisée pour démarrer un Raspberry pour un autre usage (appareil photo, etc), il vous faudra supprimer les deux partitions créées au moment de l'écriture de l'image sur la carte SD. Vous pouvez voir les partition en sélectionnant Menu Windows/Ordinateur/bouton droit "Gérer". Voici un exemple du résultat final. Vous pouvez supprimer la partition Unix de 7 Gb (ou 4Gb en fonction de la taille de votre carte) en sélectionnant la partition puis en faisant "bouton droit Supprimer". Laissez juste une partition pour pouvoir faire les autres manipulations avec DISKPART. Démarrez l'outil DISKPART en ligne de commande. Une nouvelle fenêtre s'ouvrira. Microsoft DiskPart version 6.1.7601 Copyright (C) 1999-2008 Microsoft Corporation. DISKPART> list disk   N° disque  Statut         Taille   Libre    Dyn  GPT   ---------  -------------  -------  -------  ---  ---   Disque 0    En ligne        238 G octe

Emulateur Raspberry Pi sous Windows

Si vous souhaitez développer ou tester des applications pour Raspberry Pi, vous pouvez, soit compiler directement l'application sur Raspberry, soit la développer sous Linux ou Windows et la compiler pour Raspberry. La seconde solution est souvent plus simple car elle permet de disposer d'un environnement de compilation complet tel qu'Eclipse pour le développement. Une fois l'application développée, il faut la tester sur Raspberry. Là, il faut copier l'application en utilisant un client FTP ou SCP, puis se connecter en SSH et lancer l'exécutable. Il existe un autre moyen de tester une application Raspberry sans avoir à l'allumer. Il suffit de passer par un émulateur tel que QEMU qui permet de lancer un OS pour processeur ARM sous Linux ou Windows. L'émulateur sous Windows 1. Récupérez l'émulateur à l'adresse suivante : http://sourceforge.net/projects/rpi-emulator-win32/ . 2. Dézippés le contenu de l'image Rpi-Occidentalis-v02-qemu.7z av