AlphaBot: Ultraschall Notbremse: Unterschied zwischen den Versionen
Zur Navigation springen
Zur Suche springen
Zeile 13: | Zeile 13: | ||
#include "AlphaBot.h" | #include "AlphaBot.h" | ||
#include <Servo.h> | #include <Servo.h> | ||
// Instanzen erzeugen | |||
AlphaBot Alf = AlphaBot(); // Instanz des AlphaBot erzeugen | |||
Servo AlfServo; // Servo Instanz | |||
// KONSTANTEN deklarieren | // KONSTANTEN deklarieren | ||
Zeile 22: | Zeile 26: | ||
const int nServoPort = 9; // Der Servo liegt auf D9 | const int nServoPort = 9; // Der Servo liegt auf D9 | ||
void initUltraschall() | void initUltraschall() | ||
{ | { | ||
pinMode( | pinMode(TRIG, OUTPUT); // Ultraschall Trigger als Ausgang deklarieren | ||
pinMode( | pinMode(ECHO, INPUT); // Ultraschall Echo als Eingang deklarieren | ||
} | } | ||
float messeUSAbstand() | float messeUSAbstand() // Abstand in cm | ||
{ | { | ||
float USAbstand = 0; // Rückgabewert initialisieren | float USAbstand = 0; // Rückgabewert initialisieren | ||
Zeile 40: | Zeile 41: | ||
delayMicroseconds(10); | delayMicroseconds(10); | ||
digitalWrite(TRIG, LOW); // setze Trigger auf LOW | digitalWrite(TRIG, LOW); // setze Trigger auf LOW | ||
float fSignalLaufzeit = pulseIn(ECHO, HIGH); // Messung der | float fSignalLaufzeit = pulseIn(ECHO, HIGH); // Messung der Signallaufzeit des Impulses | ||
USAbstand = fSignalLaufzeit/58; // Umrechnung Laufzeit in s in Abstand in cm | USAbstand = fSignalLaufzeit/58; // Umrechnung Laufzeit in s in Abstand in cm |
Version vom 28. April 2022, 14:52 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 byte PORT_ENC_L=2; // Die linke Lichtschranke (CNTL) liegt an Arduino D2 const byte PORT_ENC_R=3; // Die rechte Lichtschranke (CNTR) liegt an Arduino D3 const byte ANZAHL_INCREMENTE=40; // Die Encoderscheibe hat 20 Löcher und somit 40 Zustände 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 USAbstand = 0; // Rückgabewert initialisieren 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 float fSignalLaufzeit = pulseIn(ECHO, HIGH); // Messung der Signallaufzeit des Impulses USAbstand = 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 USAbstand; // 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); 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