altb_pmic / Mbed 2 deprecated GRT_VC_PIDT1_musterloesung

Dependencies:   mbed

Committer:
altb2
Date:
Tue May 07 10:22:30 2019 +0000
Revision:
1:314e2e3727f2
Parent:
0:4ed9a8952ddc
Child:
2:0b64504024fe
My Musterloesung (not tested)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
altb2 0:4ed9a8952ddc 1 #include "mbed.h"
altb2 0:4ed9a8952ddc 2 #include "EncoderCounter.h"
altb2 1:314e2e3727f2 3 #include "PID_Cntrl.h"
altb2 0:4ed9a8952ddc 4 #include "LinearCharacteristics.h"
altb2 0:4ed9a8952ddc 5 //------------------------------------------
altb2 0:4ed9a8952ddc 6 #define PI 3.1415927f
altb2 0:4ed9a8952ddc 7 //------------------------------------------
altb2 0:4ed9a8952ddc 8
altb2 1:314e2e3727f2 9 /* GRT: Control of voice-coil with PID-T1 - Controller
altb2 0:4ed9a8952ddc 10 */
altb2 0:4ed9a8952ddc 11 Serial pc(SERIAL_TX, SERIAL_RX); // serial connection via USB - programmer
altb2 0:4ed9a8952ddc 12 InterruptIn button(USER_BUTTON); // User Button, short presses: reduce speed, long presses: increase speed
altb2 1:314e2e3727f2 13 AnalogOut out(PA_5); // Analog OUT on PA_5 1.6 V -> 0A 3.2A -> 4A (see ESCON)
altb2 0:4ed9a8952ddc 14
altb2 0:4ed9a8952ddc 15 bool key_was_pressed = false;
altb2 0:4ed9a8952ddc 16 bool controller_active = false;
altb2 0:4ed9a8952ddc 17 void pressed(void); // user Button pressed
altb2 0:4ed9a8952ddc 18 void released(void); // user Button released
altb2 1:314e2e3727f2 19
altb2 0:4ed9a8952ddc 20 //------------------------------------------
altb2 0:4ed9a8952ddc 21 // ... here define variables like gains etc.
altb2 0:4ed9a8952ddc 22 //------------------------------------------
altb2 0:4ed9a8952ddc 23 LinearCharacteristics i2u(-4.0f,4.0f,0.0f,3.2f / 3.3f); // output is normalized output
altb2 0:4ed9a8952ddc 24 //------------------------------------------
altb2 0:4ed9a8952ddc 25 Ticker ControllerLoopTimer; // interrupt for control loop
altb2 0:4ed9a8952ddc 26 EncoderCounter counter1(PB_6, PB_7); // initialize counter on PB_6 and PB_7
altb2 1:314e2e3727f2 27 Timer t_but; // define timer for button
altb2 0:4ed9a8952ddc 28 // ----- User defined functions -----------
altb2 0:4ed9a8952ddc 29 void updateLoop(void); // loop for State machine (via interrupt)
altb2 1:314e2e3727f2 30 float Ts = 0.0005f; // sample time of main loop
altb2 1:314e2e3727f2 31 uint16_t k = 0;
altb2 1:314e2e3727f2 32 PID_Cntrl dt1(0.0f,0.0f,17.3780,0.000625f,Ts,-3.0,3.0);
altb2 1:314e2e3727f2 33 PID_Cntrl pi1(1.35f,13.5f,0,1.0f,Ts,-3.0,3.0);
altb2 1:314e2e3727f2 34 PID_Cntrl pidt1(-0.0019,4.72,0.4,0.005,Ts,-3.0,3.0);
altb2 0:4ed9a8952ddc 35 //******************************************************************************
altb2 0:4ed9a8952ddc 36 //---------- main loop -------------
altb2 0:4ed9a8952ddc 37 //******************************************************************************
altb2 0:4ed9a8952ddc 38 int main()
altb2 1:314e2e3727f2 39 {
altb2 0:4ed9a8952ddc 40 pc.baud(115200); // for serial comm.
altb2 0:4ed9a8952ddc 41 counter1.reset(); // encoder reset
altb2 0:4ed9a8952ddc 42 out.write(i2u(0.0));
altb2 0:4ed9a8952ddc 43 button.fall(&pressed); // attach key pressed function
altb2 0:4ed9a8952ddc 44 button.rise(&released); // attach key pressed function
altb2 1:314e2e3727f2 45 pc.printf("Start controller now...\r\n");
altb2 1:314e2e3727f2 46 ControllerLoopTimer.attach(&updateLoop, Ts); //Assume Fs = ...;
altb2 1:314e2e3727f2 47 while(1);
altb2 0:4ed9a8952ddc 48 } // END OF main
altb2 0:4ed9a8952ddc 49 //******************************************************************************
altb2 0:4ed9a8952ddc 50 //---------- main loop (called via interrupt) -------------
altb2 0:4ed9a8952ddc 51 //******************************************************************************
altb2 0:4ed9a8952ddc 52 void updateLoop(void){
altb2 1:314e2e3727f2 53 float x = (float)(counter1)/1000.0f; // get counts from Encoder
altb2 1:314e2e3727f2 54 float i_des = 0.0f; // default: set motor current to zero (will be overwritten)
altb2 1:314e2e3727f2 55 if(controller_active)
altb2 1:314e2e3727f2 56 {
altb2 1:314e2e3727f2 57 i_des = pi1(w-x -dt1(x));
altb2 1:314e2e3727f2 58 }
altb2 1:314e2e3727f2 59 out.write(i2u(i_des));
altb2 1:314e2e3727f2 60 if(++k>1000)
altb2 0:4ed9a8952ddc 61 {
altb2 1:314e2e3727f2 62 pc.printf("x: %1.3f, i: %1.4f\r\n",x,i_des);
altb2 1:314e2e3727f2 63 k=0;
altb2 1:314e2e3727f2 64 }
altb2 0:4ed9a8952ddc 65 } // END OF updateLoop(void)
altb2 0:4ed9a8952ddc 66
altb2 0:4ed9a8952ddc 67 //******************************************************************************
altb2 0:4ed9a8952ddc 68
altb2 0:4ed9a8952ddc 69
altb2 0:4ed9a8952ddc 70 // start timer as soon as Button is pressed
altb2 0:4ed9a8952ddc 71 void pressed()
altb2 0:4ed9a8952ddc 72 {
altb2 0:4ed9a8952ddc 73 t_but.start();
altb2 0:4ed9a8952ddc 74 }
altb2 1:314e2e3727f2 75 // Falling edge of button: enable/disable controller
altb2 0:4ed9a8952ddc 76 void released()
altb2 0:4ed9a8952ddc 77 {
altb2 0:4ed9a8952ddc 78 // readout, stop and reset timer
altb2 0:4ed9a8952ddc 79 float ButtonTime = t_but.read();
altb2 0:4ed9a8952ddc 80 t_but.stop();
altb2 0:4ed9a8952ddc 81 t_but.reset();
altb2 0:4ed9a8952ddc 82 if(ButtonTime > 0.05f)
altb2 1:314e2e3727f2 83 {
altb2 1:314e2e3727f2 84 controller_active = !controller_active;
altb2 1:314e2e3727f2 85 if(controller_active)
altb2 1:314e2e3727f2 86 {
altb2 1:314e2e3727f2 87 pc.printf("Controller active\r\n");
altb2 1:314e2e3727f2 88 // reset controller here!!!
altb2 1:314e2e3727f2 89 }
altb2 1:314e2e3727f2 90 else
altb2 1:314e2e3727f2 91 pc.printf("Controller disabled\r\n");
altb2 1:314e2e3727f2 92 }
altb2 0:4ed9a8952ddc 93 }