Cube Mini Solution

Dependencies:   mbed QEI MPU6050 BLE_API nRF51822 MCP4725 eMPL_MPU6050

Revision:
7:07c5b6709d87
Parent:
6:122879c1503a
Child:
8:71babe904b92
--- a/main.cpp	Tue May 12 15:44:23 2020 +0000
+++ b/main.cpp	Tue May 12 16:51:44 2020 +0000
@@ -14,7 +14,7 @@
 #include "mcp4725.h"
 #include <stdbool.h>
 #include "LinearCharacteristics.h"
-#include "PID_Cntrl.h"
+#include "PID_Cntrl_Old.h"
 #include "PID_Cntrl_2.h"
 
 // Serial PC Communication
@@ -130,8 +130,8 @@
 LinearCharacteristics VoltageToVelocity(0.0f, 3.0f, -4000.0f, 4000.0f);
 
 // PID Controllers
-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_Old C1(Kp_1,Ki_1,Kd_1,Tf_1,Ts,uMin1,uMax1);  // Defining the 1st Loop Controller (PI-Part)
+PID_Cntrl_Old 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
 
 // Timers
 Timer Loop;
@@ -183,107 +183,117 @@
     C1.reset(0.0f);
 
     pc.printf("Hello World!\n\r");
-    // ControllerLoopTimer.attach(&updateControllers, Ts);
-
     wait(1);
 
-    while(1) {
-        Loop.reset();
+    ControllerLoopTimer.attach(&updateControllers, Ts);
+
+}
 
