![](/media/cache/img/default_profile.jpg.50x50_q85.jpg)
rrr
main.cpp
- Committer:
- ChengHan
- Date:
- 2018-12-19
- Revision:
- 12:a197e7eed8ab
- Parent:
- 11:cd28cb84fd81
File content as of revision 12:a197e7eed8ab:
#include "mbed.h" //不用gyro的data,只要輸出兩個imu的acce的xyz資料即可 #include "encoder.h" //#include "Mx28.h" //#include "PID.h" #include "LSM9DS1.h" //********************* Dynamxiel ****************************** #define SERVO_ID 0x01 // ID of which we will set Dynamixel too #define SERVO_ControlPin A2 // Control pin of buffer chip, NOTE: this does not matter becasue we are not using a half to full contorl buffer. #define SERVO_SET_Baudrate 1000000 // Baud rate speed which the Dynamixel will be set too (1Mbps) #define TxPin A0 #define RxPin A1 #define CW_LIMIT_ANGLE 1 // lowest clockwise angle is 1, as when set to 0 it set servo to wheel mode #define CCW_LIMIT_ANGLE 4095 // Highest anit-clockwise angle is 0XFFF, as when set to 0 it set servo to wheel mode #define _PI 3.14159265f //*************************************************************** Serial uart(USBTX, USBRX); //Serial uart(D10,D2); // TX : D10 RX : D2 // bluetooth AnalogIn EMG(PC_3); // /*IMU*******************************************************************/ LSM9DS1 imu(D14, D15); //SDA SCL //LSM9DS1 imu2(PC_9,PA_8); //SDA SCL void init_IMU(); int16_t Gyro_axis_data[6] = {0}; // X, Y, Z axis int16_t Acce_axis_data[6] = {0}; // X, Y, Z axis float Acce_axis_data_f[6] = {0}; //_f代表經過低通濾波的資料 float Acce_axis_data_old[6] = {0}; float Acce_axis_data_f_old[6] = {0}; float Gyro_axis_data_f[6] = {0}; float Gyro_axis_data_old[6] = {0}; float Gyro_axis_data_f_old[6] = {0}; // Timer Ticker timer1; float ITR_time1 = 4000.0; //timer interrupt unit:us 多少us計時一次 4毫秒 float Ts = ITR_time1/1000000; //控馬達的某個時間參數 不用理他 // EMG float lpf(float input, float input_old, float output_old, float frequency); //low pass filter float emg_value; float emg_value_f; float emg_value_f_old; float emg_value_old; float Tf = ITR_time1/1000000; // 低通濾波的採樣週期 // uart_tx union splitter { //將data切割為兩個byte short j; char C[2]; // C[0] is lowbyte of j, C[1] is highbyte of j }; uint8_t T[16] = {255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; // T[16]中的16是2+14,2為start btye 255 255,14為要傳7個參數到電腦,拆成high byte和low byte,所以是7*2=14 // 若要更改傳到電腦的參數個數,則改x*2=y,x為要傳的參數個數,y為char T[]裡面要有多少個0 int i = 0; // function void init_UART(); //void init_TIMER(); //void timer1_ITR(); void uart_tx(); // 傳data到電腦 /**************************************************************************/ int main() { // wait_ms(500); // initial sensor init_SPI_encoder(); init_encoder(); init_UART(); init_IMU(); // init_TIMER(); while(1) { // EMG emg_value = EMG.read(); emg_value_f = lpf(emg_value,emg_value_old,emg_value_f_old,15); emg_value_f_old = emg_value_f; emg_value_old = emg_value; // IMU imu.readAccel(); imu.readGyro(); // imu2.readAccel(); // imu2.readGyro(); Acce_axis_data[0] = imu.ax*Acce_gain_x; Acce_axis_data[1] = imu.ay*Acce_gain_y; Acce_axis_data[2] = imu.az*Acce_gain_z; // Acce_axis_data[3] = -imu2.ax*Acce_gain_x_2; // Acce_axis_data[4] = imu2.az*Acce_gain_y_2; // Acce_axis_data[5] = imu2.ay*Acce_gain_z_2; Gyro_axis_data[0] = imu.gx*Gyro_gain_x; Gyro_axis_data[1] = imu.gy*Gyro_gain_y; Gyro_axis_data[2] = imu.gz*Gyro_gain_z; // Gyro_axis_data[3] = -imu2.gx*Gyro_gain_x_2; // Gyro_axis_data[4] = imu2.gz*Gyro_gain_y_2; // Gyro_axis_data[5] = imu2.gy*Gyro_gain_z_2; for(i=0; i<6; i++) { Acce_axis_data_f[i] = lpf(Acce_axis_data[i],Acce_axis_data_old[i],Acce_axis_data_f_old[i],15); Acce_axis_data_old[i] = Acce_axis_data[i]; // input_old Acce_axis_data_f_old[i] = Acce_axis_data_f[i]; // output_old Gyro_axis_data_f[i] = lpf(Gyro_axis_data[i], Gyro_axis_data_old[i], Gyro_axis_data_f_old[i],15); Gyro_axis_data_old[i] = Gyro_axis_data[i]; Gyro_axis_data_f_old[i] = Gyro_axis_data_f[i]; } // uart.printf("x: %.4f, y: %.4f, z: %.4f\n\r", imu.ax, imu.ay, imu.az); uart_tx(); // wait_ms(500); } } void init_IMU() { imu.begin(imu.G_SCALE_245DPS,imu.A_SCALE_2G,imu.M_SCALE_4GS,imu.G_ODR_238_BW_14,imu.A_ODR_119,imu.M_ODR_0625); //imu.G_SCALE_245DPS,imu.A_SCALE_2G,imu.M_SCALE_4GS,imu.G_ODR_238_BW_14,imu.A_ODR_119,imu.M_ODR_0625 // imu2.begin(imu.G_SCALE_500DPS,imu.A_SCALE_2G,imu.M_SCALE_4GS,imu.G_ODR_476_BW_21,imu.A_ODR_476,imu.M_ODR_0625); uart.printf("IMU init success\n\r"); } void init_UART() { uart.baud(115200); } //void init_TIMER() //{ // timer1.attach_us(&timer1_ITR, ITR_time1); //} //void timer1_ITR() //開始讀取資料 //{ // EMG //emg_value = EMG.read(); // emg_value_f = lpf(emg_value,emg_value_f_old,15); // emg_value_f_old = emg_value_f; // IMU // imu.readAccel(); // imu.readGyro(); // imu2.readAccel(); // imu2.readGyro(); //Acce_axis_data[0] = imu.ax*Acce_gain_x; // Acce_axis_data[1] = imu.ay*Acce_gain_y; // Acce_axis_data[2] = imu.az*Acce_gain_z; // Acce_axis_data[3] = -imu2.ax*Acce_gain_x_2; // Acce_axis_data[4] = imu2.az*Acce_gain_y_2; // Acce_axis_data[5] = imu2.ay*Acce_gain_z_2; //Gyro_axis_data[0] = imu.gx*Gyro_gain_x; // Gyro_axis_data[1] = imu.gy*Gyro_gain_y; // Gyro_axis_data[2] = imu.gz*Gyro_gain_z; // Gyro_axis_data[3] = -imu2.gx*Gyro_gain_x_2; // Gyro_axis_data[4] = imu2.gz*Gyro_gain_y_2; // Gyro_axis_data[5] = imu2.gy*Gyro_gain_z_2; //for(i=0; i<6; i++) { // Acce_axis_data_f[i] = lpf(Acce_axis_data[i],Acce_axis_data_f_old[i],15); // Acce_axis_data_f_old[i] = Acce_axis_data_f[i]; // Gyro_axis_data_f[i] = lpf(Gyro_axis_data[i],Gyro_axis_data_f_old[i],15); // Gyro_axis_data_f_old[i] = Gyro_axis_data_f[i]; // } // uart.printf("x: %7.4f, y: %7.4f, z: %7.4f\n\r",imu.ax, imu.ay, imu.az); //uart_tx(); // wait_ms(1); //} void uart_tx() //分割資料 { splitter s1; splitter s2; splitter s3; splitter s4; splitter s5; splitter s6; splitter s7; // splitter s8; s1.j = Acce_axis_data_f[0]; // 0x6161;// s2.j = Acce_axis_data_f[1]; s3.j = Acce_axis_data_f[2]; s4.j = Acce_axis_data_f[3]; s5.j = Acce_axis_data_f[4]; s6.j = Acce_axis_data_f[5]; s7.j = emg_value_f; // s8.j = 1; // 若要傳的參數不足8個,則隨意打一個常數即可 T[2] = s1.C[0]; T[3] = s1.C[1]; T[4] = s2.C[0]; T[5] = s2.C[1]; T[6] = s3.C[0]; T[7] = s3.C[1]; T[8] = s4.C[0]; T[9] = s4.C[1]; T[10] = s5.C[0]; T[11] = s5.C[1]; T[12] = s6.C[0]; T[13] = s6.C[1]; T[14] = s7.C[0]; T[15] = s7.C[1]; uart.putc(T[0]); uart.putc(T[1]); uart.putc(T[2]); uart.putc(T[3]); uart.putc(T[4]); uart.putc(T[5]); uart.putc(T[6]); uart.putc(T[7]); uart.putc(T[8]); uart.putc(T[9]); uart.putc(T[10]); uart.putc(T[11]); uart.putc(T[12]); uart.putc(T[13]); uart.putc(T[14]); uart.putc(T[15]); // while(1) { //開始傳到USB // if (uart.writeable() == 1) { // uart.putc(T[i]); // i++; // } // if (i >= sizeof(T)) { // i = 0; // break; // } // } } float lpf(float input, float input_old, float output_old, float frequency) { float output = 0; float a = frequency*Tf; output = ((a+2)*output_old + a*input + a*input_old)/(3*a+2); return output; } //有估測器有delay,丟資料給機器學習時就不是及時動作,所以之後決定直接丟資料