Operácie

MEMS Cvičenie 8: Rozdiel medzi revíziami

Z SensorWiki

(Principle of operation)
(Zadanie pre ultrazvukový snímač)
 
(24 medziľahlých úprav od rovnakého používateľa nie je zobrazených.)
Riadok 7: Riadok 7:
 
# Prepočítajte zmeranú dobu odozvy na vzdialenosť v cm (výpočet)
 
# Prepočítajte zmeranú dobu odozvy na vzdialenosť v cm (výpočet)
 
# Pridajte kompenzáciu na vplyv teploty (výpočet)
 
# Pridajte kompenzáciu na vplyv teploty (výpočet)
# '''Zmerajte prevodovú charakteristiku snímača''' s kompenzáciou a bez kompenzácie (tabuľka + grafická závislosť zmeranej vzdialenosti od skutočnej)
+
# '''Zmerajte prevodovú charakteristiku snímača''' s kompenzáciou a bez kompenzácie (tabuľka + grafická závislosť zmeranej vzdialenosti od skutočnej) - [http://senzor.robotika.sk/mems/charakteristikaUZ01.png príklad]
 
# Zmerajte '''kritický uhol''' pre vzdialenosť 50, 100 a 150 cm.
 
# Zmerajte '''kritický uhol''' pre vzdialenosť 50, 100 a 150 cm.
 +
# Zmerajte '''vyžarovaciu charakteristiku''' senzora - [http://senzor.robotika.sk/mems/charakteristikaUZ02.png príklad]
 
# Zmerajte minimálnu veľkosť detekovanej prekážky
 
# Zmerajte minimálnu veľkosť detekovanej prekážky
 
# Určte minimálnu a maximálnu detekovanú vzdialenosť
 
# Určte minimálnu a maximálnu detekovanú vzdialenosť
 
# Nájdete objekt neviditeľný pre tento senzor?
 
# Nájdete objekt neviditeľný pre tento senzor?
# Zmerajte vyžarovaciu charakteristiku senzora
 
  
'''Domáca úloha'''
+
= Ultrazvukový senzor na meranie vzdialenosti =
  
Mobilný robot na Marse je natočený smerom na východ. Ultrazvukový otočný senzor zmeral
+
[[Obrázok:SensorPING.jpg|right|200px]]
objekty, ktoré treba preskúmať  v nasledovných troch smeroch (uvedená je vždy séria niekoľkých meraní v stupňoch):
 
* a) 85, 95, 110, 90
 
* b) 350, 360, 0, 10
 
* c) 350, 360, 10, 360
 
Všetky tri sa nachádzajú vo vzdialenosti 100 m. Vypočítajte priemernú hodnotu a smerodajnú odchýlku a na základe
 
toho rozhodnite:<BR>
 
Ktorým smerom sa má vydať na prieskum, aby minul čo najmenej času a energie na otáčanie?
 
  
 +
Na tomto cvičení budeme používať ultrazvukový senzor firmy  Parallax s názvom PING))) Ultrasonic sensor.
  
 +
* [http://www.parallax.com/Portals/0/Downloads/docs/prod/acc/28015-PING-v1.6.pdf PING)))™ Documentation v1.6]  (.pdf)
  
  
= Ultrasonic sensor for distance measurement =
+
'''Vlastnosti:'''
  
 +
* Rozsah merania 2 cm až 3 m
 +
* Ovládanie cez jeden jediný pin
 +
* Indikačná LED dióda signalizuje začiatok merania
 +
* Spotreba 20 mA
 +
* Úzky vyžarovací uhol
  
  
[[Obrázok:SensorPING.jpg|right|200px]]
+
'''Technické údaje:'''
  
In following application we will use the Parallax PING))) Ultrasonic sensor.
+
* Napájanie: +5 VDC
 +
* Spustenie merania: kladný TTL impulz
 +
* Rozmery: 22 x 46 x 16 mm
 +
* Pracovná teplota: 0 až +70 °C
  
