EMG added to main IK program. No errors, not yet tested

Dependencies:   HIDScope MODSERIAL QEI biquadFilter mbed

Fork of prog_forwardkin_feedback_copy3 by Gerhard Berman

Revision:
35:a21c1cab8086
Parent:
34:96bcbddc7d2d
Child:
36:a700f64ba747
diff -r 96bcbddc7d2d -r a21c1cab8086 main.cpp
--- a/main.cpp	Tue Nov 01 13:45:31 2016 +0000
+++ b/main.cpp	Tue Nov 01 15:47:40 2016 +0000
@@ -57,7 +57,7 @@
 const int cw = 0;       //values for cw and ccw are inverted!! cw=0 and ccw=1
 const int ccw = 1;
 
-//set lengths (VALUES HAVE TO BE CHANGED)
+//set lengths and constants (VALUES HAVE TO BE CHANGED)
 float x0 = 1.0;
 float L0 = 1.0;
 float L1 = 1.0;
@@ -67,7 +67,6 @@
 float y_stampup = 0.1;      //height stamp while not stamping: 10cm above table surface
 float y_stampdown = 0.0;    //height stamp while stamping: at table surface
 
-
 //set initial conditions
 float biceps_l = 0;
 float biceps_r = 0;
@@ -107,6 +106,10 @@
 float MotorGain = 8.4; // rad/s for PWM, is max motor speed (motor value of 1)
 float t_sample = 0.1; //seconds
 const float maxStampDistance = 2.0;
+float Kp = 3; //potMeter2.read();
+float Ki = 0.2*Kp;  //0.01*Kp; //potMeter2.read();
+float Kd = 0.05;     //0.1;(unstable!) //0.05; //0.02;        //0.04*Kp; //potMeter2.read();
+float N = 100; //N=1/Tf, Higher N is faster derivative action but more sensitive to noise.
 
 float q1_refOutNew = 0;
 float q1_refOutMin = -100;         //WRONG values
@@ -122,6 +125,7 @@
 BiQuadChain bqc;
 BiQuad bq1(0.0186,    0.0743,    0.1114,    0.0743,    0.0186); //get numbers from butter filter MATLAB
 BiQuad bq2(1.0000,   -1.5704,    1.2756,   -0.4844,    0.0762);
+BiQuad pidf;        //for lowpass filtering of PID controller
 
 //set go-Ticker settings
 volatile bool MeasureTicker_go=false, BiQuadTicker_go=false, FeedbackTicker_go=false, TimeTracker_go=false; // sampleT_go=false;
@@ -211,7 +215,7 @@
         //led1 = 0;
         //led2 = 0;
         ReferencePosition_xnew = ReferencePosition_x;
-        ReferencePosition_ynew = ReferencePosition_y;   //y_stampup; 
+        ReferencePosition_ynew = y_stampup; //ReferencePosition_y;
         }
       //  }
     
@@ -286,17 +290,17 @@
     // linear feedback control
     float q1_error = q1_ref - q1; //referencePosition1 - Position1;             // proportional angular error in radians
     float q2_error = q2_ref - q2; //referencePosition1 - Position1;             // proportional angular error in radians
-    float Kp = 3; //potMeter2.read();
-
+    
+    float TotalError1 = pidf.step(q1_error);
+    float TotalError2 = pidf.step(q2_error);
+    
     float q1IntError = q1IntError + q1_error*t_sample;             // integrated error in radians
     float q2IntError = q2IntError + q2_error*t_sample;             // integrated error in radians
     //float maxKi = 0.2;
-    float Ki = 0.04*Kp;  //0.01*Kp; //potMeter2.read();
     
     float q1DerivativeError = (q1_error - q1_error_prev)/t_sample;  // derivative of error in radians
     float q2DerivativeError = (q2_error_prev + q2_error)/t_sample;  // derivative of error in radians
     //float maxKd = 0.2;
-    float Kd = 0.0;  //0.04*Kp; //potMeter2.read();
     
     //scope.set(0,referencePosition1);
     //scope.set(1,Position1);
@@ -307,20 +311,6 @@
     TotalError2 = q2_error * Kp + q2IntError * Ki + q2DerivativeError * Kd;         //total controller output in radians = motor input
     
     /*
-    if (fabs(TotalError1) < TotalErrorMin) {
-        TotalError1=0;
-        }
-    else {
-        TotalError1=TotalError1;
-        }
-    if (fabs(TotalError2) < TotalErrorMin) {
-        TotalError2=0;
-        }
-    else {
-        TotalError2=TotalError2;
-        }
-    */
-    /*
     DerTotalError1 = (TotalError1 - TotalError1_prev)/t_sample;
     DerTotalError1 = (TotalError1 - TotalError1_prev)/t_sample;
     motorValue1Out = DerTotalError1/MotorGain;       
@@ -441,8 +431,8 @@
  pc.baud(115200);
  pc.printf("Test putty IK");
  MeasureTicker.attach(&MeasureTicker_act, 0.1f); 
- bqc.add(&bq1).add(&bq2);
- 
+ bqc.add(&bq1).add(&bq2);           //set BiQuad chain
+ pidf.PIDF( Kp, Ki, Kd, N, t_sample );    //set PID filter
  while(1)
     {
         if (MeasureTicker_go){