Cube Mini Solution
Dependencies: mbed QEI MPU6050 BLE_API nRF51822 MCP4725 eMPL_MPU6050
Diff: main.cpp
- Revision:
- 20:b142ae11a12a
- Parent:
- 19:2ffbd2af2b7f
- Child:
- 21:762f8769cba4
diff -r 2ffbd2af2b7f -r b142ae11a12a main.cpp --- a/main.cpp Wed Aug 19 14:05:22 2020 +0000 +++ b/main.cpp Thu Aug 20 13:50:22 2020 +0000 @@ -133,7 +133,7 @@ double Cuboid_Angle_Speed_Degrees = 0.0; // Low pass filter variables -float t = 0.5f;//0.5f; +float t = 0.45f; //Old 0.5f; // Flywheel Position and Velocity variables double Velocity_Input_Voltage = 0.0f; @@ -154,7 +154,7 @@ float Sys_input_Amps = 0.0f; // Sate Space Controller Values -float K_SS_Controller [2] = {-57.1176*0.3, -2.6398*1.5}; // From Matlab +float K_SS_Controller [2] = {-57.1176*0.3, -2.6398*1.35}; // From Matlab // Controller Variables float Loop1_output; // Loop 1 controller output @@ -203,7 +203,7 @@ // PID (PI) Controller (My PID Controller is fine but needs clarity updates) PID_Cntrl C1(Kp_1,Ki_1,Kd_1,Tf_1,Ts,uMin1,uMax1); // Defining the 1st Loop Controller (PI-Part) PID_Cntrl C2(Kp_2,Ki_2,Kd_2,Tf_2,Ts,uMin1,uMax1); // Defining the PI Controller for Chase (State 2) to keep motor velocity at zero -PID_Cntrl C3(Kp_1*2.5,Ki_1*1.5,Kd_2,Tf_2,Ts,uMin1,uMax1); // Safety Implementation in Case 4 PID +PID_Cntrl C3(Kp_1*3,Ki_1*2.0,Kd_2,Tf_2,Ts,uMin1,uMax1); // Safety Implementation in Case 4 PID // Accelerometer and Gyroscope Filters IIR_filter FilterAccX(t, Ts, 1.0f); @@ -318,16 +318,23 @@ case 0: // Output of 0 Amps Sys_input_Amps = 0.0; + + C1.reset(0.0f); break; case 1: // Breaking // PI Controller PID_Input = 0.0f - Velocity; - PID_Output = C2.update(PID_Input); - + //PID_Output = C2.update(PID_Input); + PID_Output = 0; + C1.reset(0.0f); + float Test1 = C1.reset(0.0f); + pc.printf("PI Outpu: %0.6f\n\r", Test1); // System input - Sys_input_Amps = PID_Output; + //Sys_input_Amps = PID_Output; + Sys_input_Amps = 0; + break; case 2: // Balancing and lift-up @@ -343,6 +350,7 @@ // System input Sys_input_Amps = PID_Output - Loop1_output - Loop2_output; + //Sys_input_Amps = 0.0f - Loop1_output - Loop2_output; // Do Not Modify - This is implemented to prevent the Cube from continuously speeding up while being still for after falling due to the user interrupting its movement @@ -361,6 +369,8 @@ case 4: // Lift up when stuck // Do Not Modify - This is implemented to prevent the Cube from continuously speeding up while being still for after falling due to the user interrupting its movement + C1.reset(0.0f); + PID_Input2 = 0.0f - Velocity; PID_Output2 = C3.update(-1*PID_Input2); @@ -375,7 +385,7 @@ VoltageOut.write(CurrentToVoltage(Sys_input_Amps)); //pc.printf("%0.7f, %0.7f, \n\r", abs(Cuboid_Angle_Degrees), abs(Velocity)); - if (abs(Velocity) < 15.0f) { + if (abs(Velocity) < 1.0f) { Sys_input_Amps = 0.0; Button_Status = 2; break; @@ -404,7 +414,7 @@ // Print Data // Printing Rate (in this case) is every Ts*100 = 0.007*100 = every 0.7 seconds if(++k >= 100) { k = 0; - pc.printf("Some Outputs: %0.6f, %0.6f, %i\n\r", Sys_input_Amps, Cuboid_Angle_Degrees, Button_Status); + pc.printf("Some Outputs: %0.6f, %0.6f, %0.6f, %i\n\r", Sys_input_Amps, Cuboid_Angle_Degrees, PID_Output, Button_Status); } @@ -428,6 +438,7 @@ T_Button.reset(); if(ButtonTime > 0.05f) { Button_Status = Button_Status + 1; + C1.reset(0.0f); if (Button_Status > 3.0f) { Button_Status = 1.0; }