* [http://www.parallax.com/Portals/0/Downloads/docs/prod/acc/28015-PING-v1.6.pdf PING)))™ Documentation v1.6]  (.pdf)
 
  
'''Features:'''
 
  
* Provides precise, non-contact distance measurements within a 2 cm to 3 m range
+
=== Princíp činnosti ===
* Simple pulse in/pulse out communication
 
* Burst indicator LED shows measurement in progress
 
* 20 mA power cosumption
 
* Narrow acceptance angle
 
  
'''Key Specifications:'''
+
Snímač Ping meria vzdialenosť podobne ako sonar; najskôr sa vysiela ultrazvukový  (frekvencia je nad hranicou ľudského sluchu) impulz (chirp) a vzdialenosť k cieľu sa určuje meraním času, ktorý je potrebný na zachytenie  ozveny (echa). Výstupom zo snímača je impulz s premenlivou šírkou, ktorý zodpovedá vzdialenosti k cieľu.
  
* Power requirements: +5 VDC
 
* Communication:Positive TTL pulse
 
* Dimensions: 22 x 46 x 16 mm
 
* Operating temp range: 0 to +70 °C
 
 
 
 
=== Principle of operation ===
 
  
 +
[[Obrázok:SensorPingOperation.png|center|450px]][[Obrázok:SensorPingUS_Cone.png|center|350px]]
  
The Ping sensor measures distance using sonar; an ultrasonic (well above human hearing) pulse is transmitted from the unit and distance-to-target is determined by measuring the time required for the echo return. Output from the PING))) sensor is a variable-width pulse that corresponds to the distance to the target.
 
  
[[Obrázok:SensorPingOperation.png|center|450px]][[Obrázok:SensorPingUS_Cone.png|center|350px]]
+
Senzor detekuje objekty tak, že vyšle krátky ultrazvukový signál a potom "počúva" ozvenu. Celý proces riadi mikroprocesor. Najskôr vyšle krátky impulz, ktorý spustí odvysielanie krátkeho 40 kHz (ultrazvuk) impulzu.
 +
Ten sa šíri vzduchom, narazí na objekt a potom sa odrazí späť k snímaču. Medzitým mikroprocesor otočí smer na riadiacom pine, prepne sa do vstupného režimu a počíta, za ako dlho zachytí odozvu (echo). Čas medzi vyslaním a prijatím impulzu je proporcionálna k vzdialenosti objektu.  
  
The PING))) sensor detects objects by emitting a short ultrasonic burst and then "listening" for the echo.
 
Under control of a host microcontroller (trigger pulse), the sensor emits a short 40 kHz (ultrasonic) burst.
 
This burst travels through the air, hits an object and then bounces back to the sensor. The PING)))
 
sensor provides an output pulse to the host that will terminate when the echo is detected, hence the
 
width of this pulse corresponds to the distance to the target.
 
  
 
<!--
 
<!--
Riadok 72: Riadok 57:
 
-->
 
-->
  
== Example program ==
+
== Vzorový program na meranie ==
  
 
<source lang="c">
 
<source lang="c">
Riadok 114: Riadok 99:
  
  
=== pulseIn() ===
+
=== Funkcia pulseIn() ===
  
'''Description'''
+
'''Opis'''
  
Reads a pulse (either HIGH or LOW) on a pin. For example, if value is HIGH, pulseIn() waits for
+
Načíta dĺžku impulzu (buď HIGH alebo LOW) na danom pine. Ak napríklad hodnota 'value; je HIGH, funkcia 'pulseIn()' počká, kým sa log. úroveň na danom pine zmení na HIGH a začne počítať (merať čas). Potom čaká, kým sa hodnota zmení na úroveň LOW a zastaví počítanie. Funkcia vráti dĺžku impulzu v mikrosekundách. Keďže funkcia je blokujúca, má aj tretí parameter 'timeout' -  po jeho vypršaní fukcia skončí a vráti 0.
the pin to go HIGH, starts timing, then waits for the pin to go LOW and stops timing. Returns
 
the length of the pulse in microseconds. Gives up and returns 0 if no pulse starts within a specified time out.
 
  
The timing of this function has been determined empirically and will probably show errors in longer pulses.  
+
Časovanie tejto funkcie autori odvodili metódou pokus-omyl (teda empiricky) a preto pre dlhšie impulzy vykazuje nepresnosti. Funkcia dokáže pracovať s impulzmi od 10 mikrosekúnd až po 3 min.
Works on pulses from 10 microseconds to 3 minutes in length.
 
  
 
'''Syntax'''
 
'''Syntax'''
Riadok 130: Riadok 112:
 
pulseIn(pin, value, timeout)
 
pulseIn(pin, value, timeout)
  
'''Parameters'''
+
'''Parametre'''
 +
 
 +
pin: číslo pinu, na ktorom chceme merať impulz. (int)
 +
 
 +
value: aký impulz chceme merať HIGH alebo LOW. (int)
 +
 
 +
