Self-navigating IOT robot for ECE 4180. Before navigation code begins, wi-fi http server setup takes time (approx. 2 min, see serial output in terminal window)
Dependencies: HC_SR04_Ultrasonic_Library Motor mbed-rtos mbed
Revision 0:66c1c628e189, committed 2016-12-09
- Comitter:
- ashatune
- Date:
- Fri Dec 09 14:32:59 2016 +0000
- Commit message:
- IOT self navigating robot code for GaTech ECE 4180 final project.
Changed in this revision
diff -r 000000000000 -r 66c1c628e189 HC_SR04_Ultrasonic_Library.lib --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/HC_SR04_Ultrasonic_Library.lib Fri Dec 09 14:32:59 2016 +0000 @@ -0,0 +1,1 @@ +http://developer.mbed.org/users/ejteb/code/HC_SR04_Ultrasonic_Library/#e0f9c9fb4cf3
diff -r 000000000000 -r 66c1c628e189 Motor.lib --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Motor.lib Fri Dec 09 14:32:59 2016 +0000 @@ -0,0 +1,1 @@ +http://mbed.org/users/simon/code/Motor/#f265e441bcd9
diff -r 000000000000 -r 66c1c628e189 main.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cpp Fri Dec 09 14:32:59 2016 +0000 @@ -0,0 +1,374 @@ +#include "mbed.h" +#include "Motor.h" +#include "rtos.h" +#include "ultrasonic.h" + +//Account for time (approx. 2min, see serial output in terminal) for wi-fi server to set up before navigation code begins!! + +Motor ma(p25, p14, p13); +Motor mb(p24, p11, p12); // pwm, fwd, rev +DigitalOut myled(LED1); +DigitalOut led4(LED4); +DigitalOut led3(LED3); + +//speaker/sd set up +/*AnalogOut DACout(p18); //currently in pwm 26 +wave_player waver(&DACout); +SDFileSystem sd(p5, p6, p7, p8, "sd");*/ + +Serial pc(USBTX, USBRX); +Serial esp(p28, p27); // tx, rx +DigitalOut reset(p26); +Timer t; + +int count,ended,timeout; +char buf[2024]; +char snd[1024]; + +char ssid[32] = "iPhone"; // enter WiFi router ssid inside the quotes +char pwd [32] = "Jordan23#"; // enter WiFi router password inside the quotes + +void SendCMD(),getreply(),ESPconfig(),ESPsetbaudrate(); + void dev_recv() +{ + myled = myled; + while(esp.readable()) { + pc.putc(esp.getc()); + } +} + +void pc_recv() +{ + led4 = !led4; + while(pc.readable()) { + esp.putc(pc.getc()); + } +} + + +DigitalIn Enc1(p21); //right motor... +DigitalIn Enc2(p22); //left motor +int oldEnc1 = 0; +int oldEnc2 = 0; + +int ticksR = 0; //# times right wheel encoder changed state +int ticksL = 0; //" " + +void dist1(int distance) +{ + //put code here to execute when the distance has changed + printf("Distance1 %d mm\r\n", distance); +} +void dist2(int distance2) +{ + //put code here to execute when the distance has changed + printf("Distance2 %d mm\r\n", distance2); +} + +//Sonar1 variables +ultrasonic mu1(p15, p16, .1, 1, &dist1); + +//Sonar2 variables +ultrasonic mu2(p22, p21, .1, 1, &dist2); + +void wheelEnc(void const *argument){ + while(1){ + if(Enc1 != oldEnc1) { // Increment ticks every time the state has switched. + ticksR++; + oldEnc1 = Enc1; + + } + if(Enc2 != oldEnc2) { + ticksL++; + oldEnc2 = Enc2; + } + pc.printf("Left ticks: %d \n", ticksL); + pc.printf("Right ticks: %d \n", ticksR); + } + } + +void sonarThread(void const *argument){ + while(1){ + mu1.checkDistance(); //front sonar + mu2.checkDistance(); //right side sonar + int muDist1 = mu1.getCurrentDistance(); + int muDist2 = mu2.getCurrentDistance(); + + //always move straight forward + ma.speed(-.8); //Left motor + mb.speed(-.8); //Right motor + myled =0; + + //Front sensor is not detecting a wall, but right side is too close + if ((muDist1 > 250) && (muDist2 < 170)){ + ma.speed(-.2); + mb.speed(-.9); + } + //Front sensor is not detecting a wall, but right side is too far + else if ((muDist1 > 250) && (muDist2 > 250)){ + ma.speed(-.6); //turn + mb.speed(-0.4); + } + else if (muDist1 < 280){ + ma.speed(1); // + mb.speed(-1); + wait(0.3); + } + else if ((muDist1 > 250) && (muDist2 > 500)){ + ma.speed(-.8); + mb.speed(-.8); + wait(0.1); + mb.speed(1); + wait(0.1); + } + else { + ma.speed(-.8); + mb.speed(-.8); + wait(.1); + } + } + } +/////////////////////////// +/*void audio_thread(void const *argument) +{ + ultra_mutex.lock(); + FILE *wave_file; + wave_file=fopen("/sd/imperial_marchEdit.wav","r"); + waver.play(wave_file); + fclose(wave_file); + ultra_mutex.unlock(); +}*/ + + +int main() +{ + led3 = 1; + wait(2); + reset=0; //hardware reset for 8266 + pc.baud(9600); // set what you want here depending on your terminal program speed + pc.printf("\f\n\r-------------ESP8266 Hardware Reset-------------\n\r"); + wait(0.5); + reset=1; + timeout=2; + getreply(); + + esp.baud(9600); // change this to the new ESP8266 baudrate if it is changed at any time. + + //ESPsetbaudrate(); //****************** include this routine to set a different ESP8266 baudrate ****************** + + ESPconfig(); //****************** include Config to set the ESP8266 configuration *********************** + + + + pc.attach(&pc_recv, Serial::RxIrq); + esp.attach(&dev_recv, Serial::RxIrq); + //start measuring the distance + mu1.startUpdates(); + mu2.startUpdates(); + + Enc1.mode(PullUp); // requires a pullup resistor so i just used embed's feature. + Enc2.mode(PullUp); + + Thread thread1(wheelEnc); + Thread thread2(sonarThread); + //Thread thread3(audio_thread); + //Thread thread4(wifiThread); + + while(1) { + + Thread::wait(100); + + } +} + + + +///WIFI SERVER GUI SETUP + +// Sets new ESP8266 baurate, change the esp.baud(xxxxx) to match your new setting once this has been executed +void ESPsetbaudrate() +{ + strcpy(snd, "AT+CIOBAUD=115200\r\n"); // change the numeric value to the required baudrate + SendCMD(); +} + +// +++++++++++++++++++++++++++++++++ This is for ESP8266 config only, run this once to set up the ESP8266 +++++++++++++++ +void ESPconfig() +{ + + wait(5); + pc.printf("\f---------- Starting ESP Config ----------\r\n\n"); + strcpy(snd,".\r\n.\r\n"); + SendCMD(); + wait(1); + pc.printf("---------- Reset & get Firmware ----------\r\n"); + strcpy(snd,"node.restart()\r\n"); + SendCMD(); + timeout=5; + getreply(); + pc.printf(buf); + + wait(2); + + pc.printf("\n---------- Get Version ----------\r\n"); + strcpy(snd,"print(node.info())\r\n"); + SendCMD(); + timeout=4; + getreply(); + pc.printf(buf); + + wait(3); + + // set CWMODE to 1=Station,2=AP,3=BOTH, default mode 1 (Station) + pc.printf("\n---------- Setting Mode ----------\r\n"); + strcpy(snd, "wifi.setmode(wifi.STATION)\r\n"); + SendCMD(); + timeout=4; + getreply(); + pc.printf(buf); + + wait(2); + + + + pc.printf("\n---------- Listing Access Points ----------\r\n"); + strcpy(snd, "function listap(t)\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "for k,v in pairs(t) do\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "print(k..\" : \"..v)\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "end\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "end\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "wifi.sta.getap(listap)\r\n"); + SendCMD(); + wait(1); + timeout=15; + getreply(); + pc.printf(buf); + + wait(2); + + pc.printf("\n---------- Connecting to AP ----------\r\n"); + pc.printf("ssid = %s pwd = %s\r\n",ssid,pwd); + strcpy(snd, "wifi.sta.config(\""); + strcat(snd, ssid); + strcat(snd, "\",\""); + strcat(snd, pwd); + strcat(snd, "\")\r\n"); + SendCMD(); + timeout=10; + getreply(); + pc.printf(buf); + + wait(5); + + pc.printf("\n---------- Get IP's ----------\r\n"); + strcpy(snd, "print(wifi.sta.getip())\r\n"); + SendCMD(); + timeout=3; + getreply(); + pc.printf(buf); + + wait(1); + + pc.printf("\n---------- Get Connection Status ----------\r\n"); + strcpy(snd, "print(wifi.sta.status())\r\n"); + SendCMD(); + timeout=5; + getreply(); + pc.printf(buf); + + pc.printf("\n\n\n If you get a valid (non zero) IP, ESP8266 has been set up.\r\n"); + pc.printf(" Run this if you want to reconfig the ESP8266 at any time.\r\n"); + pc.printf(" It saves the SSID and password settings internally\r\n"); + pc.printf(" Asha Harris and Teferi Lab 2 "); + wait(10); + + + pc.printf("\n---------- Setting up http server ----------\r\n"); + strcpy(snd, "srv=net.createServer(net.TCP)\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "srv:listen(80,function(conn)\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "conn:on(\"receive\",function(conn,payload)\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "print(payload)\r\n"); + SendCMD(); + wait(1); + + strcpy(snd, "conn:send(\"<!DOCTYPE html>\")\r\n"); + SendCMD(); + wait(1); + + strcpy(snd, "conn:send(\"<html>\")\r\n"); + SendCMD(); + wait(1); + + strcpy(snd, "conn:send(\"<h1> 4180 IOT Self Nav Robot </h1>\")\r\n"); + SendCMD(); + wait(1); + + sprintf(snd, "conn:send(\"%s'\")\r\n", ticksR); + SendCMD(); + wait(1); + + strcpy(snd, "conn:send(\"<h2> cm.. </h2>\")\r\n"); + SendCMD(); + wait(1); + + strcpy(snd, "conn:send(\"</html>\")\r\n"); + SendCMD(); + wait(1); + + strcpy(snd, "end)\r\n"); + SendCMD(); + wait(1); + + strcpy(snd, "conn:on(\"sent\",function(conn) conn:close() end)\r\n"); + SendCMD(); + wait(1); + strcpy(snd, "end)\r\n"); + SendCMD(); + wait(1); + timeout=17; + getreply(); + pc.printf(buf); + pc.printf("\r\nDONE"); +} + +void SendCMD() +{ + esp.printf("%s", snd); +} + +void getreply() +{ + memset(buf, '\0', sizeof(buf)); + t.start(); + ended=0; + count=0; + while(!ended) { + if(esp.readable()) { + buf[count] = esp.getc(); + count++; + } + if(t.read() > timeout) { + ended = 1; + t.stop(); + t.reset(); + } + } +} + + \ No newline at end of file
diff -r 000000000000 -r 66c1c628e189 mbed-rtos.lib --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed-rtos.lib Fri Dec 09 14:32:59 2016 +0000 @@ -0,0 +1,1 @@ +http://developer.mbed.org/users/mbed_official/code/mbed-rtos/#58563e6cba1e
diff -r 000000000000 -r 66c1c628e189 mbed.bld --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed.bld Fri Dec 09 14:32:59 2016 +0000 @@ -0,0 +1,1 @@ +http://mbed.org/users/mbed_official/code/mbed/builds/d75b3fe1f5cb \ No newline at end of file