Corrected header file include guards.

Dependencies:   FiniteStateMachine HipControl Knee LinearBlend1 LocalFileSystem_Read dataComm hapticFeedback initExoVars mbed Blend_Generator Brad_poly_gait Gait_Generator MM_gait Encoders IMUdriver

Fork of Motion Control by HEL's Angels

Committer:
mzling
Date:
Wed May 06 17:14:00 2015 +0000
Revision:
24:2e56d3bebb24
Parent:
23:e0923403be2f
Child:
25:1292b886b8d2
Added gaitEquations

Who changed what in which revision?

UserRevisionLine numberNew contents of line
perr1940 0:d38d627c922f 1 /**************************************
perr1940 0:d38d627c922f 2 This is the main file for the "RyanEXO" control software.
perr1940 0:d38d627c922f 3 This sets up the main control loop that operates at a 1kHz frequency
perr1940 0:d38d627c922f 4 and controls the flow of the rest of the software
perr1940 0:d38d627c922f 5
perr1940 0:d38d627c922f 6 The configuration for the exo system that this software runs:
perr1940 0:d38d627c922f 7 amplifiers: 2 Copley Controls 10A digital amplifiers
perr1940 0:d38d627c922f 8 sensors: 2 Austria Microsystems 12 bit magnetic encoders, handled by encoders.h
perr1940 0:d38d627c922f 9 motors: 2 maxon EC90 DC brushless motors, handled by HipMotorControl.h (called in FSM.h)
perr1940 0:d38d627c922f 10 Knees: wrap spring clutch controlled by Firgelli PQ12P linear actuators, controlled in linearActuatorControl.h
cashdollar 3:9719ad064a2c 11 **************************************/
perr1940 0:d38d627c922f 12
perr1940 0:d38d627c922f 13 #include "mbed.h"
perr1940 0:d38d627c922f 14 #include "initExoVars.h"
perr1940 0:d38d627c922f 15 #include "FSM.h"
perr1940 2:89b78367d173 16 #include "dataBedComm.h"
mzling 13:c588cb388240 17 #include "dataComm.h"
mzling 18:03d7c5fdc0c7 18 short dataIn[7];
mzling 24:2e56d3bebb24 19 /** DataOut: Indices 0,1,2,and 8 are reserved. 0 is start byte, 8 is end byte, 1 and 2 are error codes.
mzling 24:2e56d3bebb24 20 Other indices can be used for read angles */
mzling 21:715c8cf78e14 21 short dataOut[]={0xFF,30,31,0, 0, 0, 0, 0, 0xFE};
mzling 18:03d7c5fdc0c7 22 dataComm dc = dataComm();
mzling 18:03d7c5fdc0c7 23 Timer dbg;
mzling 15:3596b7ca1c20 24
perr1940 0:d38d627c922f 25 ///////////////////////////////////////////////////////////////////////////
cashdollar 3:9719ad064a2c 26
cashdollar 3:9719ad064a2c 27 // periodicFcns runs at the start of every control loop cycle
cashdollar 3:9719ad064a2c 28 // It initiates communication with dataBed, checks for errors/safety, and starts the FSM
mzling 23:e0923403be2f 29
mzling 24:2e56d3bebb24 30
mzling 24:2e56d3bebb24 31
perr1940 0:d38d627c922f 32 void periodicFcns()
perr1940 0:d38d627c922f 33 {
mzling 18:03d7c5fdc0c7 34 dbg.reset();
mzling 24:2e56d3bebb24 35 //dataOut[1]=encoder_L.readRaw();
mzling 20:cf8e99d989a6 36 float f1 = encoder_L.read_angle();
mzling 20:cf8e99d989a6 37 float f2 = fsm.read_angle_y();
mzling 24:2e56d3bebb24 38
mzling 24:2e56d3bebb24 39 /** Multiplying by 91 allows casting float to short without losing too much precision
mzling 24:2e56d3bebb24 40 * Assuming angles range from -360 to 360, 91 is the max factor that guarantees we will not overflow
mzling 24:2e56d3bebb24 41 */
mzling 23:e0923403be2f 42 short s1 = (short)(f1*91);
mzling 23:e0923403be2f 43 short s2 = (short)(f2*91);
mzling 24:2e56d3bebb24 44 dataOut[3] = s1;
mzling 24:2e56d3bebb24 45 dataOut[4] = s2;
mzling 24:2e56d3bebb24 46 //pc.printf("1:%f %d\r\n", f1, dataOut[3]);
mzling 24:2e56d3bebb24 47 //pc.printf("2:%f %d\r\n", f2, dataOut[4]);
mzling 18:03d7c5fdc0c7 48 //dataOut[2]=fsm.error();
mzling 18:03d7c5fdc0c7 49 short* ptr=dataIn;
mzling 21:715c8cf78e14 50 ptr=sendData(dataOut, 9, dataIn);
mzling 24:2e56d3bebb24 51 if (dataIn[1] != 0) {
mzling 24:2e56d3bebb24 52 pc.printf("UI: %d\r\n", dataIn[1]);
mzling 18:03d7c5fdc0c7 53 }
mzling 21:715c8cf78e14 54 dc.process_write(dataIn+2, 7);
perr1940 7:d44555be84b7 55 //pc.printf("%d, %d, %d, %d,", dataIn[0], dataIn[1], dataIn[2], dataIn[3]);
mzling 18:03d7c5fdc0c7 56
cashdollar 3:9719ad064a2c 57 // Run state change/analysis in FSM
mzling 17:b77c31807825 58 int exoState=fsm.state(dataIn[1]);
mzling 18:03d7c5fdc0c7 59 float temp=dbg.read_us();
mzling 21:715c8cf78e14 60 //pc.printf("%f\r\n",temp);
mzling 18:03d7c5fdc0c7 61
perr1940 0:d38d627c922f 62 }
perr1940 0:d38d627c922f 63
mzling 20:cf8e99d989a6 64 //Starts the Exo controlbed, and processes messages by repeatedly executing periodicFcns
perr1940 0:d38d627c922f 65 int main()
perr1940 0:d38d627c922f 66 {
cashdollar 5:498c9bfc56f0 67 pc.printf("\r\nExoStart \r\n");
perr1940 0:d38d627c922f 68 initializeExoIOs();
mzling 18:03d7c5fdc0c7 69 //pc.printf("Test\r\n"); // keep for debugging compile errors
mzling 20:cf8e99d989a6 70 mbedLED1 = 1;
perr1940 0:d38d627c922f 71 pc.printf("Starting exo...\n\r");
perr1940 0:d38d627c922f 72 //If desired, a startup sound can be played. This function is defined in the DatabedCode, because it will command a sound to be played once it detects a heartbeat from ControlBed
perr1940 0:d38d627c922f 73 wait(2);
mzling 18:03d7c5fdc0c7 74 dbg.start();
perr1940 0:d38d627c922f 75 Ticker doControl;
mzling 14:8929f5a9837c 76 dataBedSPI.format(16,0);
perr1940 0:d38d627c922f 77 doControl.attach(&periodicFcns, SAMPLE_TIME);
perr1940 0:d38d627c922f 78
mzling 18:03d7c5fdc0c7 79 while (1);
perr1940 0:d38d627c922f 80 }