timeout (nepovinný): koľko mikrosekúnd čakať na začiatok impulzu; default hodnota je 1 sekunda (unsigned long)
 +
 
 +
'''Návratová hodnota'''
 +
 
 +
dĺžka impulzu v mikrosekundách, alebo 0 ak impulz nezačal do daného timeoutu (unsigned long)
 +
 
 +
 
 +
 
 +
 
 +
=== Program na meranie a zobrazovanie na LCD displej ===
 +
 
 +
 
 +
Nasledovný program vyšle echo, zmeria čas  za ktorý sa vráti a vypíše ho na displej v mikrosekundách. Na meranie môžete použiť priamo tento program, hodnoty v mikrosekundách si zapisujte a výpočty spravte dodatočne.
 +
 
 +
Nezabudnite nastaviť hodnotu premennej `pingPin` na ten pin, kam skutočne senzor pripojíte.
 +
 
 +
Poznámka: tento program možno po odkomentovaní niektorých častí použiť aj na meranie so senzorom HCSR-04 (lacnejší klon, ktorý však využíva dva oddelené piny na štart a meranie).
 +
 
 +
 
 +
<source lang="c">
  
pin: the number of the pin on which you want to read the pulse. (int)
+
/*
 +
  LiquidCrystal Library - Hello World
  
value: type of pulse to read: either HIGH or LOW. (int)
+
Demonstrates the use a 8x2 LCD display.
  
timeout (optional): the number of microseconds to wait for the pulse to start; default is one second (unsigned long)
+
  The circuit:
 +
* LCD RS pin to digital pin 3
 +
* LCD R/W pin to digital pin 2
 +
* LCD Enable pin to digital pin 1
 +
* LCD D4 pin to digital pin 4
 +
* LCD D5 pin to digital pin 5
 +
* LCD D6 pin to digital pin 6
 +
* LCD D7 pin to digital pin 7
 +
*/
  
'''Returns'''
+
#include <LiquidCrystal.h>          // include the library
  
the length of the pulse (in microseconds) or 0 if no pulse started before the timeout (unsigned long)
+
// initialize the library with the numbers of the interface pins
 +
//  LiquidCrystal(RS, RW, EN, D4, D5, D6, D7)
 +
LiquidCrystal lcd( 3,  2,  1,  4,  5,  6,  7);
 +
int pingPin = 11;
  
== Connection ==
+
const int trigPin = 11;
 +
const int echoPin = 12;
  
  
Interfacing to the microcontrollers is a snap: a single (shared) I/O pin is use to trigger the Ping sensor and "listen" for the echo return pulseAn onboard three-pin header allows the PING))) to be plugged into a solderless breadboard (on an Acrob, for example), and to be connected to its host through a standard three-pin servo extension cable.
+
 
 +
void setup() {
 +
  // set up the LCD's number of columns and rows:
 +
  lcd.begin(8, 2);
 +
  // Print a message to the LCD.
 +
  lcd.print("Time[us]");
 +
 
 +
  pinMode(trigPin, OUTPUT);
 +
  pinMode(echoPin, INPUT);
 +
}
 +
 
 +
void loop() {
 +
 
 +
  long duration1;
 +
  long duration2;
 +
  int distanceCm;
 +
 
 +
    // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
 +
  // We give a short LOW pulse beforehand to ensure a clean HIGH pulse.
 +
 
 +
  pinMode(pingPin, OUTPUT);
 +
  digitalWrite(pingPin, LOW);
 +
  delayMicroseconds(2);
 +
  digitalWrite(pingPin, HIGH);
 +
  delayMicroseconds(5);
 +
  digitalWrite(pingPin, LOW);
 +
 
 +
  // The same pin is used to read the signal from the PING))): a HIGH
 +
  // pulse whose duration is the time (in microseconds) from the sending
 +
  // of the ping to the reception of its echo off of an object.
 +
 
 +
  pinMode(pingPin, INPUT);
 +
  duration1 = pulseIn(pingPin, HIGH);
 +
 
 +
// // Simillar for the HSR-04 sensor
 +
//  digitalWrite(trigPin, LOW);
 +
//  delayMicroseconds(2);
 +
//  digitalWrite(trigPin, HIGH);
 +
//  delayMicroseconds(10);
 +
//  digitalWrite(trigPin, LOW);
 +
//  duration2 = pulseIn(echoPin, HIGH);
 +
 
 +
  // set the cursor to column 0, line 1
 +
  // (note: line 1 is the second row, since counting begins with 0):
 +
  lcd.setCursor(0, 1);
 +
  lcd.print("        ");
 +
  lcd.setCursor(0, 1);
 +
  // print the number of seconds since reset:
 +
  //lcd.print(millis()/1000);
 +
 
 +
  lcd.print(duration1);
 +
//  distanceCm= duration2*0.034/2;
 +
//  lcd.print(distanceCm);
 +
 
 +
  delay(200);
 +
 
 +
}
 +
 
 +
