Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: MODSERIAL USBDevice compensation_tables mbed-dsp mbed
Fork of haptic_hid by
Diff: main.cpp
- Revision:
- 3:10863117020c
- Parent:
- 2:bf29d24b69dd
- Child:
- 4:9d37f163d64c
diff -r bf29d24b69dd -r 10863117020c main.cpp
--- a/main.cpp	Mon Jan 11 12:03:23 2016 +0000
+++ b/main.cpp	Mon Jun 19 07:40:22 2017 +0000
@@ -9,11 +9,25 @@
 #include "position_sensor_error.h"
 #include "cogging_compensation.h"
 #include "main.h"
+Ticker tickObject;
+
+#include <iostream>
+
+using namespace std;
+const int n = 1000;
+int k = 0;
+int z = 0;
+int prbstest[n];
+int status;
+int statusnew;
+const int p = 2*n;
+int positievec[p];
+int q = 0;
 
 /** Main function
  * Bootstraps the system
  */
-typedef enum z_state{Z_ZERO,Z_B,Z_I,Z_K,Z_OFF}z_states;
+typedef enum z_state{/*Z_ZERO,Z_B,Z_K,Z_OFF*/Z_I,Z_NUL}z_states;
 
 void SetImpedance(float i, float b, float k, float pos)
 {
@@ -25,10 +39,10 @@
 
 void blink(void)
 {
-    static z_states localstate=Z_ZERO;
+    static z_states localstate=Z_I;
     switch(localstate)
     {
-        case Z_ZERO:
+        /*case Z_ZERO:
         {
             localstate = Z_B; //mass
             SetImpedance(0,0.03,0,position);
@@ -39,14 +53,20 @@
             localstate = Z_I; //fluid
             SetImpedance(0.0009,0.01,0.001,position);
             break;
-        }
+        }*/
         case Z_I:
         {
-            localstate = Z_K;//spring
-            SetImpedance(0,0,0.05,position);
+            localstate = Z_NUL;//spring
+            SetImpedance(0.00033,0.00033,0.0000034,0);
             break;
         }
-        case Z_K:
+        case Z_NUL:
+        {
+            localstate = Z_I;//spring
+            SetImpedance(0.00033,0.00033,0.0000034,500);
+            break;
+        }
+        /*case Z_K:
         {
             localstate = Z_OFF;
             SetImpedance(0,0,0,position);
@@ -56,15 +76,15 @@
         }
         case Z_OFF:
         {
-            localstate = Z_ZERO;
+            localstate = Z_I;
             SetImpedance(0,0.00,0,position);
             driver_enable_a = 1;
             driver_enable_b = 1;
             break;
-        }
+        }*/
         default:
         {
-            localstate = Z_ZERO;
+            localstate = Z_I;
             ZControl_I = 0;
             ZControl_B = 0;
             ZControl_K = 0;
@@ -74,24 +94,71 @@
     info_led_3 != info_led_3;
     wait_ms(300); //debounce
 }
-
+    
+void printer(){
+    int positie = GET_POSITION();
+    positievec[q] = positie;
+    cout << positievec[q] << ",";
+    q = q+1;
+    }
+     
 int main()
 {
     // Initialize system
+    //initialiseer_prbs();
     initialize_io();
     calibrate_current_sensor();
     calibrate_position();
 
-    torque_controller.attach_us(&torque_control, TORQUE_CONTROLLER_INTERVAL_US);
+    for (int i = 0; i <= n; i++) {
+        prbstest[i] = rand() % 2;
+        cout << prbstest[i] << ",";//"\r\n";
+        }
+        
+    while(z<=n){    
+        //torque_controller.attach_us(&torque_control, TORQUE_CONTROLLER_INTERVAL_US);
+        //tickObject.attach_us(&printer, 100000);
+        torque_control();
+        printer();
+        cout << z << ";\r\n";
+        z = z+1;
+        wait_us(TORQUE_CONTROLLER_INTERVAL_US);
+
+    }
 
     //send_report.length = 16;
     //recv_report.length = 16;
 
+        cout << "\r\n";
+        /*
+        for(int k=0; k <= n; k++) {
+         status = prbstest[k];
+         int kplus = k+1;
+         statusnew = prbstest[kplus];
+         if (status == statusnew){
+            //cout << "equal:\r\n";
+            //cout << status << " " << k << "\r\n";
+            //cout << statusnew << " " << kplus << "\r\n";
+            }
+         else if (status != statusnew){
+            //cout << "unequal:\r\n";
+            //cout << status << " " << k << "\r\n";
+            //cout << statusnew << " " << kplus << "\r\n";
+            blink();
+            }
+        }*/
+    cout << positievec;
+    
     while(1) {
         int32_t abspos = ABSPOS();
-
-        if(!user_btn)
+        
+        /*if(!user_btn)
             blink();
+        tickObject.attach(&blink, 5);*/
+        
+        //blink();
+        //wait(1);  
+        
         //send_report.data[3] = abspos & 0x000000ff;
         //send_report.data[2] = (abspos & 0x0000ff00) >> 8;
         //send_report.data[1] = (abspos & 0x00ff0000) >> 16;
@@ -116,10 +183,19 @@
         info_led_3 = !info_led_3;
         wait(0.01);
     }
-
     return 0;
 }
 
+/*//create a prbs signal
+void initialiseer_prbs() {
+    int prbstest[n] = {};
+
+    for (int i = 0; i <= n; i++) {
+        prbstest[i] = rand() % 2;
+        cout << prbstest[i];
+    }
+}*/
+
 /** Sample the current sensor to determine the offset
  */
 void calibrate_current_sensor()
@@ -165,7 +241,7 @@
 {
     user_btn.mode(PullUp);
     //user_btn.rise(blink);
-    pc.baud(115200);
+    pc.baud(9600);
     spi.format(14,3);
     driver_1a.period_us(33);
     driver_2a.period_us(33);
@@ -218,7 +294,14 @@
     position_cos    = arm_cos_f32(position_theta);
 
     // Impedance controller...
-    torque = -ZControl_K*0.00076699f*(ABSPOS()-ZControl_RefPos) - ZControl_B*speed - ZControl_I*acceleration;
+    if(prbstest[z] == 1){
+        torque = -0.1;//-ZControl_K*0.00076699f*(ABSPOS()-ZControl_RefPos) - ZControl_B*speed - ZControl_I*acceleration;
+        cout << torque << ",";//"\r\n";
+        }
+    else if(prbstest[z] == 0){
+        torque = 0.1;
+        cout << torque << ",";//"\r\n";
+        }
 
     // Preprocess torque command
     torque_setpoint = (torque > TORQUE_LIMIT) ? TORQUE_LIMIT : (torque < -TORQUE_LIMIT ? -TORQUE_LIMIT : torque);
    