New reference frame: y=0 is now at table height.

Dependencies:   HIDScope MODSERIAL QEI biquadFilter mbed

Fork of prog_forwardkin_feedback_copy by Elfi Hofmeijer

Revision:
28:6d8c6fe79394
Parent:
27:456e8a47f815
Child:
29:caf3dd699617
--- a/main.cpp	Wed Oct 26 20:24:58 2016 +0000
+++ b/main.cpp	Thu Oct 27 10:35:53 2016 +0000
@@ -59,12 +59,13 @@
 float L1 = 1.0;
 float L2 = 1.0;
 float TowerHeight = 0.4; //height of motor axes above table surface!
+float StampHeight = 0.1; // height of end effector
 
 //set initial conditions
 float biceps_l = 0;
 float biceps_r = 0;
 float ReferencePosition_x = L2;
-float ReferencePosition_y = L1 + TowerHeight;
+float ReferencePosition_y = L1 + TowerHeight - StampHeight;
 float ReferencePosition_xnew = 0;
 float ReferencePosition_ynew = 0;
 float Position_x = 0.0;
@@ -145,7 +146,7 @@
     */
     //get end effector position feedback with trigonometry
     Position_x = (L1*sin(q1) + L2*sin(q1+q2));
-    Position_y = (L1*cos(q1) + L2*cos(q1+q2)) + TowerHeight;  
+    Position_y = (L1*cos(q1) + L2*cos(q1+q2)) + TowerHeight - StampHeight;  
     //float PositionVector = sqrt(pow(Position_x,2)+pow(Position_y,2));
       
     //get velocity vector v = (Pe*- Pe) = [0; dx; dy] from EMG  
@@ -205,12 +206,12 @@
         ReferencePosition_ynew = ReferencePosition_y;
         }
     
-    float PointPosition_x = ReferencePosition_x;
-    float PointPosition_y = ReferencePosition_y - TowerHeight;
-    float PointVector = sqrt(pow(PointPosition_x,2)+pow(PointPosition_y,2));
+    float PointPositionArm2_x = ReferencePosition_x;
+    float PointPositionArm2_y = ReferencePosition_y - TowerHeight + StampHeight;
+    float PointVectorArm2 = sqrt(pow(PointPositionArm2_x,2)+pow(PointPositionArm2_y,2));
     
     //check position boundaries
-    if (PointVector > maxStampDistance){
+    if (PointVectorArm2 > maxStampDistance){
         ReferencePosition_x = ReferencePosition_x;
         ReferencePosition_y = ReferencePosition_y;
         }
@@ -223,10 +224,10 @@
         }
     
     //calculate reference joint angles for the new reference position
-    float alpha = atan(PointPosition_y/PointPosition_x);
-    float beta = acos((L2*L2-L1*L1-pow(PointVector,2))/(-2*L1*PointVector));
+    float alpha = atan(PointPositionArm2_y/PointPositionArm2_x);
+    float beta = acos((L2*L2-L1*L1-pow(PointVectorArm2,2))/(-2*L1*PointVectorArm2));
     q1_refOutNew = PI/2 - (alpha+beta);
-    q2_refOutNew = PI - asin(PointVector*sin(beta)/L2);
+    q2_refOutNew = PI - asin(PointVectorArm2*sin(beta)/L2);
     
     //check angle boundaries
     if (q1_refOutNew > q1_refOutMin && q1_refOutNew < q1_refOutMax){