</source>
 +
 
 +
== Zapojenie ==
 +
 
 +
Pripojenie senzora k mikroprocesoru je ve+lmi jednoduché: základom je pripojiť správne napájanie (+5V) na vstup Vcc, a zem na GND. Potom už ostane len pripojiť Start/Echo spoločný vstup/výstup na niektorý z pinov procesora.
 +
Podľa skutočného zapojenia je potom potrebná aj príslušná zmena v ovládacom programe. Na meranie je zrejme najvhodnejšie zapichnúť senzor na okraj univerzálnej prepojovacej doštičky, ale ak chcete, dá sa využiť aj prepojovací ohybný káblik zapojený priamo do konektora na hornom okraji [[Acrob technical description|Acrob dosky]].  
  
 
[[Obrázok:SensorPingConnection.png|center|600px]]
 
[[Obrázok:SensorPingConnection.png|center|600px]]
  
  
== Sources of errors ==
+
== Zdroje chýb merania ==
  
  
=== Air Temperature ===
+
=== Teplota vzduchu ===
  
Changing environmental conditions are the main source of the differences. Many quantities influences measurement
+
Na meranie najviac vplývajú meniace sa atmosférické podmienky. Vietor a prúdenie vzduchu vykompenzovať nevieme. Okrem toho však na meranie najviac vplýva
including temperature, humidity, turbulences, pressure and damping. Main source of error is air circulation and
+
teplota, vlhkosť, zmeny tlaku a útlm signálu. V literatúre možno nájsť niekoľko vzťahov pre kompenzáciu vplyvu teploty a vlhkosti, tu uvedieme dva z nich:<BR>
temperature. Many equations appears in literature, two of them are mentioned here:<BR>
 
 
<math>
 
<math>
 
  (1) \qquad    c = c_0 ( 1 + \gamma \vartheta )( 1 + A_V \eta )   
 
  (1) \qquad    c = c_0 ( 1 + \gamma \vartheta )( 1 + A_V \eta )   
 
</math>  
 
</math>  
  
where
+
kde
* <math>c_0</math> - speed of the sound at 0° C and 0% RH (c0 = 331,5 [m/s]),
+
* <math>c_0</math> - je rýchlosť zvuku pri teplote 0 °C a relatívnej vlhkosti 0% RH (c0 = 331,5 [m/s]),
* <math>\gamma</math> - temperature coefficient of the speed (@ 0° C), γ = 1.83 10-3 [°C-1],
+
* <math>\gamma</math> - teplotný koeficient rýchlosti (pri 0° C), γ = 1.83 10-3 [°C-1],
* <math>A_V</math> - humidity constatnt (AV = 2,2 . 10^-4, for 50 ÷ 200 kHz),  
+
* <math>A_V</math> - koeficient vlhosti (AV = 2,2 . 10^-4, pre frekvencie 50 ÷ 200 kHz),  
* <math>\eta</math> - relative humidity of air [%],
+
* <math>\eta</math> - relatívna vlhkosť vzduchu humidity of air [%],
* <math>\vartheta</math> - air temperature [°C].
+
* <math>\vartheta</math> - teplota vzduchu [°C].
  
For practical purposes we can abandon humidity influences and then simplified formula applies:<BR>
+
Pre praktické účely sa často vplyv vlhkosti zanedbáva a používa sa len zjednodušený korekčný vzťah:<BR>
 +
<!--
 
<math>
 
<math>
  (2)  \qquad  c = c_0 + 0,6 \vartheta [m/s]
+
  (2)  \qquad  c = c_0 + 0,6 \vartheta [m/s]
 
</math>
 
</math>
 +
-->
  
