AlphaBot: Ultraschall Notbremse: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
Keine Bearbeitungszusammenfassung |
|||
(5 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 7: | Zeile 7: | ||
* Wir sind vorwärts gefahren und haben 20 cm eine Notbremsung gemacht. | * Wir sind vorwärts gefahren und haben 20 cm eine Notbremsung gemacht. | ||
[[Datei:Notbremse.jpg|right|200px|Abb. 1: Programmablaufplan]]<br/> | |||
[[Datei:Notbremse.jpg| | |||
== Quelltext == | == Quelltext == | ||
Zeile 22: | Zeile 21: | ||
// KONSTANTEN deklarieren | // KONSTANTEN deklarieren | ||
const int TRIG = 11; // US Trigger an D11 | const int TRIG = 11; // US Trigger an D11 | ||
const int ECHO = 12; // US Echo an D12 | const int ECHO = 12; // US Echo an D12 | ||
Zeile 38: | Zeile 34: | ||
float messeUSAbstand() // Abstand in cm | float messeUSAbstand() // Abstand in cm | ||
{ | { | ||
float | float fUSAbstand = 0; // Rückgabewert initialisieren | ||
float fSignalLaufzeit=0; // Messwert der Signallaufzeit | |||
digitalWrite(TRIG, LOW); // setze Trigger auf LOW für 2μs | digitalWrite(TRIG, LOW); // setze Trigger auf LOW für 2μs | ||
delayMicroseconds(2); | delayMicroseconds(2); | ||
Zeile 44: | Zeile 42: | ||
delayMicroseconds(10); | delayMicroseconds(10); | ||
digitalWrite(TRIG, LOW); // setze Trigger auf LOW | digitalWrite(TRIG, LOW); // setze Trigger auf LOW | ||
fSignalLaufzeit = pulseIn(ECHO, HIGH); // Messung der Signallaufzeit des Impulses | |||
fUSAbstand = fSignalLaufzeit/58; // Umrechnung Laufzeit in s in Abstand in cm | |||
//Y m =(X s * 344)/ 2; | //Y m =(X s * 344)/ 2; | ||
//X s =( 2 * Y m)/ 344; | //X s =( 2 * Y m)/ 344; | ||
//X s = 0.0058 * Y m; | //X s = 0.0058 * Y m; | ||
//cm = us /58 | //cm = us /58 | ||
return | return fUSAbstand; // Rückgabewert | ||
} | } | ||
Zeile 60: | Zeile 58: | ||
Serial.begin(9600); // Serieller Monitor mit 9600 Baud | Serial.begin(9600); // Serieller Monitor mit 9600 Baud | ||
AlfServo.write(90); // Der Servo soll sich an die Mitte drehen | AlfServo.write(90); // Der Servo soll sich an die Mitte drehen | ||
delay(15); | delay(15); // Drehung abwarten | ||
Alf.MotorRun(80,80); // Alf fährt vorwärts; Leistung 100 | Alf.MotorRun(80,80); // Alf fährt vorwärts; Leistung 100 | ||
} | } |
Aktuelle Version vom 28. April 2022, 15:28 Uhr
Autor: Prof. Dr.-Ing. Schneider
Inhalt des siebten Termins
- Wir haben die Servoansteuerung wiederholt.
- Wir haben den Ultraschall-Sensor mittig ausgerichtet.
- Wir haben Abstandswerte gemessen.
- Wir sind vorwärts gefahren und haben 20 cm eine Notbremsung gemacht.
Quelltext
// Bibliotheken einbinden #include "AlphaBot.h" #include <Servo.h> // Instanzen erzeugen AlphaBot Alf = AlphaBot(); // Instanz des AlphaBot erzeugen Servo AlfServo; // Servo Instanz // KONSTANTEN deklarieren const int TRIG = 11; // US Trigger an D11 const int ECHO = 12; // US Echo an D12 const int nServoPort = 9; // Der Servo liegt auf D9 void initUltraschall() { pinMode(TRIG, OUTPUT); // Ultraschall Trigger als Ausgang deklarieren pinMode(ECHO, INPUT); // Ultraschall Echo als Eingang deklarieren } float messeUSAbstand() // Abstand in cm { float fUSAbstand = 0; // Rückgabewert initialisieren float fSignalLaufzeit=0; // Messwert der Signallaufzeit digitalWrite(TRIG, LOW); // setze Trigger auf LOW für 2μs delayMicroseconds(2); digitalWrite(TRIG, HIGH); // setze Trigger auf HIGH für mind. 10 us delayMicroseconds(10); digitalWrite(TRIG, LOW); // setze Trigger auf LOW fSignalLaufzeit = pulseIn(ECHO, HIGH); // Messung der Signallaufzeit des Impulses fUSAbstand = fSignalLaufzeit/58; // Umrechnung Laufzeit in s in Abstand in cm //Y m =(X s * 344)/ 2; //X s =( 2 * Y m)/ 344; //X s = 0.0058 * Y m; //cm = us /58 return fUSAbstand; // Rückgabewert } void setup() // Einmalige Systeminitialisierung { initUltraschall(); // US initialisieren AlfServo.attach(nServoPort); // Servo verbinden Serial.begin(9600); // Serieller Monitor mit 9600 Baud AlfServo.write(90); // Der Servo soll sich an die Mitte drehen delay(15); // Drehung abwarten Alf.MotorRun(80,80); // Alf fährt vorwärts; Leistung 100 } void loop() // Main Schleife { float USAbstand =0; USAbstand = messeUSAbstand(); // US Abstand messen Serial.println(USAbstand); if (USAbstand<20){ Serial.println("Notbremse"); Alf.Brake(); // Anhalten } }
Hausaufgaben bis zum 8. Termin
- Suche mit dem Ultraschall den Bereich 0°-180° vor dem AlphaBot ab.
- Fahre auf das nächstgelegene Ziel im Sichtbereich zu.
- Stoppe 10 cm vor dem Ziel.
Musterlösung
→ zurück zum Hauptartikel: Projekt Alf