cube
Dependencies: BNO055_fusion_tom FastPWM mbed
main.cpp
- Committer:
- wchurch
- Date:
- 2017-04-11
- Revision:
- 21:4f60d60b2e5a
- Parent:
- 20:79c99bbf6dd7
- Child:
- 22:9f3022fe9084
File content as of revision 21:4f60d60b2e5a:
#include "mbed.h" #include "BNO055.h" //------------------------------------ // Hyperterminal configuration // 9600 bauds, 8-bit data, no parity //------------------------------------ Serial pc(SERIAL_TX, SERIAL_RX); Ticker pwmint; DigitalOut myled(LED1); InterruptIn button(USER_BUTTON); PwmOut P1(PE_9); DigitalOut EN1(D0); AnalogIn I1(A0); //PwmOut P2(PE_11); 1D FOCUS FOR NOW //PwmOut P3(PE_13); I2C i2c(PB_9, PB_8); // SDA, SCL BNO055 imu(i2c, PA_8); // Reset BNO055_ID_INF_TypeDef bno055_id_inf; BNO055_EULER_TypeDef euler_angles; BNO055_VEL_TypeDef velocity; //IN PROGRESS double Kbt = -89.9276; double Kbv = -14.9398; double Kwv = 0.0;//-0.0909; double wv; double bt; double r1; double pi = 3.14159265; int isPressed; void pwmupdate() { //myled = !myled; wv = I1.read(); // Converts and read the analog input value (value from 0.0 to 1.0) wv = (wv-2.0)*5000.0; // Scale the velocity to rad/s bt = (euler_angles.p - (pi/4.0)); r1 = (Kbt*bt + Kbv*velocity.z + Kwv*wv); //Limit PWM range if (r1 > 6.0) { r1 = 6.0; } if (r1 < -6.0) { r1 = -6.0; } r1 = ((.4*(r1/6.0)) + 0.5) ; //Normalize for PWM output P1 = r1; //P2 = (euler_angles.r/360.0); //P3 = (euler_angles.p/360.0); if (bt > (pi/8)){ EN1 = 0; pwmint.detach(); } else if (bt< -(pi/8)){ EN1 = 0; pwmint.detach(); } } void eventFunction() { if(!isPressed) { pwmint.attach(&pwmupdate, .005); EN1 = 1; myled = 1; isPressed=1; } else { pwmint.detach(); P1 = 0.5; bt = 0.0; myled = 0; EN1 = 0; //P2 = 0; //P3 = 0; isPressed=0; } } int main() { pc.printf("Bosch Sensortec BNO055 test program on " __DATE__ "/" __TIME__ "\r\n"); if (imu.chip_ready() == 0) { pc.printf("Bosch BNO055 is NOT available!!\r\n"); } imu.read_id_inf(&bno055_id_inf); P1 = .5; //Stops ESCON studio from throwing out-of-range error //pc.printf("CHIP:0x%02x, ACC:0x%02x, MAG:0x%02x, GYR:0x%02x, , SW:0x%04x, , BL:0x%02x\r\n", // bno055_id_inf.chip_id, bno055_id_inf.acc_id, bno055_id_inf.mag_id, // bno055_id_inf.gyr_id, bno055_id_inf.sw_rev_id, bno055_id_inf.bootldr_rev_id); P1.period(0.0002); //Set PWM frequency isPressed=0; button.rise(&eventFunction); //Enable Closed Loop while(1) { // pc.printf("H:%+6.4f [rad], P:%+6.4f, R:%+6.4f, R1%+6.4f [PWM], Theta_dot:%+6.4f [rad/s] , WV:%+6.4f [rad/s] \r\n", // euler_angles.h, euler_angles.p, euler_angles.r, r1, velocity.z, wv); //pc.printf("Theta:%+6.4f [rad], P:%+6.4f [rad], R1%+6.4f [PWM], Theta_dot:%+6.4f [rad/s], WV:%+6.4f [rad/s] \r\n", // bt, euler_angles.p, r1, velocity.z, wv); imu.get_Euler_Angles(&euler_angles); imu.get_velocities(&velocity); //wait(0.2); } }