share

Dependencies:   mbed-rtos mbed

Fork of BX-car_2 by Tony Lin

main.cpp

Committer:
TonyLin
Date:
2014-06-29
Revision:
20:4ed21397e775
Parent:
19:eb0552a0ddae

File content as of revision 20:4ed21397e775:

#include "mbed.h"
#include "controller.h"
#include "servo_api.h"
#include "camera_api.h"
#include "motor_api.h"
#include "pot.h"


#define Debug_cam_uart
#define R_eye
#define motor_on
#define Pcontroller
#define task_ma_time
#define offset 65
#include "TSISensor.h"

Serial pc(USBTX, USBRX);
BX_servo servo;
BX_camera cam(0);
BX_motor MotorA('A');
BX_motor MotorB('B');
BX_pot pot1('1');            // 90/30=3
BX_pot pot2('2');
PID cam_to_M_ctrlr(10.0,118.0,0.06,0.11,(0.104/30),0.0,0.0,10);
DigitalOut task_pin(PTD1);
TSISensor tsi;

void run();

int main()
{
    pc.baud(115200);

    /*while(1) {
        if(tsi.readPercentage()>0.00011)
            break;
    }*/
    run();

    return 0;
}



void run()
{
    double motor, angle=0.0;
    double b_r_c;
    double PID_v;
    double error , P, I, D, kp, r_kp;
    double last_error=0.0 ,last_I=0.0, last_brc, brc_df;
    bool first_time=true, r_kp_neg=false;

    while(1) {
#ifdef task_ma_time
        task_pin=1;
#endif

        cam.read();
#ifdef Debug_cam_uart
#ifdef L_eye
        for(int i=0; i<128; i++) {
            if(i==64)
                pc.printf("X");
            else
                pc.printf("%c", cam.sign_line_imageL[i]);
        }
        pc.printf("           ||             ");
#endif
#ifdef R_eye
        for(int i=128; i>=0; i--) {
            if(i==64)
                pc.printf("X");
            else if(i<10)
                pc.printf("-");
            else if(i>117)
                pc.printf("-");
            else
                pc.printf("%c", cam.sign_line_imageR[i]);
        }
        pc.printf("    ");
        //pc.printf("\r\n");
#endif
#endif

#ifdef motor_on
        motor=pot1.read();
        MotorA.rotate(motor);
        MotorB.rotate(motor);
        //pc.printf("%f\r\n",motor);
#endif

        b_r_c=(double)cam.black_centerR();
        //pc.printf("%d %d speed :%f  bk_center %f PID:%f \r\n",cam.de_v,cam.de_v2,motor,b_r_c,PID_v);
        if(b_r_c<0.0){
            pc.printf("\r\n");
            continue;
            }
        //compute
        //stand at 65
        error=b_r_c-offset;
        brc_df=b_r_c-last_brc;
        
        
        if(first_time==true){
                r_kp=0;
                first_time=false;
            }
        else{
                r_kp+=brc_df;
                if(b_r_c==last_brc)
                    r_kp=0;
            }
        last_brc=b_r_c;
            
        if(r_kp<0.0){
                r_kp*=-1.0;
                r_kp_neg=true;
            }
        kp=0.016/(50-(r_kp/10.0));
        if(r_kp_neg==true){
                r_kp_neg=false;
                r_kp*=-1.0;
            } 
                
        P=kp*error;

        I=last_I*2.0/3.0+error;
        last_I=I;
        I=(kp*0.02/0.04)*I;

        D=error-last_error;
        last_error=error;
        D=(kp*0.04/0.02)*D;

        PID_v=P;

        if(PID_v < 0.0) {
            PID_v*=-1.0;
            PID_v=0.077+PID_v;
        } else if(PID_v > 0.0)
            PID_v=0.077-PID_v;
        else
            PID_v=0.077;
        pc.printf("%lf %lf %lf\r\n",PID_v, r_kp, b_r_c);
        //pc.printf("%lf\r\n",angle);
        servo.set_angle(PID_v);

#ifdef task_ma_time
        task_pin=0;
#endif
    }
}