share

Dependencies:   mbed-rtos mbed

Fork of BX-car_2 by Tony Lin

Committer:
TonyLin
Date:
Sun Jun 29 16:20:22 2014 +0000
Revision:
20:4ed21397e775
Parent:
19:eb0552a0ddae
6/30

Who changed what in which revision?

UserRevisionLine numberNew contents of line
backman 0:68c173249c01 1 #include "mbed.h"
backman 7:fd976e1ced33 2 #include "controller.h"
backman 1:82bc25a7b68b 3 #include "servo_api.h"
backman 1:82bc25a7b68b 4 #include "camera_api.h"
backman 6:5a39bde2e016 5 #include "motor_api.h"
backman 7:fd976e1ced33 6 #include "pot.h"
TonyLin 13:a33a7705fe2b 7
backman 3:c5f2281b3ed2 8
TonyLin 16:b1e11b865d05 9 #define Debug_cam_uart
backman 6:5a39bde2e016 10 #define R_eye
TonyLin 14:303b22b76d7a 11 #define motor_on
backman 6:5a39bde2e016 12 #define Pcontroller
backman 8:8e49e21d80a2 13 #define task_ma_time
TonyLin 13:a33a7705fe2b 14 #define offset 65
TonyLin 13:a33a7705fe2b 15 #include "TSISensor.h"
backman 12:418e39749f48 16
TonyLin 13:a33a7705fe2b 17 Serial pc(USBTX, USBRX);
TonyLin 14:303b22b76d7a 18 BX_servo servo;
TonyLin 20:4ed21397e775 19 BX_camera cam(0);
backman 6:5a39bde2e016 20 BX_motor MotorA('A');
backman 6:5a39bde2e016 21 BX_motor MotorB('B');
TonyLin 13:a33a7705fe2b 22 BX_pot pot1('1'); // 90/30=3
TonyLin 13:a33a7705fe2b 23 BX_pot pot2('2');
TonyLin 13:a33a7705fe2b 24 PID cam_to_M_ctrlr(10.0,118.0,0.06,0.11,(0.104/30),0.0,0.0,10);
backman 8:8e49e21d80a2 25 DigitalOut task_pin(PTD1);
backman 9:33b99cb45e99 26 TSISensor tsi;
backman 12:418e39749f48 27
TonyLin 13:a33a7705fe2b 28 void run();
backman 12:418e39749f48 29
TonyLin 14:303b22b76d7a 30 int main()
TonyLin 14:303b22b76d7a 31 {
TonyLin 13:a33a7705fe2b 32 pc.baud(115200);
TonyLin 14:303b22b76d7a 33
TonyLin 15:57567d3ee27e 34 /*while(1) {
TonyLin 13:a33a7705fe2b 35 if(tsi.readPercentage()>0.00011)
TonyLin 14:303b22b76d7a 36 break;
TonyLin 15:57567d3ee27e 37 }*/
TonyLin 13:a33a7705fe2b 38 run();
TonyLin 14:303b22b76d7a 39
TonyLin 13:a33a7705fe2b 40 return 0;
TonyLin 14:303b22b76d7a 41 }
backman 12:418e39749f48 42
backman 12:418e39749f48 43
backman 7:fd976e1ced33 44
TonyLin 14:303b22b76d7a 45 void run()
TonyLin 14:303b22b76d7a 46 {
TonyLin 15:57567d3ee27e 47 double motor, angle=0.0;
TonyLin 14:303b22b76d7a 48 double b_r_c;
TonyLin 14:303b22b76d7a 49 double PID_v;
TonyLin 14:303b22b76d7a 50 double error , P, I, D, kp, r_kp;
TonyLin 14:303b22b76d7a 51 double last_error=0.0 ,last_I=0.0, last_brc, brc_df;
TonyLin 14:303b22b76d7a 52 bool first_time=true, r_kp_neg=false;
TonyLin 14:303b22b76d7a 53
TonyLin 14:303b22b76d7a 54 while(1) {
TonyLin 14:303b22b76d7a 55 #ifdef task_ma_time
TonyLin 14:303b22b76d7a 56 task_pin=1;
TonyLin 14:303b22b76d7a 57 #endif
TonyLin 14:303b22b76d7a 58
TonyLin 14:303b22b76d7a 59 cam.read();
TonyLin 14:303b22b76d7a 60 #ifdef Debug_cam_uart
TonyLin 14:303b22b76d7a 61 #ifdef L_eye
TonyLin 14:303b22b76d7a 62 for(int i=0; i<128; i++) {
TonyLin 14:303b22b76d7a 63 if(i==64)
TonyLin 14:303b22b76d7a 64 pc.printf("X");
TonyLin 14:303b22b76d7a 65 else
TonyLin 14:303b22b76d7a 66 pc.printf("%c", cam.sign_line_imageL[i]);
TonyLin 14:303b22b76d7a 67 }
TonyLin 14:303b22b76d7a 68 pc.printf(" || ");
TonyLin 14:303b22b76d7a 69 #endif
TonyLin 14:303b22b76d7a 70 #ifdef R_eye
TonyLin 14:303b22b76d7a 71 for(int i=128; i>=0; i--) {
TonyLin 14:303b22b76d7a 72 if(i==64)
TonyLin 14:303b22b76d7a 73 pc.printf("X");
TonyLin 14:303b22b76d7a 74 else if(i<10)
TonyLin 14:303b22b76d7a 75 pc.printf("-");
TonyLin 14:303b22b76d7a 76 else if(i>117)
TonyLin 14:303b22b76d7a 77 pc.printf("-");
TonyLin 14:303b22b76d7a 78 else
TonyLin 14:303b22b76d7a 79 pc.printf("%c", cam.sign_line_imageR[i]);
TonyLin 14:303b22b76d7a 80 }
TonyLin 19:eb0552a0ddae 81 pc.printf(" ");
TonyLin 19:eb0552a0ddae 82 //pc.printf("\r\n");
TonyLin 14:303b22b76d7a 83 #endif
TonyLin 14:303b22b76d7a 84 #endif
TonyLin 14:303b22b76d7a 85
TonyLin 14:303b22b76d7a 86 #ifdef motor_on
TonyLin 14:303b22b76d7a 87 motor=pot1.read();
TonyLin 20:4ed21397e775 88 MotorA.rotate(motor);
TonyLin 20:4ed21397e775 89 MotorB.rotate(motor);
TonyLin 20:4ed21397e775 90 //pc.printf("%f\r\n",motor);
TonyLin 14:303b22b76d7a 91 #endif
TonyLin 14:303b22b76d7a 92
TonyLin 14:303b22b76d7a 93 b_r_c=(double)cam.black_centerR();
TonyLin 15:57567d3ee27e 94 //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);
TonyLin 20:4ed21397e775 95 if(b_r_c<0.0){
TonyLin 20:4ed21397e775 96 pc.printf("\r\n");
TonyLin 20:4ed21397e775 97 continue;
TonyLin 20:4ed21397e775 98 }
TonyLin 14:303b22b76d7a 99 //compute
TonyLin 14:303b22b76d7a 100 //stand at 65
TonyLin 14:303b22b76d7a 101 error=b_r_c-offset;
TonyLin 14:303b22b76d7a 102 brc_df=b_r_c-last_brc;
TonyLin 19:eb0552a0ddae 103
backman 12:418e39749f48 104
TonyLin 14:303b22b76d7a 105 if(first_time==true){
TonyLin 17:af867c7512bb 106 r_kp=0;
TonyLin 14:303b22b76d7a 107 first_time=false;
TonyLin 13:a33a7705fe2b 108 }
TonyLin 13:a33a7705fe2b 109 else{
TonyLin 15:57567d3ee27e 110 r_kp+=brc_df;
TonyLin 19:eb0552a0ddae 111 if(b_r_c==last_brc)
TonyLin 19:eb0552a0ddae 112 r_kp=0;
TonyLin 14:303b22b76d7a 113 }
TonyLin 19:eb0552a0ddae 114 last_brc=b_r_c;
backman 12:418e39749f48 115
TonyLin 14:303b22b76d7a 116 if(r_kp<0.0){
TonyLin 14:303b22b76d7a 117 r_kp*=-1.0;
TonyLin 14:303b22b76d7a 118 r_kp_neg=true;
TonyLin 14:303b22b76d7a 119 }
TonyLin 20:4ed21397e775 120 kp=0.016/(50-(r_kp/10.0));
TonyLin 14:303b22b76d7a 121 if(r_kp_neg==true){
TonyLin 14:303b22b76d7a 122 r_kp_neg=false;
TonyLin 14:303b22b76d7a 123 r_kp*=-1.0;
TonyLin 14:303b22b76d7a 124 }
TonyLin 14:303b22b76d7a 125
TonyLin 14:303b22b76d7a 126 P=kp*error;
TonyLin 14:303b22b76d7a 127
TonyLin 14:303b22b76d7a 128 I=last_I*2.0/3.0+error;
TonyLin 14:303b22b76d7a 129 last_I=I;
TonyLin 14:303b22b76d7a 130 I=(kp*0.02/0.04)*I;
TonyLin 14:303b22b76d7a 131
TonyLin 14:303b22b76d7a 132 D=error-last_error;
TonyLin 14:303b22b76d7a 133 last_error=error;
TonyLin 14:303b22b76d7a 134 D=(kp*0.04/0.02)*D;
TonyLin 14:303b22b76d7a 135
TonyLin 15:57567d3ee27e 136 PID_v=P;
TonyLin 14:303b22b76d7a 137
TonyLin 14:303b22b76d7a 138 if(PID_v < 0.0) {
TonyLin 15:57567d3ee27e 139 PID_v*=-1.0;
TonyLin 19:eb0552a0ddae 140 PID_v=0.077+PID_v;
TonyLin 14:303b22b76d7a 141 } else if(PID_v > 0.0)
TonyLin 19:eb0552a0ddae 142 PID_v=0.077-PID_v;
TonyLin 13:a33a7705fe2b 143 else
TonyLin 15:57567d3ee27e 144 PID_v=0.077;
TonyLin 16:b1e11b865d05 145 pc.printf("%lf %lf %lf\r\n",PID_v, r_kp, b_r_c);
TonyLin 15:57567d3ee27e 146 //pc.printf("%lf\r\n",angle);
TonyLin 13:a33a7705fe2b 147 servo.set_angle(PID_v);
TonyLin 14:303b22b76d7a 148
TonyLin 14:303b22b76d7a 149 #ifdef task_ma_time
TonyLin 14:303b22b76d7a 150 task_pin=0;
TonyLin 14:303b22b76d7a 151 #endif
TonyLin 14:303b22b76d7a 152 }
TonyLin 13:a33a7705fe2b 153 }