2輪に移行
Dependencies: MPU92502 Motor2 PIDonerobot Stepper mbed
main.cpp@0:1faa9570d725, 2016-08-07 (annotated)
- Committer:
- kikoaac
- Date:
- Sun Aug 07 12:47:51 2016 +0000
- Revision:
- 0:1faa9570d725
2????
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
kikoaac | 0:1faa9570d725 | 1 | #include "mbed.h" |
kikoaac | 0:1faa9570d725 | 2 | #include "Motor.h" |
kikoaac | 0:1faa9570d725 | 3 | #include "MPU9250.h" |
kikoaac | 0:1faa9570d725 | 4 | #include "stepperMotor.h" |
kikoaac | 0:1faa9570d725 | 5 | |
kikoaac | 0:1faa9570d725 | 6 | #include "PID.h" |
kikoaac | 0:1faa9570d725 | 7 | |
kikoaac | 0:1faa9570d725 | 8 | #define INTERVAL 0.1 |
kikoaac | 0:1faa9570d725 | 9 | #define Lx 0.0 |
kikoaac | 0:1faa9570d725 | 10 | #define Ku 26.2//0.922000 |
kikoaac | 0:1faa9570d725 | 11 | #define Pu 20.8 |
kikoaac | 0:1faa9570d725 | 12 | #define Kp Ku*0.182 |
kikoaac | 0:1faa9570d725 | 13 | #define Ti Pu*0.55 |
kikoaac | 0:1faa9570d725 | 14 | #define Td Pu*0.35 |
kikoaac | 0:1faa9570d725 | 15 | #define P Kp |
kikoaac | 0:1faa9570d725 | 16 | #define I Kp/Ti |
kikoaac | 0:1faa9570d725 | 17 | #define D Kp*Td |
kikoaac | 0:1faa9570d725 | 18 | #include<esp8266.cpp> |
kikoaac | 0:1faa9570d725 | 19 | |
kikoaac | 0:1faa9570d725 | 20 | //DigitalOut myled(LED1); |
kikoaac | 0:1faa9570d725 | 21 | Serial esp(dp16,dp15); |
kikoaac | 0:1faa9570d725 | 22 | |
kikoaac | 0:1faa9570d725 | 23 | Ticker tick; |
kikoaac | 0:1faa9570d725 | 24 | SPI spi(dp2,dp1,dp6);//(A6, A5, A4);//(p5,p6,p7) |
kikoaac | 0:1faa9570d725 | 25 | mpu9250_spi imu(spi,dp26);//,A3);//,p8) //define the mpu9250 object |
kikoaac | 0:1faa9570d725 | 26 | Timer pi; |
kikoaac | 0:1faa9570d725 | 27 | PID pid1(P,I,D,&pi); |
kikoaac | 0:1faa9570d725 | 28 | PID pid2(P,I,D,&pi); |
kikoaac | 0:1faa9570d725 | 29 | DigitalOut led1(dp28); |
kikoaac | 0:1faa9570d725 | 30 | void init(); |
kikoaac | 0:1faa9570d725 | 31 | |
kikoaac | 0:1faa9570d725 | 32 | esp8266 ESP; |
kikoaac | 0:1faa9570d725 | 33 | Stepper wheel1(dp13,dp14);//(D11,D12);//dp10,11 |
kikoaac | 0:1faa9570d725 | 34 | |
kikoaac | 0:1faa9570d725 | 35 | Stepper wheel2(dp10,dp9);//(D11,D12);//dp10,11 |
kikoaac | 0:1faa9570d725 | 36 | #define k1 3.8 |
kikoaac | 0:1faa9570d725 | 37 | #define k2 1.6 |
kikoaac | 0:1faa9570d725 | 38 | #define k3 0.1 |
kikoaac | 0:1faa9570d725 | 39 | #define k4 0.1 |
kikoaac | 0:1faa9570d725 | 40 | |
kikoaac | 0:1faa9570d725 | 41 | float st1() |
kikoaac | 0:1faa9570d725 | 42 | { |
kikoaac | 0:1faa9570d725 | 43 | float s1 = wheel1.pulse * 7.5; |
kikoaac | 0:1faa9570d725 | 44 | |
kikoaac | 0:1faa9570d725 | 45 | static float prev_s2 = 0; |
kikoaac | 0:1faa9570d725 | 46 | float s2 = (s1 - prev_s2)/INTERVAL; |
kikoaac | 0:1faa9570d725 | 47 | static float prev = 0; |
kikoaac | 0:1faa9570d725 | 48 | float s5 = (s2 - prev)/INTERVAL; |
kikoaac | 0:1faa9570d725 | 49 | static float prev_s3 = 0; |
kikoaac | 0:1faa9570d725 | 50 | float s3 = imu.kalman_angle[2]; |
kikoaac | 0:1faa9570d725 | 51 | float s4 = (s3 - prev_s3)/INTERVAL; |
kikoaac | 0:1faa9570d725 | 52 | prev_s2=s1; |
kikoaac | 0:1faa9570d725 | 53 | prev_s3=s3; |
kikoaac | 0:1faa9570d725 | 54 | prev = s2; |
kikoaac | 0:1faa9570d725 | 55 | //printf("%f,%f,%f,%f,%f",k1*s5,k2*s2,k3*s3,k4*s4,k1*s1+k2*s2+k3*s3+k4*s4); |
kikoaac | 0:1faa9570d725 | 56 | printf(end); |
kikoaac | 0:1faa9570d725 | 57 | return k1*s3+k2*s4+k3*s2+k4*s1; |
kikoaac | 0:1faa9570d725 | 58 | |
kikoaac | 0:1faa9570d725 | 59 | } |
kikoaac | 0:1faa9570d725 | 60 | #define k12 k1 |
kikoaac | 0:1faa9570d725 | 61 | #define k22 k2 |
kikoaac | 0:1faa9570d725 | 62 | #define k32 k3 |
kikoaac | 0:1faa9570d725 | 63 | #define k42 k4 |
kikoaac | 0:1faa9570d725 | 64 | float st2() |
kikoaac | 0:1faa9570d725 | 65 | { |
kikoaac | 0:1faa9570d725 | 66 | float s1 = wheel2.pulse * 7.5; |
kikoaac | 0:1faa9570d725 | 67 | |
kikoaac | 0:1faa9570d725 | 68 | static float prev_s2 = 0; |
kikoaac | 0:1faa9570d725 | 69 | float s2 = (s1 - prev_s2)/INTERVAL; |
kikoaac | 0:1faa9570d725 | 70 | static float prev = 0; |
kikoaac | 0:1faa9570d725 | 71 | float s5 = (s2 - prev)/INTERVAL; |
kikoaac | 0:1faa9570d725 | 72 | static float prev_s3 = 0; |
kikoaac | 0:1faa9570d725 | 73 | float s3 = imu.kalman_angle[2]; |
kikoaac | 0:1faa9570d725 | 74 | float s4 = (s3 - prev_s3)/INTERVAL; |
kikoaac | 0:1faa9570d725 | 75 | prev_s2=s1; |
kikoaac | 0:1faa9570d725 | 76 | prev = s2; |
kikoaac | 0:1faa9570d725 | 77 | prev_s3=s3; |
kikoaac | 0:1faa9570d725 | 78 | //printf("%f,%f,%f,%f,%f",k1*s5,k2*s2,k3*s3,k4*s4,k1*s1+k2*s2+k3*s3+k4*s4); |
kikoaac | 0:1faa9570d725 | 79 | printf(end); |
kikoaac | 0:1faa9570d725 | 80 | return k1*s3+k2*s4+k3*s2+k4*s1; |
kikoaac | 0:1faa9570d725 | 81 | |
kikoaac | 0:1faa9570d725 | 82 | } |
kikoaac | 0:1faa9570d725 | 83 | int main() { |
kikoaac | 0:1faa9570d725 | 84 | //while(1); |
kikoaac | 0:1faa9570d725 | 85 | //printf("st"); |
kikoaac | 0:1faa9570d725 | 86 | /*DigitalOut a(dp9); |
kikoaac | 0:1faa9570d725 | 87 | DigitalOut b(dp10); |
kikoaac | 0:1faa9570d725 | 88 | while(1) |
kikoaac | 0:1faa9570d725 | 89 | { |
kikoaac | 0:1faa9570d725 | 90 | a=1; |
kikoaac | 0:1faa9570d725 | 91 | b=0; |
kikoaac | 0:1faa9570d725 | 92 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 93 | a=1; |
kikoaac | 0:1faa9570d725 | 94 | b=1; |
kikoaac | 0:1faa9570d725 | 95 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 96 | a=0; |
kikoaac | 0:1faa9570d725 | 97 | b=1; |
kikoaac | 0:1faa9570d725 | 98 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 99 | a=0; |
kikoaac | 0:1faa9570d725 | 100 | b=0; |
kikoaac | 0:1faa9570d725 | 101 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 102 | printf("rotate"); |
kikoaac | 0:1faa9570d725 | 103 | printf(end); |
kikoaac | 0:1faa9570d725 | 104 | }*/ |
kikoaac | 0:1faa9570d725 | 105 | |
kikoaac | 0:1faa9570d725 | 106 | init(); |
kikoaac | 0:1faa9570d725 | 107 | |
kikoaac | 0:1faa9570d725 | 108 | led1 = 1; |
kikoaac | 0:1faa9570d725 | 109 | wheel1.start(); |
kikoaac | 0:1faa9570d725 | 110 | wheel2.start(); |
kikoaac | 0:1faa9570d725 | 111 | while(1) { |
kikoaac | 0:1faa9570d725 | 112 | double data[3]; |
kikoaac | 0:1faa9570d725 | 113 | imu.read_all(); |
kikoaac | 0:1faa9570d725 | 114 | imu.set_angle(); |
kikoaac | 0:1faa9570d725 | 115 | imu.get_angle_acc(); |
kikoaac | 0:1faa9570d725 | 116 | imu.get_angle(&data[0],&data[1],&data[2]); |
kikoaac | 0:1faa9570d725 | 117 | //printf("%10.3lf, %10.3lf, %10.3f\n", |
kikoaac | 0:1faa9570d725 | 118 | // imu.kalman_angle[2],imu.angle[2],imu.angle_acc[2]); |
kikoaac | 0:1faa9570d725 | 119 | if(abs(imu.kalman_angle[2]) < 50) |
kikoaac | 0:1faa9570d725 | 120 | { |
kikoaac | 0:1faa9570d725 | 121 | |
kikoaac | 0:1faa9570d725 | 122 | pid1.dPoint = imu.kalman_angle[2]; |
kikoaac | 0:1faa9570d725 | 123 | pid2.dPoint = imu.kalman_angle[2]; |
kikoaac | 0:1faa9570d725 | 124 | pid1.PIDctrl(); |
kikoaac | 0:1faa9570d725 | 125 | pid2.PIDctrl(); |
kikoaac | 0:1faa9570d725 | 126 | float d1 = pid1.data , d2 = pid2.data; |
kikoaac | 0:1faa9570d725 | 127 | printf("%10.3f , %10.3f \n" , d1,d2); |
kikoaac | 0:1faa9570d725 | 128 | wheel1 = -st1() / 255; |
kikoaac | 0:1faa9570d725 | 129 | wheel2 = -st2() / 255; |
kikoaac | 0:1faa9570d725 | 130 | } |
kikoaac | 0:1faa9570d725 | 131 | else |
kikoaac | 0:1faa9570d725 | 132 | { |
kikoaac | 0:1faa9570d725 | 133 | pid1.pid_reset(); |
kikoaac | 0:1faa9570d725 | 134 | pid2.pid_reset(); |
kikoaac | 0:1faa9570d725 | 135 | wheel1 = 0; |
kikoaac | 0:1faa9570d725 | 136 | wheel2 = 0; |
kikoaac | 0:1faa9570d725 | 137 | wheel1.pulse = 0; |
kikoaac | 0:1faa9570d725 | 138 | wheel2.pulse = 0; |
kikoaac | 0:1faa9570d725 | 139 | }/* |
kikoaac | 0:1faa9570d725 | 140 | if(imu.kalman_angle[1]<0) |
kikoaac | 0:1faa9570d725 | 141 | { |
kikoaac | 0:1faa9570d725 | 142 | wheel1 = 1; |
kikoaac | 0:1faa9570d725 | 143 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 144 | wheel1 = -1; |
kikoaac | 0:1faa9570d725 | 145 | wait(0.1); |
kikoaac | 0:1faa9570d725 | 146 | } |
kikoaac | 0:1faa9570d725 | 147 | else if(imu.kalman_angle[1]>0) |
kikoaac | 0:1faa9570d725 | 148 | { |
kikoaac | 0:1faa9570d725 | 149 | wheel1 = -1; |
kikoaac | 0:1faa9570d725 | 150 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 151 | wheel1 = 1; |
kikoaac | 0:1faa9570d725 | 152 | wait(0.1); |
kikoaac | 0:1faa9570d725 | 153 | }*/ |
kikoaac | 0:1faa9570d725 | 154 | wait(INTERVAL); |
kikoaac | 0:1faa9570d725 | 155 | } |
kikoaac | 0:1faa9570d725 | 156 | } |
kikoaac | 0:1faa9570d725 | 157 | |
kikoaac | 0:1faa9570d725 | 158 | void init() |
kikoaac | 0:1faa9570d725 | 159 | { |
kikoaac | 0:1faa9570d725 | 160 | //pc.baud(230400); |
kikoaac | 0:1faa9570d725 | 161 | |
kikoaac | 0:1faa9570d725 | 162 | esp.baud(115200); |
kikoaac | 0:1faa9570d725 | 163 | ESP.setSerial(&esp); |
kikoaac | 0:1faa9570d725 | 164 | led1=0; |
kikoaac | 0:1faa9570d725 | 165 | wait(1); |
kikoaac | 0:1faa9570d725 | 166 | for(int i= 0 ; i<6;i++){led1=1;wait(0.05);led1=0;wait(0.05);} |
kikoaac | 0:1faa9570d725 | 167 | wait(1); |
kikoaac | 0:1faa9570d725 | 168 | /*while(1) |
kikoaac | 0:1faa9570d725 | 169 | { |
kikoaac | 0:1faa9570d725 | 170 | int i = esp.getc(); |
kikoaac | 0:1faa9570d725 | 171 | if(i == 'A') |
kikoaac | 0:1faa9570d725 | 172 | { |
kikoaac | 0:1faa9570d725 | 173 | led1 = 1; |
kikoaac | 0:1faa9570d725 | 174 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 175 | esp.putc(i); |
kikoaac | 0:1faa9570d725 | 176 | } |
kikoaac | 0:1faa9570d725 | 177 | if(i == 'B') |
kikoaac | 0:1faa9570d725 | 178 | { |
kikoaac | 0:1faa9570d725 | 179 | led1 = 0; |
kikoaac | 0:1faa9570d725 | 180 | wait(0.5); |
kikoaac | 0:1faa9570d725 | 181 | esp.putc(i); |
kikoaac | 0:1faa9570d725 | 182 | } |
kikoaac | 0:1faa9570d725 | 183 | }*/ |
kikoaac | 0:1faa9570d725 | 184 | //printf("sart!!"); |
kikoaac | 0:1faa9570d725 | 185 | /*while(ESP.ATcommand("")) |
kikoaac | 0:1faa9570d725 | 186 | { |
kikoaac | 0:1faa9570d725 | 187 | wait(2); |
kikoaac | 0:1faa9570d725 | 188 | printf("esp8266 is no connection\n"); |
kikoaac | 0:1faa9570d725 | 189 | }*/ |
kikoaac | 0:1faa9570d725 | 190 | //ESP.wifiConnectionMode(2); |
kikoaac | 0:1faa9570d725 | 191 | //ESP.wifiSoftAPSetting("ESP8266","ta",5,3); |
kikoaac | 0:1faa9570d725 | 192 | |
kikoaac | 0:1faa9570d725 | 193 | //ESP.WifiFindAccesspoint(); |
kikoaac | 0:1faa9570d725 | 194 | //myled = 1; |
kikoaac | 0:1faa9570d725 | 195 | /* |
kikoaac | 0:1faa9570d725 | 196 | do |
kikoaac | 0:1faa9570d725 | 197 | { |
kikoaac | 0:1faa9570d725 | 198 | wait(1); |
kikoaac | 0:1faa9570d725 | 199 | //printf("Finding ESP8266"); |
kikoaac | 0:1faa9570d725 | 200 | }while(ESP.WifiFindAccesspoint("ESP8366")); |
kikoaac | 0:1faa9570d725 | 201 | while(ESP.wifiConnect("ESP8366","ryuutaka")) |
kikoaac | 0:1faa9570d725 | 202 | { |
kikoaac | 0:1faa9570d725 | 203 | wait(1); |
kikoaac | 0:1faa9570d725 | 204 | // printf("connecting to ESP8266\n"); |
kikoaac | 0:1faa9570d725 | 205 | }*/ |
kikoaac | 0:1faa9570d725 | 206 | //printf("esp8266 is acyivity\n"); |
kikoaac | 0:1faa9570d725 | 207 | double g[3]; |
kikoaac | 0:1faa9570d725 | 208 | //Thread thread2(GET); |
kikoaac | 0:1faa9570d725 | 209 | if(imu.init(1,BITS_DLPF_CFG_188HZ)) { //INIT the mpu9250 |
kikoaac | 0:1faa9570d725 | 210 | //printf("\nCouldn't initialize MPU9250 via SPI!"); |
kikoaac | 0:1faa9570d725 | 211 | } |
kikoaac | 0:1faa9570d725 | 212 | char x = imu.whoami(); |
kikoaac | 0:1faa9570d725 | 213 | do { |
kikoaac | 0:1faa9570d725 | 214 | x = imu.whoami(); |
kikoaac | 0:1faa9570d725 | 215 | printf("WHOAMI=0x%2x\n",x); //output the I2C address to know if SPI is working, it should be 104 |
kikoaac | 0:1faa9570d725 | 216 | wait(0.3); |
kikoaac | 0:1faa9570d725 | 217 | } while(x!=0x71); |
kikoaac | 0:1faa9570d725 | 218 | //printf("Gyro_scale=%u\n",); //Set full scale range for gyros |
kikoaac | 0:1faa9570d725 | 219 | imu.set_gyro_scale(BITS_FS_2000DPS); |
kikoaac | 0:1faa9570d725 | 220 | wait(0.3); |
kikoaac | 0:1faa9570d725 | 221 | //printf("Acc_scale=%u\n",imu.set_acc_scale(BITS_FS_16G)); //Set full scale range for accs |
kikoaac | 0:1faa9570d725 | 222 | imu.set_acc_scale(BITS_FS_16G); |
kikoaac | 0:1faa9570d725 | 223 | wait(0.3); |
kikoaac | 0:1faa9570d725 | 224 | do { |
kikoaac | 0:1faa9570d725 | 225 | x=imu.AK8963_whoami(); |
kikoaac | 0:1faa9570d725 | 226 | printf("AK8963 WHIAM=0x%2x\n",x); |
kikoaac | 0:1faa9570d725 | 227 | wait(0.3); |
kikoaac | 0:1faa9570d725 | 228 | } while(x!=0x48); |
kikoaac | 0:1faa9570d725 | 229 | imu.MPU_setup(); |
kikoaac | 0:1faa9570d725 | 230 | wait(0.1); |
kikoaac | 0:1faa9570d725 | 231 | pid1.OutputLimits(255,-255); |
kikoaac | 0:1faa9570d725 | 232 | pid1.start(); |
kikoaac | 0:1faa9570d725 | 233 | pid1.dTarget = 0; |
kikoaac | 0:1faa9570d725 | 234 | pid2.OutputLimits(255,-255); |
kikoaac | 0:1faa9570d725 | 235 | pid2.start(); |
kikoaac | 0:1faa9570d725 | 236 | pid2.dTarget = 0; |
kikoaac | 0:1faa9570d725 | 237 | } |