The percent error over the sensor’s operating range of 0 to 70 ° C is significant, in the magnitude of 11
+
<html>
to 12 percent. The use of conversion constants to account for air temperature may be incorporated into
+
<math xmlns="http://www.w3.org/1998/Math/MathML" display="block" title=" (2) \qquad c = c_0 + 0,6 \vartheta \qquad [m/s]  ">
your program.
+
  <mrow>
 +
    <mo stretchy="false">(</mo>
 +
    <mn>2</mn>
 +
    <mo stretchy="false">)</mo>
 +
    <mspace width="2em"/>
 +
    <mi>c</mi>
 +
    <mo>=</mo>
 +
    <msub>
 +
      <mrow>
 +
        <mi>c</mi>
 +
      </mrow>
 +
      <mrow>
 +
        <mn>0</mn>
 +
      </mrow>
 +
    </msub>
 +
    <mo>+</mo>
 +
    <mn>0</mn>
 +
    <mo>,</mo>
 +
    <mn>6</mn>
 +
    <mi>ϑ</mi>
 +
    <mspace width="2em"/>
 +
    <mi>[</mi>
 +
    <mi>m</mi>
 +
    <mo>/</mo>
 +
    <mi>s</mi>
 +
    <mi>]</mi>
 +
  </mrow>
 +
</math>
 +
</html>
  
 +
V rozsahu teplôt 0 až 70 °C je korekcia na teplotu veľmi dôležitá, chyba dosahuje veľksoť až 11-12 percent. Vhodnú kompenzačnú funkciu môžete implementovať
 +
priamo do programu, alebo kompenzáciu dopočítate dodatočne pri spracovaní nameraných dát.
  
  
 +
<center>
  
 +
[[Súbor:UltrasonicAmbiguities.png]]<BR>
 +
<I>Neistoty pri detekcii objektov ultrazvukovým senzorom. <BR>Zdroj:
 +
Tareen, Shaharyar Ahmed Khan. (2016). [https://www.researchgate.net/publication/318216130_Design_Development_of_THE_ROBUST_-_An_Autonomous_Mobile_Robot Design & Development of THE ROBUST – An Autonomous Mobile Robot]. Journal of Space Technology. 6. 14-23. </I>
 +
</center>
 +
 +
=== Kritický uhol ===
 +
 +
Kritický uhol je taký uhol, pod ktorým dopadá ultrazvuková vlna na prekážku, kedy sa väčšina odrazí smerom od senzora a ten potom nezaregistruje žiaden odraz. Meranie kritického uhla robíme podložkou, ktorú otáčame dovtedy, kým nameraná vzdialenosť zodpovedá skutočnej. Po prudkej zmene detekovanej vzdialenosti zapíšeme hodnotu kritického uhla v danej vzdialenosti.
 +
 +
 +
[[Súbor:UZ-MeranieKritickehoUhla.png|center]]
 +
 +
=== Vyžarovacia charakteristika ===
 +
 +
Vyžarovaciu charakteristiku meriame tak, že zboku, kolmo na os senzora, pomaly zasúvame dostatočne veľkú prekážku. Akonáhle ju senzor začne detekovať, zapíšeme si vzdialenosť od kolmice a takto získané údaje vykreslíme do grafu.
 +
 +
[[Súbor:UZ-MeranieVyzarovacejCharakteristiky.png|center]]
  
 
Potrebujete pravítko, alebo uhlomer?
 
Potrebujete pravítko, alebo uhlomer?
Riadok 187: Riadok 319:
 
# [http://www.teachervision.fen.com/tv/printables/scottforesman/Math_6_TTT_17.pdf Uhlomer 2]
 
# [http://www.teachervision.fen.com/tv/printables/scottforesman/Math_6_TTT_17.pdf Uhlomer 2]
 
# [http://www.ossmann.com/protractor/conventional-protractor.pdf Uhlomer 3]
 
# [http://www.ossmann.com/protractor/conventional-protractor.pdf Uhlomer 3]
 +
 +
 +
[[Súbor:logoTinkerCAD.png|left]] Ak nemôžete prísť na cvičenie do laboratória, aspoň čiastočne si ho môžete nahradiť [https://www.tinkercad.com/things/bYVr5DA8INW-surprising-habbi-hillar/editel?sharecode=uPk_QW3dja21IZHMeHPWhxlis9iPn6_LneXe8XYy23I simulátorom TinkerCAD].
 +
 +
 +
 +
<BR>
 +
<BR>
 +
<BR>
 +
<BR>
 +
<BR>
 +
<BR>
 +
 +
 +
'''Nepovinná domáca úloha'''
 +
 +
 +
Mobilný robot na Marse je natočený smerom na východ. Ultrazvukový otočný senzor zmeral
 +
objekty, ktoré treba preskúmať  v nasledovných troch smeroch (uvedená je vždy séria niekoľkých meraní v stupňoch):
 +
* a) 85, 95, 110, 90
 +
* b) 350, 360, 0, 10
 +
