Basic funcitonality

Dependencies:   mbed mbed-rtos SevenSegmentSerial HC_SR04_Ultrasonic_Library

Committer:
glanier9
Date:
Wed Apr 28 16:05:30 2021 +0000
Revision:
7:04c8f6b7a42a
Parent:
6:c8f14de0e3f4
Child:
8:88cf71c84e04
Child:
9:1d973bd9786c
Minor edits. fixed a float issue. 7 SEGMENT DISPLAY NEEDS TO BE ADDED BACK IN.;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
dtran76 5:99be83f824b8 1 //******************************************************
dtran76 5:99be83f824b8 2 // Mbed to Raspberry Pi ** Raspberry Pi to Mbed *
dtran76 5:99be83f824b8 3 //******************************************************
dtran76 5:99be83f824b8 4 // 0 - pass starting line ** S - start race *
dtran76 5:99be83f824b8 5 // 1 - pass checkpoint 1 ** R - reset *
dtran76 5:99be83f824b8 6 // 2 - pass checkpoint 2 ** *
dtran76 5:99be83f824b8 7 // ... ** *
dtran76 5:99be83f824b8 8 // 9 - end race ** *
dtran76 5:99be83f824b8 9 //******************************************************
dtran76 0:0747159bf07d 10
dtran76 0:0747159bf07d 11 #include "mbed.h"
dtran76 0:0747159bf07d 12 #include "ultrasonic.h"
glanier9 1:28e137ae5af7 13 #include "rtos.h"
dtran76 0:0747159bf07d 14
glanier9 1:28e137ae5af7 15 Thread thread1;
glanier9 3:293a771fc470 16 Thread thread2;
dtran76 0:0747159bf07d 17 Serial pc(USBTX,USBRX);
dtran76 0:0747159bf07d 18 DigitalOut led0(p5);
dtran76 0:0747159bf07d 19 DigitalOut led1(p6);
dtran76 0:0747159bf07d 20 DigitalOut led2(p7);
glanier9 1:28e137ae5af7 21 PwmOut speaker(p25);
glanier9 3:293a771fc470 22 DigitalOut rgbRed(p23);
glanier9 3:293a771fc470 23 DigitalOut rgbGreen(p24);
glanier9 3:293a771fc470 24 DigitalOut rgbCtrl1(p8);
glanier9 3:293a771fc470 25 DigitalOut rgbCtrl2(p9);
glanier9 3:293a771fc470 26 DigitalOut rgbCtrl3(p10);
dtran76 0:0747159bf07d 27
dtran76 5:99be83f824b8 28 #define B4NOTE 500 //Hz
dtran76 5:99be83f824b8 29 #define E5NOTE 659 //Hz
dtran76 5:99be83f824b8 30
dtran76 5:99be83f824b8 31 int width[3]; //width of each checkpoint, mm
dtran76 5:99be83f824b8 32 int threshold[3]; //how much distance has to change, mm
glanier9 7:04c8f6b7a42a 33 float sensitivity[3] = {0.1,0.1,0.1};
dtran76 0:0747159bf07d 34 int total_laps = 3;
dtran76 0:0747159bf07d 35 int current_lap = 0;
glanier9 1:28e137ae5af7 36 int i = 500;
dtran76 5:99be83f824b8 37
glanier9 3:293a771fc470 38 bool early_start = 0;
glanier9 3:293a771fc470 39 bool start_done = 0;
dtran76 0:0747159bf07d 40
dtran76 0:0747159bf07d 41 int setup[3] = {1,1,1};
dtran76 0:0747159bf07d 42
dtran76 0:0747159bf07d 43 //state machine, tracks current position in track
dtran76 0:0747159bf07d 44 enum state_type {start,past_start,past_cp1,past_cp2};
dtran76 0:0747159bf07d 45 state_type track_state = start;
dtran76 0:0747159bf07d 46
dtran76 5:99be83f824b8 47 //Mbed reset
dtran76 5:99be83f824b8 48 extern "C" void mbed_reset();
dtran76 5:99be83f824b8 49
dtran76 5:99be83f824b8 50 //Starting countdown
glanier9 3:293a771fc470 51 void start_race()
glanier9 3:293a771fc470 52 {
glanier9 3:293a771fc470 53 // 3
glanier9 3:293a771fc470 54 rgbRed = 1;
dtran76 5:99be83f824b8 55 speaker.period(1.0/B4NOTE);
glanier9 3:293a771fc470 56 speaker =0.5;
glanier9 3:293a771fc470 57 rgbCtrl1 = 1;
glanier9 3:293a771fc470 58 Thread::wait(500);
glanier9 3:293a771fc470 59 speaker = 0;
glanier9 3:293a771fc470 60 Thread::wait(500);
glanier9 3:293a771fc470 61 // 2
glanier9 3:293a771fc470 62 speaker =0.5;
glanier9 3:293a771fc470 63 rgbCtrl2 = 1;
glanier9 3:293a771fc470 64 Thread::wait(500);
glanier9 3:293a771fc470 65 speaker = 0;
glanier9 3:293a771fc470 66 Thread::wait(500);
glanier9 3:293a771fc470 67 // 1
glanier9 3:293a771fc470 68 speaker =0.5;
glanier9 3:293a771fc470 69 rgbCtrl3 = 1;
glanier9 3:293a771fc470 70 Thread::wait(500);
glanier9 3:293a771fc470 71 speaker = 0;
glanier9 3:293a771fc470 72 Thread::wait(500);
glanier9 3:293a771fc470 73 // GO!
glanier9 3:293a771fc470 74 rgbRed = 0;
glanier9 3:293a771fc470 75 rgbGreen = 1;
glanier9 3:293a771fc470 76 start_done = 1;
dtran76 5:99be83f824b8 77 speaker.period(1.0/E5NOTE);
glanier9 3:293a771fc470 78 speaker =0.5;
glanier9 7:04c8f6b7a42a 79 Thread::wait(1500);
glanier9 3:293a771fc470 80 speaker = 0;
glanier9 3:293a771fc470 81 rgbCtrl1 = 0;
glanier9 3:293a771fc470 82 rgbCtrl2 = 0;
glanier9 3:293a771fc470 83 rgbCtrl3 = 0;
glanier9 3:293a771fc470 84 }
glanier9 3:293a771fc470 85
glanier9 2:8c29e1aaaff0 86 // Plays bleep for crossing finish line
glanier9 1:28e137ae5af7 87 void play_audio()
glanier9 1:28e137ae5af7 88 {
dtran76 5:99be83f824b8 89 speaker.period(1.0/B4NOTE); // 500hz period
glanier9 1:28e137ae5af7 90 speaker =0.5; //50% duty cycle - max volume
glanier9 2:8c29e1aaaff0 91 Thread::wait(150);
glanier9 1:28e137ae5af7 92 speaker=0.0; // turn off audio
glanier9 1:28e137ae5af7 93 }
glanier9 1:28e137ae5af7 94
dtran76 0:0747159bf07d 95 //executed when crossing starting line
dtran76 0:0747159bf07d 96 void start_line(int distance)
dtran76 0:0747159bf07d 97 {
dtran76 0:0747159bf07d 98 if (setup[0]) {
dtran76 0:0747159bf07d 99 width[0] = distance;
dtran76 5:99be83f824b8 100 threshold[0] = distance*sensitivity[0];
glanier9 1:28e137ae5af7 101 setup[0] = !setup[0];
dtran76 6:c8f14de0e3f4 102 //pc.printf("Setup: Starting Line\n");
dtran76 6:c8f14de0e3f4 103 //pc.printf("Distance: %3d\n\n",distance);
dtran76 0:0747159bf07d 104 }
glanier9 1:28e137ae5af7 105
dtran76 5:99be83f824b8 106 if (width[0] - distance >= threshold[0]) {
dtran76 6:c8f14de0e3f4 107 //pc.printf("Past starting line\n");
dtran76 0:0747159bf07d 108 led0 = 1;
dtran76 0:0747159bf07d 109 led1 = 0;
dtran76 0:0747159bf07d 110 led2 = 0;
dtran76 0:0747159bf07d 111 current_lap++;
glanier9 7:04c8f6b7a42a 112 //pc.printf("%d\n",current_lap);
dtran76 0:0747159bf07d 113 track_state = past_start;
glanier9 7:04c8f6b7a42a 114 switch (current_lap) {
glanier9 7:04c8f6b7a42a 115 case 1 :
glanier9 7:04c8f6b7a42a 116 pc.putc('0');
glanier9 7:04c8f6b7a42a 117 break;
glanier9 7:04c8f6b7a42a 118 case 2 :
glanier9 7:04c8f6b7a42a 119 pc.putc('3');
glanier9 7:04c8f6b7a42a 120 break;
glanier9 7:04c8f6b7a42a 121 case 3 :
glanier9 7:04c8f6b7a42a 122 pc.putc('6');
glanier9 7:04c8f6b7a42a 123 break;
glanier9 7:04c8f6b7a42a 124 }
glanier9 1:28e137ae5af7 125 thread1.start(&play_audio);
dtran76 0:0747159bf07d 126 }
dtran76 0:0747159bf07d 127 }
dtran76 0:0747159bf07d 128
dtran76 0:0747159bf07d 129 //executed when passing checkpoint 1
dtran76 0:0747159bf07d 130 void checkpoint1(int distance)
dtran76 0:0747159bf07d 131 {
dtran76 0:0747159bf07d 132 if (setup[1]) {
dtran76 0:0747159bf07d 133 width[1] = distance;
dtran76 5:99be83f824b8 134 threshold[1] = distance*sensitivity[1];
glanier9 1:28e137ae5af7 135 setup[1] = !setup[1];
dtran76 6:c8f14de0e3f4 136 //pc.printf("Setup: Starting Line\n");
dtran76 6:c8f14de0e3f4 137 //pc.printf("Distance: %3d\n\n",distance);
dtran76 0:0747159bf07d 138 }
glanier9 1:28e137ae5af7 139
dtran76 5:99be83f824b8 140 if (width[1] - distance >= threshold[1]) {
dtran76 6:c8f14de0e3f4 141 //pc.printf("Past Checkpoint 1\n");
dtran76 0:0747159bf07d 142 led1 = 1;
dtran76 0:0747159bf07d 143 track_state = past_cp1;
glanier9 7:04c8f6b7a42a 144 switch (current_lap) {
glanier9 7:04c8f6b7a42a 145 case 1 :
glanier9 7:04c8f6b7a42a 146 pc.putc('1');
glanier9 7:04c8f6b7a42a 147 break;
glanier9 7:04c8f6b7a42a 148 case 2 :
glanier9 7:04c8f6b7a42a 149 pc.putc('4');
glanier9 7:04c8f6b7a42a 150 break;
glanier9 7:04c8f6b7a42a 151 case 3 :
glanier9 7:04c8f6b7a42a 152 pc.putc('7');
glanier9 7:04c8f6b7a42a 153 break;
glanier9 7:04c8f6b7a42a 154 }
dtran76 6:c8f14de0e3f4 155 thread1.start(&play_audio);
dtran76 0:0747159bf07d 156 }
dtran76 0:0747159bf07d 157 }
dtran76 0:0747159bf07d 158
dtran76 0:0747159bf07d 159 //executed when passing checkpoint 2
dtran76 0:0747159bf07d 160 void checkpoint2(int distance)
dtran76 0:0747159bf07d 161 {
dtran76 0:0747159bf07d 162 if (setup[2]) {
dtran76 0:0747159bf07d 163 width[2] = distance;
dtran76 5:99be83f824b8 164 threshold[2] = distance*sensitivity[2];
dtran76 5:99be83f824b8 165 setup[2] = !setup[1];
dtran76 6:c8f14de0e3f4 166 //pc.printf("Setup: Starting Line\n");
dtran76 6:c8f14de0e3f4 167 //pc.printf("Distance: %3d\n\n",distance);
dtran76 0:0747159bf07d 168 }
glanier9 1:28e137ae5af7 169
dtran76 5:99be83f824b8 170 if (width[2] - distance >= threshold[2]) {
dtran76 6:c8f14de0e3f4 171 //pc.printf("Past Checkpoint 2\n");
dtran76 0:0747159bf07d 172 led2 = 1;
dtran76 0:0747159bf07d 173 track_state = past_cp2;
glanier9 7:04c8f6b7a42a 174 switch (current_lap) {
glanier9 7:04c8f6b7a42a 175 case 1 :
glanier9 7:04c8f6b7a42a 176 pc.putc('2');
glanier9 7:04c8f6b7a42a 177 break;
glanier9 7:04c8f6b7a42a 178 case 2 :
glanier9 7:04c8f6b7a42a 179 pc.putc('5');
glanier9 7:04c8f6b7a42a 180 break;
glanier9 7:04c8f6b7a42a 181 case 3 :
glanier9 7:04c8f6b7a42a 182 pc.putc('8');
glanier9 7:04c8f6b7a42a 183 break;
glanier9 7:04c8f6b7a42a 184 }
dtran76 6:c8f14de0e3f4 185 thread1.start(&play_audio);
dtran76 0:0747159bf07d 186 }
dtran76 0:0747159bf07d 187 }
dtran76 0:0747159bf07d 188
dtran76 0:0747159bf07d 189 ultrasonic sonar0(p15,p16,0.1,0.1,&start_line); //starting line
dtran76 0:0747159bf07d 190 ultrasonic sonar1(p17,p18,0.1,0.1,&checkpoint1); //checkpoint 1
dtran76 0:0747159bf07d 191 ultrasonic sonar2(p21,p22,0.1,0.1,&checkpoint2); //checkpoint 2
dtran76 0:0747159bf07d 192
glanier9 1:28e137ae5af7 193 int main()
dtran76 0:0747159bf07d 194 {
dtran76 5:99be83f824b8 195 //sonar initialization
dtran76 0:0747159bf07d 196 sonar0.startUpdates();
dtran76 0:0747159bf07d 197 sonar1.startUpdates();
dtran76 0:0747159bf07d 198 sonar2.startUpdates();
glanier9 1:28e137ae5af7 199
dtran76 5:99be83f824b8 200 //sonar calibration
dtran76 0:0747159bf07d 201 sonar0.checkDistance();
dtran76 0:0747159bf07d 202 sonar1.checkDistance();
dtran76 0:0747159bf07d 203 sonar2.checkDistance();
dtran76 0:0747159bf07d 204
dtran76 5:99be83f824b8 205 //wait for start char from Pi
dtran76 5:99be83f824b8 206 while (1) {
dtran76 5:99be83f824b8 207 if (pc.getc() == 'S') {
dtran76 5:99be83f824b8 208 break;
dtran76 5:99be83f824b8 209 }
dtran76 5:99be83f824b8 210 Thread::wait(50);
dtran76 5:99be83f824b8 211 }
dtran76 5:99be83f824b8 212
glanier9 7:04c8f6b7a42a 213 //starting countdown sequence
glanier9 3:293a771fc470 214 thread2.start(&start_race);
glanier9 3:293a771fc470 215
dtran76 5:99be83f824b8 216 //false start detect
glanier9 3:293a771fc470 217 while(!start_done) {
glanier9 3:293a771fc470 218 if (current_lap) {
dtran76 5:99be83f824b8 219 rgbCtrl1 = rgbCtrl2 = rgbCtrl3 = 0;
dtran76 6:c8f14de0e3f4 220 led0 = led1 = led2 = 0;
dtran76 5:99be83f824b8 221 rgbRed = 1;
dtran76 5:99be83f824b8 222 rgbGreen = 0;
dtran76 6:c8f14de0e3f4 223 bool other = true;
dtran76 6:c8f14de0e3f4 224 speaker.period(1/E5NOTE);
dtran76 5:99be83f824b8 225 while (1) {
dtran76 5:99be83f824b8 226 rgbCtrl1 = !rgbCtrl1;
dtran76 5:99be83f824b8 227 rgbCtrl2 = !rgbCtrl2;
dtran76 5:99be83f824b8 228 rgbCtrl3 = !rgbCtrl3;
dtran76 6:c8f14de0e3f4 229 led0 = !led0;
dtran76 6:c8f14de0e3f4 230 led1 = !led1;
dtran76 6:c8f14de0e3f4 231 led2 = !led2;
dtran76 6:c8f14de0e3f4 232 speaker = other ? 0.5 : 0.0;
dtran76 6:c8f14de0e3f4 233 other = !other;
dtran76 5:99be83f824b8 234 if (pc.getc() == 'R') {
dtran76 5:99be83f824b8 235 mbed_reset();
dtran76 5:99be83f824b8 236 }
dtran76 5:99be83f824b8 237 Thread::wait(50);
dtran76 5:99be83f824b8 238 }
glanier9 3:293a771fc470 239 }
glanier9 3:293a771fc470 240 Thread::wait(50);
glanier9 3:293a771fc470 241 }
glanier9 3:293a771fc470 242
glanier9 1:28e137ae5af7 243 while(1) {
dtran76 0:0747159bf07d 244 switch (track_state) {
dtran76 0:0747159bf07d 245 case start:
dtran76 0:0747159bf07d 246 sonar0.checkDistance();
dtran76 0:0747159bf07d 247 break;
dtran76 0:0747159bf07d 248 case past_start:
dtran76 0:0747159bf07d 249 sonar1.checkDistance();
dtran76 0:0747159bf07d 250 break;
dtran76 0:0747159bf07d 251 case past_cp1:
dtran76 0:0747159bf07d 252 sonar2.checkDistance();
dtran76 0:0747159bf07d 253 break;
dtran76 0:0747159bf07d 254 case past_cp2:
dtran76 0:0747159bf07d 255 sonar0.checkDistance();
dtran76 0:0747159bf07d 256 break;
dtran76 0:0747159bf07d 257 }
dtran76 0:0747159bf07d 258 if (current_lap > total_laps) {
dtran76 0:0747159bf07d 259 pc.putc('9');
dtran76 6:c8f14de0e3f4 260 //pc.printf("Race Over");
dtran76 0:0747159bf07d 261 while(1) {
dtran76 5:99be83f824b8 262 if (pc.getc() == 'R') {
dtran76 5:99be83f824b8 263 mbed_reset();
dtran76 5:99be83f824b8 264 }
glanier9 3:293a771fc470 265 Thread::wait(50);
dtran76 0:0747159bf07d 266 }
dtran76 0:0747159bf07d 267 }
glanier9 3:293a771fc470 268 Thread::wait(50);
dtran76 0:0747159bf07d 269 }
dtran76 0:0747159bf07d 270 }