Pathfinding nach rechts funktioniert noch nicht...der rest schon

Dependencies:   mbed

Fork of MicroMouse_MASTER_THREE by PES2_R2D2.0

Committer:
ruesipat
Date:
Wed May 16 16:41:44 2018 +0000
Revision:
9:ab19796bf14a
Parent:
7:5ef09519a6e9
;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ruesipat 1:d9e840c48b1e 1 #include <cmath>
ruesipat 5:b8b1a979b0d5 2 #include "mbed.h"
ruesipat 1:d9e840c48b1e 3 #include "Drive.h"
ruesipat 1:d9e840c48b1e 4
ruesipat 1:d9e840c48b1e 5
ruesipat 1:d9e840c48b1e 6
TheDarkDurzo 3:2ec7cf8bc3fc 7
ruesipat 1:d9e840c48b1e 8 using namespace std;
ruesipat 1:d9e840c48b1e 9
ruesipat 7:5ef09519a6e9 10 const float Drive::FRONTDISTANCE = 70.0f; //Abstand Sensor zur VorderWand //DONT TOUCH //62.0f //55.0 110.0
ruesipat 7:5ef09519a6e9 11 const float Drive::DRIVINGSPEED = 130.0f;//Fahrgeschwindigkeit Drehzahl in [rpm] //130.0f
ruesipat 9:ab19796bf14a 12 const int Drive::DRIVINGCOUNTS = 1390; //Entspricht Strecke von 20cm //DONT TOUCH /1773 //1800 //1350 /////1390
ruesipat 1:d9e840c48b1e 13
ruesipat 9:ab19796bf14a 14 Drive::Drive(KontrastSensor& kontrastSensor, EncoderCounter& counterLeft, EncoderCounter& counterRight, Controller& controller, IRSensor& irSensor0, IRSensor& irSensor1, IRSensor& irSensor2, IRSensor& irSensor3, int& dontStop, int& modeStart, int& path, int& pathNext):
ruesipat 1:d9e840c48b1e 15 kontrastSensor(kontrastSensor),
ruesipat 5:b8b1a979b0d5 16 counterLeft(counterLeft),
ruesipat 1:d9e840c48b1e 17 counterRight(counterRight),
ruesipat 4:e3f388933954 18 controller(controller),
ruesipat 4:e3f388933954 19 irSensor0(irSensor0),
ruesipat 4:e3f388933954 20 irSensor1(irSensor1),
ruesipat 4:e3f388933954 21 irSensor2(irSensor2),
ruesipat 7:5ef09519a6e9 22 irSensor3(irSensor3),
ruesipat 9:ab19796bf14a 23 dontStop(dontStop),
ruesipat 9:ab19796bf14a 24 modeStart(modeStart),
ruesipat 9:ab19796bf14a 25 path(path),
ruesipat 9:ab19796bf14a 26 pathNext(pathNext)
ruesipat 5:b8b1a979b0d5 27
ruesipat 1:d9e840c48b1e 28 {
ruesipat 4:e3f388933954 29
ruesipat 1:d9e840c48b1e 30 }
ruesipat 1:d9e840c48b1e 31
ruesipat 1:d9e840c48b1e 32 Drive::~Drive() {}
ruesipat 1:d9e840c48b1e 33
ruesipat 1:d9e840c48b1e 34
ruesipat 1:d9e840c48b1e 35 void Drive::driving()
ruesipat 1:d9e840c48b1e 36 {
ruesipat 1:d9e840c48b1e 37
ruesipat 5:b8b1a979b0d5 38 controller.reset();
ruesipat 7:5ef09519a6e9 39
ruesipat 5:b8b1a979b0d5 40 int countsRight = counterRight.read(); //EncoderCounts auslesen
ruesipat 9:ab19796bf14a 41 int countsLeft = counterLeft.read();
ruesipat 5:b8b1a979b0d5 42 int countsRight0 = countsRight; //ReferenzCounts setzten
ruesipat 5:b8b1a979b0d5 43 int countsLeft0 = countsLeft;
ruesipat 5:b8b1a979b0d5 44
ruesipat 7:5ef09519a6e9 45 float parallelDif = 0.0f;
ruesipat 7:5ef09519a6e9 46 float rightLeftDif = 0.0f;
ruesipat 7:5ef09519a6e9 47 float leftDif = 0.0f;
ruesipat 7:5ef09519a6e9 48 float rightDif = 0.0f;
ruesipat 5:b8b1a979b0d5 49
ruesipat 7:5ef09519a6e9 50 float speedCorrection = 0.0f;
ruesipat 7:5ef09519a6e9 51 int countCorrection = 0;
ruesipat 9:ab19796bf14a 52
ruesipat 7:5ef09519a6e9 53 float softStart = DRIVINGSPEED;
ruesipat 7:5ef09519a6e9 54 float slowdown = 0.0f;
ruesipat 7:5ef09519a6e9 55
ruesipat 9:ab19796bf14a 56 if(dontStop == 2) { //geradeaus
ruesipat 7:5ef09519a6e9 57 softStart =0.0f;
ruesipat 7:5ef09519a6e9 58 }
ruesipat 5:b8b1a979b0d5 59
ruesipat 5:b8b1a979b0d5 60 int drive;
ruesipat 5:b8b1a979b0d5 61
ruesipat 5:b8b1a979b0d5 62
ruesipat 5:b8b1a979b0d5 63 //Abfangen wenn Wand vorne dass sicher nicht vorwärts gefahren wird
ruesipat 5:b8b1a979b0d5 64
ruesipat 5:b8b1a979b0d5 65 if(irSensor1.read() < FRONTDISTANCE) {
ruesipat 5:b8b1a979b0d5 66 drive = 0;
ruesipat 5:b8b1a979b0d5 67 } else {
ruesipat 5:b8b1a979b0d5 68 drive = 1;
ruesipat 5:b8b1a979b0d5 69 }
ruesipat 5:b8b1a979b0d5 70
ruesipat 7:5ef09519a6e9 71 while(((countsRight <= countsRight0 + DRIVINGCOUNTS + countCorrection) || (countsLeft >= countsLeft0 - DRIVINGCOUNTS - countCorrection)) && (drive == 1) ) {
ruesipat 5:b8b1a979b0d5 72
ruesipat 6:a09d2ee3b82e 73 kontrastSensor.check();
ruesipat 1:d9e840c48b1e 74 countsRight = counterRight.read();
ruesipat 1:d9e840c48b1e 75 countsLeft = counterLeft.read();
ruesipat 7:5ef09519a6e9 76 controller.setDesiredSpeedRight(-softStart + DRIVINGSPEED - speedCorrection - slowdown); //Korrektur passt Geschwindigkeit an beiden Raedern an //slowdown
ruesipat 7:5ef09519a6e9 77 controller.setDesiredSpeedLeft(softStart - DRIVINGSPEED - speedCorrection + slowdown); //slowdown
ruesipat 5:b8b1a979b0d5 78
ruesipat 5:b8b1a979b0d5 79
ruesipat 7:5ef09519a6e9 80 //Ermittlung der Differenz Hinten-Vorne (PARALLEL)
ruesipat 9:ab19796bf14a 81
ruesipat 7:5ef09519a6e9 82 if((irSensor3.read() < 120.0f) && (irSensor2.read() < 120.0f)) { //irSensor3 => sensorLeftBack , irSensor2 => sensorLeftFront
ruesipat 7:5ef09519a6e9 83
ruesipat 5:b8b1a979b0d5 84 parallelDif = irSensor3.read()-irSensor2.read(); //differenz hinten vorne bestimmen
ruesipat 7:5ef09519a6e9 85
ruesipat 5:b8b1a979b0d5 86 } else { //ist wand eine wand nicht vorhanden => keine korrektur
ruesipat 7:5ef09519a6e9 87
ruesipat 5:b8b1a979b0d5 88 parallelDif = 0;
ruesipat 5:b8b1a979b0d5 89 }
ruesipat 5:b8b1a979b0d5 90
ruesipat 5:b8b1a979b0d5 91
ruesipat 7:5ef09519a6e9 92 //Ermittlung der Differenz Rechts-Links (LINKS UND RECHTS WAND VORHANDEN)
ruesipat 9:ab19796bf14a 93
ruesipat 7:5ef09519a6e9 94 if((irSensor0.read() < 120.0f) && (irSensor2.read() < 120.0f)) { //irSensor0 => sensorRight irSensor2 => sensorLeftFornt
ruesipat 7:5ef09519a6e9 95
ruesipat 5:b8b1a979b0d5 96 rightLeftDif = irSensor0.read()-irSensor2.read(); //differenz links rechts bestimmen
ruesipat 5:b8b1a979b0d5 97
ruesipat 5:b8b1a979b0d5 98 } else { //ist wand eine wand nicht vorhanden => keine korrektur
ruesipat 5:b8b1a979b0d5 99
ruesipat 5:b8b1a979b0d5 100 rightLeftDif = 0;
ruesipat 5:b8b1a979b0d5 101
ruesipat 7:5ef09519a6e9 102 //Ermittlung der Differenz links auf ReferenzWert
ruesipat 7:5ef09519a6e9 103 if(irSensor2.read() < 120.0f) { //irSensor2 => sensorLeftFornt
ruesipat 7:5ef09519a6e9 104
ruesipat 7:5ef09519a6e9 105 leftDif = 60.0f - irSensor2.read(); //differenz links rechts bestimmen
ruesipat 7:5ef09519a6e9 106
ruesipat 7:5ef09519a6e9 107 } else { //ist wand eine wand nicht vorhanden => keine korrektur
ruesipat 7:5ef09519a6e9 108
ruesipat 7:5ef09519a6e9 109 leftDif = 0;
ruesipat 7:5ef09519a6e9 110 }
ruesipat 7:5ef09519a6e9 111
ruesipat 7:5ef09519a6e9 112
ruesipat 7:5ef09519a6e9 113 //Ermittlung der Differenz rechts auf Referenzwert
ruesipat 9:ab19796bf14a 114
ruesipat 7:5ef09519a6e9 115 if(irSensor0.read() < 120.0f) { //irSensor0 => sensorRight
ruesipat 7:5ef09519a6e9 116
ruesipat 7:5ef09519a6e9 117 rightDif = irSensor0.read() - 60.0f; //differenz links rechts bestimmen
ruesipat 7:5ef09519a6e9 118
ruesipat 7:5ef09519a6e9 119 } else { //ist wand eine wand nicht vorhanden => keine korrektur
ruesipat 7:5ef09519a6e9 120
ruesipat 7:5ef09519a6e9 121 rightDif = 0;
ruesipat 7:5ef09519a6e9 122 }
ruesipat 5:b8b1a979b0d5 123 }
ruesipat 5:b8b1a979b0d5 124
ruesipat 5:b8b1a979b0d5 125
ruesipat 9:ab19796bf14a 126 //Berechung Korrektur
ruesipat 5:b8b1a979b0d5 127
ruesipat 9:ab19796bf14a 128 speedCorrection = ((0.3f * rightLeftDif) + (0.6f * parallelDif) + (0.6f * leftDif) + (0.6f * rightDif)); //DONT TOUCH 0.35 0.7 0.7 0.7
ruesipat 7:5ef09519a6e9 129
ruesipat 7:5ef09519a6e9 130
ruesipat 7:5ef09519a6e9 131 //Anfahrrampe damit die Raeder nicht durchdrehen
ruesipat 9:ab19796bf14a 132
ruesipat 7:5ef09519a6e9 133 softStart = softStart - 3.5f;
ruesipat 7:5ef09519a6e9 134 if (softStart <= 0.0f) {
ruesipat 7:5ef09519a6e9 135 softStart = 0.0f;
ruesipat 7:5ef09519a6e9 136 }
ruesipat 5:b8b1a979b0d5 137
ruesipat 5:b8b1a979b0d5 138
ruesipat 7:5ef09519a6e9 139 //Kontrolle ob vorne Wand...wenn vorhanden nach vorderer Wand ausrichten und anhalten ansonst nur nach counts anhalten
ruesipat 9:ab19796bf14a 140
ruesipat 5:b8b1a979b0d5 141 if(irSensor1.read() < 150.0f) { //slow down
ruesipat 5:b8b1a979b0d5 142
ruesipat 7:5ef09519a6e9 143 countCorrection = 5000;
ruesipat 7:5ef09519a6e9 144 slowdown = slowdown + 5.0f;
ruesipat 7:5ef09519a6e9 145 if (slowdown >= DRIVINGSPEED - 20.0f) {
ruesipat 9:ab19796bf14a 146
ruesipat 7:5ef09519a6e9 147 slowdown = DRIVINGSPEED - 20.0f;
ruesipat 7:5ef09519a6e9 148 }
ruesipat 7:5ef09519a6e9 149 if (irSensor1.read() < FRONTDISTANCE) {
ruesipat 5:b8b1a979b0d5 150
ruesipat 5:b8b1a979b0d5 151 drive = 0;
ruesipat 9:ab19796bf14a 152 }
ruesipat 5:b8b1a979b0d5 153
ruesipat 9:ab19796bf14a 154 } else if((((DRIVINGCOUNTS - countsRight) < 220) || ((countsLeft + DRIVINGCOUNTS) < 220)) && ((irSensor2.read() > 120.0f) && ((modeStart != 1) || (pathNext == 2)))) { //Anhaltrampe wenn nach counts gefahren
ruesipat 7:5ef09519a6e9 155 slowdown = slowdown + 5.0f;
ruesipat 7:5ef09519a6e9 156 if (slowdown >= DRIVINGSPEED - 20.0f) {
ruesipat 9:ab19796bf14a 157
ruesipat 7:5ef09519a6e9 158 slowdown = DRIVINGSPEED - 20.0f;
ruesipat 9:ab19796bf14a 159 }
ruesipat 9:ab19796bf14a 160 } else if((((DRIVINGCOUNTS - countsRight) < 220) || ((countsLeft + DRIVINGCOUNTS) < 220)) && ((irSensor0.read() > 120.0f) && ((modeStart == 1) && (pathNext == 3)))) { //Anhaltrampe wenn nach counts gefahren
ruesipat 9:ab19796bf14a 161 slowdown = slowdown + 5.0f;
ruesipat 9:ab19796bf14a 162 if (slowdown >= DRIVINGSPEED - 20.0f) {
ruesipat 9:ab19796bf14a 163
ruesipat 9:ab19796bf14a 164 slowdown = DRIVINGSPEED - 20.0f;
ruesipat 9:ab19796bf14a 165 }
ruesipat 9:ab19796bf14a 166 } else {
ruesipat 9:ab19796bf14a 167
ruesipat 9:ab19796bf14a 168 slowdown = 0.0f;
ruesipat 7:5ef09519a6e9 169 }
ruesipat 5:b8b1a979b0d5 170
ruesipat 9:ab19796bf14a 171 wait(0.01f);
ruesipat 9:ab19796bf14a 172 }//Ende Whileschleife Drive...
ruesipat 9:ab19796bf14a 173 }