* c) 350, 360, 10, 360
 +
Všetky tri sa nachádzajú vo vzdialenosti 100 m. Vypočítajte priemernú hodnotu a smerodajnú odchýlku a na základe
 +
toho rozhodnite:<BR>
 +
Ktorým smerom sa má vydať na prieskum, aby minul čo najmenej času a energie na otáčanie?
  
  

Aktuálna revízia z 14:41, 26. apríl 2022

Ultrazvukové snímače

Zadanie pre ultrazvukový snímač

  1. Zmerajte dobu odozvy UZ snímača pri odraze od prekážky
  2. Prepočítajte zmeranú dobu odozvy na vzdialenosť v cm (výpočet)
  3. Pridajte kompenzáciu na vplyv teploty (výpočet)
  4. Zmerajte prevodovú charakteristiku snímača s kompenzáciou a bez kompenzácie (tabuľka + grafická závislosť zmeranej vzdialenosti od skutočnej) - príklad
  5. Zmerajte kritický uhol pre vzdialenosť 50, 100 a 150 cm.
  6. Zmerajte vyžarovaciu charakteristiku senzora - príklad
  7. Zmerajte minimálnu veľkosť detekovanej prekážky
  8. Určte minimálnu a maximálnu detekovanú vzdialenosť
  9. Nájdete objekt neviditeľný pre tento senzor?

Ultrazvukový senzor na meranie vzdialenosti

SensorPING.jpg

Na tomto cvičení budeme používať ultrazvukový senzor firmy Parallax s názvom PING))) Ultrasonic sensor.


Vlastnosti:

  • Rozsah merania 2 cm až 3 m
  • Ovládanie cez jeden jediný pin
  • Indikačná LED dióda signalizuje začiatok merania
  • Spotreba 20 mA
  • Úzky vyžarovací uhol


Technické údaje:

  • Napájanie: +5 VDC
  • Spustenie merania: kladný TTL impulz
  • Rozmery: 22 x 46 x 16 mm
  • Pracovná teplota: 0 až +70 °C


Princíp činnosti

Snímač Ping meria vzdialenosť podobne ako sonar; najskôr sa vysiela ultrazvukový (frekvencia je nad hranicou ľudského sluchu) impulz (chirp) a vzdialenosť k cieľu sa určuje meraním času, ktorý je potrebný na zachytenie ozveny (echa). Výstupom zo snímača je impulz s premenlivou šírkou, ktorý zodpovedá vzdialenosti k cieľu.


SensorPingOperation.png
SensorPingUS Cone.png


Senzor detekuje objekty tak, že vyšle krátky ultrazvukový signál a potom "počúva" ozvenu. Celý proces riadi mikroprocesor. Najskôr vyšle krátky impulz, ktorý spustí odvysielanie krátkeho 40 kHz (ultrazvuk) impulzu. Ten sa šíri vzduchom, narazí na objekt a potom sa odrazí späť k snímaču. Medzitým mikroprocesor otočí smer na riadiacom pine, prepne sa do vstupného režimu a počíta, za ako dlho zachytí odozvu (echo). Čas medzi vyslaním a prijatím impulzu je proporcionálna k vzdialenosti objektu.


Vzorový program na meranie

int pingPin = 11;

void setup()
{
  Serial.begin(9600);
}

void loop()
{
  long duration;

  // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
  // We give a short LOW pulse beforehand to ensure a clean HIGH pulse.

  pinMode(pingPin, OUTPUT);
  digitalWrite(pingPin, LOW);
  delayMicroseconds(2);
  digitalWrite(pingPin, HIGH);
  delayMicroseconds(5);
  digitalWrite(pingPin, LOW);

  // The same pin is used to read the signal from the PING))): a HIGH
  // pulse whose duration is the time (in microseconds) from the sending
  // of the ping to the reception of its echo off of an object.

  pinMode(pingPin, INPUT);
  duration = pulseIn(pingPin, HIGH);

  Serial.print(duration);
  Serial.print("us");
  Serial.println();

  delay(100);
}


Funkcia pulseIn()

Opis

