Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of IEEE_14_Freescale by
main.cpp
- Committer:
- soonerbot
- Date:
- 2013-11-22
- Revision:
- 7:3b2cf7efe5d1
- Parent:
- 6:62d498ee97cf
- Child:
- 9:aff48e331147
File content as of revision 7:3b2cf7efe5d1:
#include "mbed.h" #include "dbgprint.h" #include "robot.h" BusOut leds(LED_RED,LED_GREEN,LED_BLUE); Serial pc(USBTX, USBRX); robot bot; int main() { DBGPRINT("AA\n\r",1); char tmpchar = 0; leds = 0x2; const int* constbuf; double targetAngle=0.0; while(1) { DBGPRINT("BB\n\r",1); leds = leds^0x7; // toggle the LEDs for each loop tmpchar = pc.getc(); // all of these movement commands are blocking, so they can't be easily stopped short of resetting the microcontroller switch(tmpchar){ case 'e': //drive in a smallish square bot.driveForward(0,3000); bot.driveForward(-90,0); bot.driveForward(-90,3000); bot.driveForward(-180,0); bot.driveForward(-180,3000); bot.driveForward(-270,0); bot.driveForward(-270,3000); bot.driveForward(0,0); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'q': //poll the encoders constbuf = bot.bigenc.getVals(); DBGPRINT("\n\r%d\t%d\t%d\t%d\n\r",constbuf[0],constbuf[1],constbuf[2],constbuf[3]); break; case 'z': //set the current direction to "forward" for the following "go forward/reverse" commands targetAngle = bot.gyro.getZDegrees(); break; case 'w': // turn 90 degrees counter clockwise from the starting rotation bot.driveForward(90,0); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'x': // turn 90 degrees clockwise from the starting rotation bot.driveForward(-90,0); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'a': // turn the opposite direction from the starting one bot.driveForward(180,0); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'd': // turn back to starting rotation bot.driveForward(0,0); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'W': // drive forward a small bit bot.driveForward(targetAngle,1000); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'E': //drive forward five times as much bot.driveForward(targetAngle,5000); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'X': // small reverse bot.driveForward(targetAngle,-1000); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'C': // big reverse bot.driveForward(targetAngle,-5000); DBGPRINT("={%f,\t%f,\t%f}\n\r",bot.x,bot.y,bot.rot*180.0/3.14159); break; case 'p': // poll the gyro DBGPRINT("%d\r\n",bot.gyro.getZ()); break; case 'l': //calibrate the gyro ( caution, only use after resetting and before moving, otherwise will break any calibration) bot.gyro.calibrate(); break; // these are all control system modifications which should be fairly well locked down at this point case 't': bot.pfac*=2; DBGPRINT("pfac = %f\r\n",bot.pfac); break; case 'g': bot.pfac/=2; DBGPRINT("pfac = %f\r\n",bot.pfac); break; case 'y': bot.ifac*=2; DBGPRINT("ifac = %f\r\n",bot.ifac); break; case 'h': bot.ifac/=2; DBGPRINT("ifac = %f\r\n",bot.ifac); break; case 'u': bot.dfac*=2; DBGPRINT("dfac = %f\r\n",bot.dfac); break; case 'j': bot.dfac/=2; DBGPRINT("dfac = %f\r\n",bot.dfac); break; case 'i': bot.angfac*=2; DBGPRINT("angfac = %f\r\n",bot.angfac); break; case 'k': bot.angfac/=2; DBGPRINT("angfac = %f\r\n",bot.angfac); break; case 'T': bot.pfac*=1.05; DBGPRINT("pfac = %f\r\n",bot.pfac); break; case 'G': bot.pfac/=1.05; DBGPRINT("pfac = %f\r\n",bot.pfac); break; case 'Y': bot.ifac*=1.05; DBGPRINT("ifac = %f\r\n",bot.ifac); break; case 'H': bot.ifac/=1.05; DBGPRINT("ifac = %f\r\n",bot.ifac); break; case 'U': bot.dfac*=1.05; DBGPRINT("dfac = %f\r\n",bot.dfac); break; case 'J': bot.dfac/=1.05; DBGPRINT("dfac = %f\r\n",bot.dfac); break; // poll the compass ( currently gives bad values ) case 'Q': DBGPRINT("Compass vector = %d\t%d\t%d\r\n",bot.gyro.xmag,bot.gyro.ymag,bot.gyro.zmag); break; // brake if we get an unknown command default: bot.left.brake(); bot.right.brake(); break; } } }