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 SAILORSbot by
main.cpp
- Committer:
 - zsunberg
 - Date:
 - 2015-08-02
 - Revision:
 - 22:dae192ffca90
 - Parent:
 - 21:18b585a44155
 - Child:
 - 23:55f8b1abbf99
 
File content as of revision 22:dae192ffca90:
#include "robot.h"
/*
 * This function will be called at approximately <SPEED> when the control mode is LINE_FOLLOW_MODE
 */
 
 ///////////////////////////////////////////add line following code
void line_follow_loop(){
    led4 = 1;
    
    //varaibles to
    float prev_position = 0;
    float derivative, proportional, integral = 0;
    int sensors[5];
    float position = 0;
    float power;    //speed increase or decrease
    float speed = MAX;
    //get sensors
    pi.sensor_reading(sensors);
    
    //line position
    position = pi.line_position();
    proportional = position;
    
    //derivative
    derivative = position - prev_position;
    
    //integral
    integral += proportional;
    
    //last position
    prev_position = position;
    
    power = (proportional * k_p) + (integral * k_i) + (derivative * k_d);
    
    //new speeds
    rightspeed = speed - power;
    leftspeed = speed + power;
    
   if(rightspeed < MIN)
        rightspeed = MIN;
    else if(rightspeed > MAX)
        rightspeed = MAX;
    
    if(leftspeed < MIN)
        leftspeed = MIN;
    else if(leftspeed > MAX)
        leftspeed = MAX;
    
    //pi.left_motor(leftspeed);
   // pi.right_motor(rightspeed);
    
    if(sensors[0] < 1200 && sensors[1] < 1200 && sensors[2] < 1200 && sensors[3] < 1200 && sensors[4] < 1200)
    {
        pi.stop();
        //dead end
        mode = MANUAL_MODE;
    }
    else if(sensors[0] > 1800 || sensors[4] > 1800)
    {
        //intersection
        mode = MANUAL_MODE;
    }
    // set mode to MANUAL_MODE when the end is detected
    // mode = MANUAL_MODE
    
    // wait_ms(10);
    led4 = 0;
}
// INPUT COMMANDS
// l:<float>    set left wheel speed (only effective in MANUAL_MODE)
// r:<float>    set right wheel speed (only effective in MANUAL_MODE)
// c:<int>      change mode
// g:<p|i|d>:<float>
//              change gains
// b:           check battery
// OUTPUT MESSAGES
// p:<float>    line position
// s:<int>,<int>,<int>,<int>,<int>
//              light sensor values
// m:<int>      mode
void communicate()
{
    led1 = 1;
    pi.sensor_reading(sensors);
    int* s = sensors; // just to make the next line more compact
    xbee.printf("s:%i,%i,%i,%i,%i\n", s[0], s[1], s[2], s[3], s[4]);
    xbee.printf("p:%f\n", pi.line_position());
    xbee.printf("m:%d\n", mode);
    led1 = 0;
}
int parse_command(const char* cmd)
{
    if(cmd[1]==':'){
        // left motor
        if(cmd[0]=='l'){
            if(mode==MANUAL_MODE){
                leftspeed = atof(&cmd[2]);
            }
        // right motor
        }else if(cmd[0]=='r'){
            if(mode==MANUAL_MODE){
                rightspeed = atof(&cmd[2]);
            }
        // mode
        }else if(cmd[0]=='c'){
            mode = atoi(&cmd[2]);
            communicate(); // make sure we get a confirmation of the mode
            // xbee.printf("mode set to %d\n", mode);
        // gains
        }else if(cmd[0]=='g'){
            if(cmd[2]=='p'){
                k_p = atof(&cmd[4]);
            }else if(cmd[2]=='i'){
                k_i = atof(&cmd[4]);
            }else if(cmd[2]=='d'){
                k_d = atof(&cmd[4]);
            }
            xbee.printf("gains p:%f, i:%f, d:%f\n", k_p, k_i, k_d);
        // battery
        }else if(cmd[0]=='b'){
            xbee.printf("battery voltage: %f\n", pi.battery());
        }else{
            xbee.printf("%s\n",cmd); 
        }
    }else{
        xbee.printf("%s\n",cmd);
    }
    return 0;
}
void Rx_interrupt()
{
    // assume recursive interrupt is not possible
    led2 = 1;
    char read;
    
    while(xbee.readable()){
        read = xbee.getc();
        if(read=='\n'){
            received[r_index]='\0'; // put a null character at the end
            parse_command(received);
            r_index=0;
        } else {
            if(r_index >= 80){
                r_index=0;
            }
            received[r_index]=read;
            r_index++;
        }
    }
    
    led2=0;
    
    return;
}
void control()
{
    if(mode==LINE_FOLLOW_MODE){
        line_follow_loop();
    }
}
int main() {
    
    xbee.attach(&Rx_interrupt, Serial::RxIrq);
    xbeeReset = 0;
    wait(2);
    xbeeReset = 1;
    pi.sensor_auto_calibrate();
    leftspeed = 0.0;
    rightspeed = 0.0;
    
    r_index = 0;
    received[0] = '\0';
    mode = MANUAL_MODE;
    
    communication.attach(&communicate, 0.1);
    controls.attach(&control, 0.02);
    while(1){
        led3 = mode;
        __disable_irq();
        pi.left_motor(rightspeed);
        pi.right_motor(leftspeed);
        __enable_irq();
    }
    return 0;
}
            
    