Načíta dĺžku impulzu (buď HIGH alebo LOW) na danom pine. Ak napríklad hodnota 'value; je HIGH, funkcia 'pulseIn()' počká, kým sa log. úroveň na danom pine zmení na HIGH a začne počítať (merať čas). Potom čaká, kým sa hodnota zmení na úroveň LOW a zastaví počítanie. Funkcia vráti dĺžku impulzu v mikrosekundách. Keďže funkcia je blokujúca, má aj tretí parameter 'timeout' - po jeho vypršaní fukcia skončí a vráti 0.

Časovanie tejto funkcie autori odvodili metódou pokus-omyl (teda empiricky) a preto pre dlhšie impulzy vykazuje nepresnosti. Funkcia dokáže pracovať s impulzmi od 10 mikrosekúnd až po 3 min.

Syntax

pulseIn(pin, value) pulseIn(pin, value, timeout)

Parametre

pin: číslo pinu, na ktorom chceme merať impulz. (int)

value: aký impulz chceme merať HIGH alebo LOW. (int)

timeout (nepovinný): koľko mikrosekúnd čakať na začiatok impulzu; default hodnota je 1 sekunda (unsigned long)

Návratová hodnota

dĺžka impulzu v mikrosekundách, alebo 0 ak impulz nezačal do daného timeoutu (unsigned long)



Program na meranie a zobrazovanie na LCD displej

Nasledovný program vyšle echo, zmeria čas za ktorý sa vráti a vypíše ho na displej v mikrosekundách. Na meranie môžete použiť priamo tento program, hodnoty v mikrosekundách si zapisujte a výpočty spravte dodatočne.

Nezabudnite nastaviť hodnotu premennej `pingPin` na ten pin, kam skutočne senzor pripojíte.

Poznámka: tento program možno po odkomentovaní niektorých častí použiť aj na meranie so senzorom HCSR-04 (lacnejší klon, ktorý však využíva dva oddelené piny na štart a meranie).


/*
  LiquidCrystal Library - Hello World

 Demonstrates the use a 8x2 LCD display.

   The circuit:
 * LCD RS pin to digital pin 3
 * LCD R/W pin to digital pin 2
 * LCD Enable pin to digital pin 1
 * LCD D4 pin to digital pin 4
 * LCD D5 pin to digital pin 5
 * LCD D6 pin to digital pin 6
 * LCD D7 pin to digital pin 7
 */

#include <LiquidCrystal.h>           // include the library

// initialize the library with the numbers of the interface pins
//  LiquidCrystal(RS, RW, EN, D4, D5, D6, D7)
LiquidCrystal lcd( 3,  2,  1,  4,  5,  6,  7);
int pingPin = 11;

const int trigPin = 11;
const int echoPin = 12;



void setup() {
  // set up the LCD's number of columns and rows:
  lcd.begin(8, 2);
  // Print a message to the LCD.
  lcd.print("Time[us]");

  pinMode(trigPin, OUTPUT);
  pinMode(echoPin, INPUT);
}

void loop() {

  long duration1;
  long duration2;
   int distanceCm;

     // The PING))) is triggered by a HIGH pulse of 2 or more microseconds.
  // We give a short LOW pulse beforehand to ensure a clean HIGH pulse.

  pinMode(pingPin, OUTPUT);
  digitalWrite(pingPin, LOW);
  delayMicroseconds(2);
  digitalWrite(pingPin, HIGH);
  delayMicroseconds(5);
  digitalWrite(pingPin, LOW);

  // The same pin is used to read the signal from the PING))): a HIGH
  // pulse whose duration is the time (in microseconds) from the sending
  // of the ping to the reception of its echo off of an object.

  pinMode(pingPin, INPUT);
  duration1 = pulseIn(pingPin, HIGH);

//  // Simillar for the HSR-04 sensor
//  digitalWrite(trigPin, LOW);
//  delayMicroseconds(2);
//  digitalWrite(trigPin, HIGH);
//  delayMicroseconds(10);
//  digitalWrite(trigPin, LOW);
//  duration2 = pulseIn(echoPin, HIGH);

  // set the cursor to column 0, line 1
  // (note: line 1 is the second row, since counting begins with 0):
  lcd.setCursor(0, 1);
  lcd.print("        ");
  lcd.setCursor(0, 1);
  // print the number of seconds since reset:
  //lcd.print(millis()/1000);

  lcd.print(duration1);
//  distanceCm= duration2*0.034/2;
//  lcd.print(distanceCm);

  delay(200);

}

Zapojenie