-        // Counter
-        LoopCounter++;
+void updateControllers(void)
+{
+    //Loop.reset();
 
-        // Acquire Velocity
-        Velocity_Voltage_Read = Velocity_Voltage_Input.read();
-        Velocity_Voltage = 3.2442*(Velocity_Voltage_Read);
-        Velocity_rpm = VoltageToVelocity(Velocity_Voltage);
-        Velocity = Velocity_rpm*2.0*pi/60.0;
+    // Counter
+    //LoopCounter++;
 
-        // Aquire Raw Acceleration and Gyro Data form the IMU
-        mpu.getMotion6(&AccX_Raw, &AccY_Raw, &AccZ_Raw, &GyroX_Raw, &GyroY_Raw, &GyroZ_Raw);
-
-        // -------------- Convert Raw data to SI Units --------------------
+    // Acquire Velocity
+    Velocity_Voltage_Read = Velocity_Voltage_Input.read();
+    Velocity_Voltage = 3.2442178*(Velocity_Voltage_Read);
+    Velocity_rpm = VoltageToVelocity(Velocity_Voltage);
+    Velocity = Velocity_rpm*2.0*pi/60.0;
+    
 
-        //Convert Acceleration Raw Data to (ms^-2) - (Settings of +/- 4g)
-        AccX_g = AccX_Raw / 8192.0f;
-        AccY_g = AccY_Raw / 8192.0f;
-        AccZ_g = AccZ_Raw / 8192.0f;
+    // Aquire Raw Acceleration and Gyro Data form the IMU
+    mpu.getMotion6(&AccX_Raw, &AccY_Raw, &AccZ_Raw, &GyroX_Raw, &GyroY_Raw, &GyroZ_Raw);
+
+    // -------------- Convert Raw data to SI Units --------------------
+
+    //Convert Acceleration Raw Data to (ms^-2) - (Settings of +/- 4g)
+    AccX_g = AccX_Raw / 8192.0f;
+    AccY_g = AccY_Raw / 8192.0f;
+    AccZ_g = AccZ_Raw / 8192.0f;
 
-        //Convert Gyroscope Raw Data to Degrees per second
-        GyroX_Degrees = GyroX_Raw / 32.768f;  // (2^15/1000 = 32.768)
-        GyroY_Degrees = GyroY_Raw / 32.768f;  // (2^15/1000 = 32.768)
-        GyroZ_Degrees = GyroZ_Raw / 32.768f;  // (2^15/1000 = 32.768)
+    //Convert Gyroscope Raw Data to Degrees per second
+    GyroX_Degrees = GyroX_Raw / 32.768f;  // (2^15/1000 = 32.768)
+    GyroY_Degrees = GyroY_Raw / 32.768f;  // (2^15/1000 = 32.768)
+    GyroZ_Degrees = GyroZ_Raw / 32.768f;  // (2^15/1000 = 32.768)
 
-        //Convert Gyroscope Raw Data to Degrees per second
-        GyroZ_RadiansPerSecond = (GyroZ_Raw / 32.768f)* pi/180.0f;
+    //Convert Gyroscope Raw Data to Degrees per second
+    GyroZ_RadiansPerSecond = (GyroZ_Raw / 32.768f)* pi/180.0f;
 
-        // ----- Combine Accelerometer Data and Gyro Data to Get Angle ------
+    // ----- Combine Accelerometer Data and Gyro Data to Get Angle ------
 
-        Cuboid_Angle_Radians =  -1*atan2(-FilterAccX(AccX_g), FilterAccY(AccY_g)) + 0.7854f + FilterGyro(GyroZ_RadiansPerSecond);  // Check later if fast enough!!
-        Cuboid_Angle_Degrees = Cuboid_Angle_Radians*180.0f/pi;
+    Cuboid_Angle_Radians =  -1*atan2(-FilterAccX(AccX_g), FilterAccY(AccY_g)) + 0.7854f + FilterGyro(GyroZ_RadiansPerSecond);  // Check later if fast enough!!
+    Cuboid_Angle_Degrees = Cuboid_Angle_Radians*180.0f/pi;
 
 
-        // ------------------------- Controller -----------------------------
-        // Current Input Updater - Amperes
-        // Loop 1
-        Loop1_output = Cuboid_Angle_Radians*K_SS_Controller[0];
-        // Loop 2
-        Loop2_output = GyroZ_RadiansPerSecond*K_SS_Controller[1];
-        // PI Controller
-        PID_Input = Desired_input - Velocity;
-        PID_Output = C1.update(PID_Input);
-        /*
-        //PID_Input = 20.0 - Velocity;
-        //PID_Output = C1.update(-1*PID_Input);
-        //PID_Output = 0; // CHANGE LATER - This is for testing purposes
-        */
+    // ------------------------- Controller -----------------------------
+    // Current Input Updater - Amperes
+    // Loop 1
+    Loop1_output = Cuboid_Angle_Radians*K_SS_Controller[0];
+    // Loop 2
+    Loop2_output = GyroZ_RadiansPerSecond*K_SS_Controller[1];
+    // PI Controller
+    PID_Input = Desired_input - Velocity;
+    PID_Output = C1.update(-1*PID_Input);
+    /*
+    //PID_Input = 20.0 - Velocity;
+    //PID_Output = C1.update(-1*PID_Input);
+    //PID_Output = 0; // CHANGE LATER - This is for testing purposes
+    */
 
-        // System input
-        Sys_input_Amps = PID_Output; //- Loop1_output - Loop2_output;
+    // System input
+    Sys_input_Amps = PID_Output; //- Loop1_output - Loop2_output;
 
 
-        if (Sys_input_Amps > uMax2) {
-            Sys_input_Amps = uMax2;
-        }
-        if (Sys_input_Amps < uMin2) {
-            Sys_input_Amps = uMin2;
-        }
+    if (Sys_input_Amps > uMax2) {
+        Sys_input_Amps = uMax2;
+    }
+    if (Sys_input_Amps < uMin2) {
+        Sys_input_Amps = uMin2;
+    }
 
-        // Scaling the controller output from -15 A --> 15 A to 0 V --> 5 V
-        VoltageOut.write(CurrentToVoltage(Sys_input_Amps));
+    // Scaling the controller output from -15 A --> 15 A to 0 V --> 5 V
+    VoltageOut.write(CurrentToVoltage(Sys_input_Amps));
+
+    // Print Data
+    if(++k >= 30) {
+        k = 0;
 
         //1LoopCounter,2.1CurrentToVoltage, 2Sys_input_Amps, 3Cuboid_Angle_Degrees, 4GyroZ_RadiansPerSecond, 5Velocity, 6Velocity_Voltage, 7AccX_g, 8AccY_g, 9PID_Input, 10PID_Output, (Loop1_output+Loop2_output), Loop.read())
-        //pc.printf(" %i, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, ", LoopCounter, CurrentToVoltage(Sys_input_Amps), Sys_input_Amps, Cuboid_Angle_Degrees, GyroZ_RadiansPerSecond, Velocity, Velocity_Voltage, AccX_g, AccY_g, PID_Input, PID_Output, (Loop1_output+Loop2_output));
-
-        //pc.printf("%i; %0.6f, \n\r", LoopCounter, Loop.read());
-
-        //
+        pc.printf(" %i, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, %0.5f, ", LoopCounter, CurrentToVoltage(Sys_input_Amps), Sys_input_Amps, Cuboid_Angle_Degrees, GyroZ_RadiansPerSecond, Velocity, Velocity_Voltage, AccX_g, AccY_g, PID_Input, PID_Output, (Loop1_output+Loop2_output));
+        pc.printf("\n\r");
+    }
 
-        // wait(0.0025);
-        // pc.printf(" %0.5f \n\r", Loop.read());
+    //pc.printf("%i; %0.6f, \n\r", LoopCounter, Loop.read());
 
-        /*
-         LoopTime = Loop.read();
-         while(LoopTime < Ts) {
-             LoopTime = Loop.read();
-         }
-         */
+    //
+
+    // wait(0.0025);
+    // pc.printf(" %0.5f \n\r", Loop.read());
 
-        // pc.printf(" %0.5f \n\r", LoopTime);
+    /*
+     LoopTime = Loop.read();
+     while(LoopTime < Ts) {
+         LoopTime = Loop.read();
+     }
+     */
 
-        //pc.printf("Angle = %0.2f,  Current = %0.2f, VoltageOut = %0.3f, Velocity = %0.2f, VoltageIn = %0.3f\n\r", Cuboid_Angle_Degrees, Sys_input_Amps, CurrentToVoltage(Sys_input_Amps), Velocity, Velocity_Voltage);
+    // pc.printf(" %0.5f \n\r", LoopTime);
+
+    //pc.printf("Angle = %0.2f,  Current = %0.2f, VoltageOut = %0.3f, Velocity = %0.2f, VoltageIn = %0.3f\n\r", Cuboid_Angle_Degrees, Sys_input_Amps, CurrentToVoltage(Sys_input_Amps), Velocity, Velocity_Voltage);
 
-        /*
-                // Print Data
-                if(++k >= 300) {
-                    k = 0;
-                    //pc.printf("%0.8f\n\r", Loop.read());
-                    pc.printf("Angle = %0.2f,  Current = %0.2f, VoltageOut = %0.3f, Velocity = %0.2f, VoltageIn = %0.3f\n\r", Cuboid_Angle_Degrees, Sys_input_Amps, CurrentToVoltage(Sys_input_Amps), Velocity, Velocity_Voltage);
+    /*
+            // Print Data
+            if(++k >= 300) {
+                k = 0;
+                //pc.printf("%0.8f\n\r", Loop.read());
+                pc.printf("Angle = %0.2f,  Current = %0.2f, VoltageOut = %0.3f, Velocity = %0.2f, VoltageIn = %0.3f\n\r", Cuboid_Angle_Degrees, Sys_input_Amps, CurrentToVoltage(Sys_input_Amps), Velocity, Velocity_Voltage);
 
-                }
-        */
+            }
+    */
 
-    }
+
 }