robot

Dependencies:   Encoder HIDScope MODSERIAL TouchButton mbed-dsp mbed

Fork of Robot2false by BMT M9 Groep01

Revision:
24:a165dcd86710
Parent:
23:8f7ce4894c58
Child:
25:b58e10cbd35b
Child:
30:28be2bf11ad7
--- a/main.cpp	Fri Oct 31 14:33:13 2014 +0000
+++ b/main.cpp	Fri Oct 31 14:54:49 2014 +0000
@@ -9,6 +9,9 @@
 #define K_I (0.02  *TSAMP1)
 #define K_D (0  /TSAMP1)
 #define I_LIMIT 1.
+#define K_Pp (0.2)
+#define K_Ip (0.02  *TSAMP1)
+#define K_Dp (0  /TSAMP1)
 
 #define TSAMP1 0.01
 #define TSAMP2 0.01
@@ -24,6 +27,7 @@
 void Calibratie_Triceps();
 void Calibratie_Biceps();
 float pid(float setspeed, float measurement, bool reset = false);
+float pidpositie(float setposition, float measurement);
 void motor2aansturing();
 void motor1aansturing();
 void motor1aansturingdeel2();
@@ -78,14 +82,13 @@
 bool stop;
 float new_pwm;
 float PWM2 = 0.3; //PWM voor instellen hoek batje
-int toestand = TERUGKEREN;
+int toestand = WACHTEN; //terugkeren?
 float setspeed = 0, V3=60, V2=40, V1 =30, Vreturn= 35;//V in counts/s
 
 
-//Encoder motor1(PTD5,PTD3); //actual
-//Encoder motor2(PTD0,PTD2);
-//Encoder motor1(PTD5,PTD3);
-//Encoder motor2(PTD0,PTD2);
+Encoder motor1(PTD5,PTD3);
+Encoder motor2(PTD0,PTD2);
+
 DigitalOut motordir1(PTA4);
 DigitalOut motordir2(PTC9);
 PwmOut pwm_motor1(PTA5);
@@ -426,6 +429,21 @@
     return out_p + out_i + out_d;
 }
 
+float pidpositie(float setposition, float measurement)
+{
+    float error;
+    static float prev_error = 0;
+    float           out_p = 0;
+    static float    out_i = 0;
+    float           out_d = 0;
+    error  = setspeed-measurement;
+    out_p  = error*K_Pp;
+    out_i += error*K_Ip;
+    out_d  = (error-prev_error)*K_Dp;
+    prev_error = error;
+    return out_p + out_i + out_d;
+}
+
 void Triceps()
 {
     //Triceps lezen
@@ -629,8 +647,6 @@
 
     if (motor1.getPosition()>= ANGLEMIN && toestand != SLAAN) {
         toestand = WACHTEN;
-        //motor1.setPosition(0);
-        pid(0,0,true);
         pc.printf("if1\n");
     }
     if (snelheidsstand != 0 && toestand == WACHTEN && stop == 0) { // stop = 0 in het begin let op dat dit na reset nog zo is
@@ -653,11 +669,12 @@
         toestand = TERUGKEREN;
         //motor1.setPosition(0);
         pwm_motor1.write(0);
-        pid(0,0,true);
+        //pid(0,0,true);
         stop = 1; //zorgt dat hij niet weer gaat slaan tot er gereset is...
         pc.printf("toestand = terugkeren\n\r");
     }
     if (toestand == WACHTEN) {
+        pidpositie(ANGLEMIN, motor1.getPosition());
         pwm_motor1.write(0);
         pc.printf("ifwachten\n");
     }
@@ -666,6 +683,10 @@
         pwm_motor1.write(new_pwm);
         motordir1 = 1;
         pc.printf("SLAAN\n");
+        
+    if (toestand == TERUGKEREN) {
+        pidpositie(ANGLEMAX, motor1.getPosition());
+        }
 
 
         /*if (toestand == TERUGKEREN) {
@@ -686,7 +707,7 @@
     if (motor1.getPosition()>= ANGLEMIN && toestand != SLAAN) {
         toestand = WACHTEN;
         //motor1.setPosition(0);
-        pid(0,0,true);
+        //pid(0,0,true);
         //pc.printf("if2\n");
     }
     if (toestand == TERUGKEREN) {
@@ -698,6 +719,7 @@
     }
     if (toestand == WACHTEN) {
         pwm_motor1.write(0);
+        pidpositie(ANGLEMIN, motor1.getPosition());
         //pc.printf("ifwachten2\n");
     }
     //sturen naar HID Scope