Pripojenie senzora k mikroprocesoru je ve+lmi jednoduché: základom je pripojiť správne napájanie (+5V) na vstup Vcc, a zem na GND. Potom už ostane len pripojiť Start/Echo spoločný vstup/výstup na niektorý z pinov procesora. Podľa skutočného zapojenia je potom potrebná aj príslušná zmena v ovládacom programe. Na meranie je zrejme najvhodnejšie zapichnúť senzor na okraj univerzálnej prepojovacej doštičky, ale ak chcete, dá sa využiť aj prepojovací ohybný káblik zapojený priamo do konektora na hornom okraji Acrob dosky.

SensorPingConnection.png


Zdroje chýb merania

Teplota vzduchu

Na meranie najviac vplývajú meniace sa atmosférické podmienky. Vietor a prúdenie vzduchu vykompenzovať nevieme. Okrem toho však na meranie najviac vplýva teplota, vlhkosť, zmeny tlaku a útlm signálu. V literatúre možno nájsť niekoľko vzťahov pre kompenzáciu vplyvu teploty a vlhkosti, tu uvedieme dva z nich:

 (1) \qquad    c = c_0 ( 1 + \gamma \vartheta )( 1 + A_V \eta )

kde

  • c_0 - je rýchlosť zvuku pri teplote 0 °C a relatívnej vlhkosti 0% RH (c0 = 331,5 [m/s]),
  • \gamma - teplotný koeficient rýchlosti (pri 0° C), γ = 1.83 10-3 [°C-1],
  • A_V - koeficient vlhosti (AV = 2,2 . 10^-4, pre frekvencie 50 ÷ 200 kHz),
  • \eta - relatívna vlhkosť vzduchu humidity of air [%],
  • \vartheta - teplota vzduchu [°C].

Pre praktické účely sa často vplyv vlhkosti zanedbáva a používa sa len zjednodušený korekčný vzťah:

( 2 ) c = c 0 + 0 , 6 ϑ [ m / s ]

V rozsahu teplôt 0 až 70 °C je korekcia na teplotu veľmi dôležitá, chyba dosahuje veľksoť až 11-12 percent. Vhodnú kompenzačnú funkciu môžete implementovať priamo do programu, alebo kompenzáciu dopočítate dodatočne pri spracovaní nameraných dát.


UltrasonicAmbiguities.png
Neistoty pri detekcii objektov ultrazvukovým senzorom.
Zdroj: Tareen, Shaharyar Ahmed Khan. (2016). Design & Development of THE ROBUST – An Autonomous Mobile Robot. Journal of Space Technology. 6. 14-23.

Kritický uhol

Kritický uhol je taký uhol, pod ktorým dopadá ultrazvuková vlna na prekážku, kedy sa väčšina odrazí smerom od senzora a ten potom nezaregistruje žiaden odraz. Meranie kritického uhla robíme podložkou, ktorú otáčame dovtedy, kým nameraná vzdialenosť zodpovedá skutočnej. Po prudkej zmene detekovanej vzdialenosti zapíšeme hodnotu kritického uhla v danej vzdialenosti.


UZ-MeranieKritickehoUhla.png

Vyžarovacia charakteristika

Vyžarovaciu charakteristiku meriame tak, že zboku, kolmo na os senzora, pomaly zasúvame dostatočne veľkú prekážku. Akonáhle ju senzor začne detekovať, zapíšeme si vzdialenosť od kolmice a takto získané údaje vykreslíme do grafu.

UZ-MeranieVyzarovacejCharakteristiky.png

Potrebujete pravítko, alebo uhlomer?

  1. Printable paper rules
  2. Uhlomer 1
  3. Uhlomer 2
  4. Uhlomer 3


LogoTinkerCAD.png
Ak nemôžete prísť na cvičenie do laboratória, aspoň čiastočne si ho môžete nahradiť simulátorom TinkerCAD.









Nepovinná domáca úloha


Mobilný robot na Marse je natočený smerom na východ. Ultrazvukový otočný senzor zmeral objekty, ktoré treba preskúmať v nasledovných troch smeroch (uvedená je vždy séria niekoľkých meraní v stupňoch):

  • a) 85, 95, 110, 90
  • b) 350, 360, 0, 10
  • c) 350, 360, 10, 360

Všetky tri sa nachádzajú vo vzdialenosti 100 m. Vypočítajte priemernú hodnotu a smerodajnú odchýlku a na základe toho rozhodnite:
Ktorým smerom sa má vydať na prieskum, aby minul čo najmenej času a energie na otáčanie?


Návrat na zoznam cvičení...