FSG / IMU_code_

Fork of IMU_code_7_14 by Troy Holley

Committer:
tnhnrl
Date:
Mon Jul 17 14:23:51 2017 +0000
Revision:
2:b00adea2187b
Parent:
1:0672f84101e4
Child:
3:232de5807dac
7_14_17 commit
;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mdavis30 0:22fc81041056 1 #include "IMU_code.h" //include your header file
mdavis30 0:22fc81041056 2
mdavis30 0:22fc81041056 3 #include "MODSERIAL.h"
mdavis30 0:22fc81041056 4 Serial IMU(p13,p14); //tx, rx for IMU
mdavis30 1:0672f84101e4 5
mdavis30 0:22fc81041056 6 //FUNCTION DECLARATION for what is used below in IMU
mdavis30 0:22fc81041056 7 double double_from_le_bytes(unsigned char * p_to_double);
mdavis30 0:22fc81041056 8 float float_from_le_bytes(unsigned char * p_to_float);
mdavis30 0:22fc81041056 9
mdavis30 1:0672f84101e4 10 const double GRAVITY = 9.80665; //new placement 6/22/2017
mdavis30 1:0672f84101e4 11 float stab_accel[3];
mdavis30 1:0672f84101e4 12
mdavis30 0:22fc81041056 13 #include <string> //FOR STRINGS
mdavis30 0:22fc81041056 14 using namespace std;
mdavis30 0:22fc81041056 15
mdavis30 0:22fc81041056 16 //constructor (blank)
mdavis30 0:22fc81041056 17 IMU_code::IMU_code()
mdavis30 0:22fc81041056 18 {
mdavis30 0:22fc81041056 19 }
mdavis30 0:22fc81041056 20
mdavis30 0:22fc81041056 21 //functions
mdavis30 0:22fc81041056 22 string IMU_code::IMU_run()
mdavis30 0:22fc81041056 23 {
mdavis30 0:22fc81041056 24 unsigned char current, last, cb1=0, cb2=0, data[MAXPACKETSIZE];
mdavis30 0:22fc81041056 25 int packetlength=MAXPACKETSIZE; //Redefined for each packet payod length below
mdavis30 0:22fc81041056 26 int mode=0,count=0;
mdavis30 0:22fc81041056 27 //Field length for IMU data (always 0x0E)
mdavis30 0:22fc81041056 28 unsigned char fieldlength=0x0E;
mdavis30 0:22fc81041056 29 unsigned char descripts[NUMDESCRIPTS];
mdavis30 0:22fc81041056 30 //GPS Correlation Timestamp (0x0e,0x12)
mdavis30 0:22fc81041056 31 double timestamp;
mdavis30 0:22fc81041056 32 descripts[0]=0x12;
mdavis30 0:22fc81041056 33 //Delta Theta Vector (0x0e,0x07)
mdavis30 0:22fc81041056 34 float delta_theta[3];
mdavis30 0:22fc81041056 35 int dt_pos;
mdavis30 0:22fc81041056 36 descripts[1]=0x07;
mdavis30 0:22fc81041056 37 //Delta Velocity Vector (0x0e,0x08)
mdavis30 0:22fc81041056 38 float delta_vel[3];
mdavis30 0:22fc81041056 39 int dv_pos;
mdavis30 0:22fc81041056 40 descripts[2]=0x08;
mdavis30 0:22fc81041056 41 //CF Stablized Accel Vector (up) (0x0e,0x11)
mdavis30 1:0672f84101e4 42 //float stab_accel[3]; //TROY: I MADE THIS GLOBAL 6/22/17
mdavis30 0:22fc81041056 43 int sa_pos;
mdavis30 0:22fc81041056 44 descripts[3]=0x0c;
mdavis30 0:22fc81041056 45 //If adding/removing stuff, change NUMDESCRIPTS above
mdavis30 0:22fc81041056 46 IMU.baud(9600);
mdavis30 0:22fc81041056 47 current=0;
mdavis30 0:22fc81041056 48 last=0;
mdavis30 1:0672f84101e4 49 //PC.printf("I'm alive\n");
mdavis30 0:22fc81041056 50
mdavis30 0:22fc81041056 51 std::string imu_string = "";
mdavis30 0:22fc81041056 52
mdavis30 0:22fc81041056 53 while(1)
mdavis30 0:22fc81041056 54 {
mdavis30 0:22fc81041056 55 if(IMU.readable()>0)
mdavis30 0:22fc81041056 56 {
mdavis30 1:0672f84101e4 57 //PC.printf("IMU readable");
mdavis30 0:22fc81041056 58 last=current;
mdavis30 0:22fc81041056 59 current=IMU.getc();
mdavis30 0:22fc81041056 60 if(mode==0&&current==0x65&&last==0x75)
mdavis30 0:22fc81041056 61 {
mdavis30 0:22fc81041056 62 mode=1;
mdavis30 0:22fc81041056 63 data[0]=last;
mdavis30 0:22fc81041056 64 data[1]=current;
mdavis30 0:22fc81041056 65 cb1=last;
mdavis30 0:22fc81041056 66 cb2=last;
mdavis30 0:22fc81041056 67 cb1+=current;
mdavis30 0:22fc81041056 68 cb2+=cb1;
mdavis30 0:22fc81041056 69 count=2;
mdavis30 0:22fc81041056 70 }
mdavis30 0:22fc81041056 71 else
mdavis30 0:22fc81041056 72 {
mdavis30 0:22fc81041056 73 //Packet length is header (4) + payload length (varies) + Checksum (2)
mdavis30 0:22fc81041056 74 if(count==3) //payload length is byte 3
mdavis30 0:22fc81041056 75 packetlength=current+6;
mdavis30 0:22fc81041056 76 //Read in packet length worth of bytes (includes Checksum)
mdavis30 0:22fc81041056 77 if(count<packetlength)
mdavis30 0:22fc81041056 78 {
mdavis30 0:22fc81041056 79 //PC.printf("%02x ",current);
mdavis30 0:22fc81041056 80 if(count<packetlength-2)
mdavis30 0:22fc81041056 81 {
mdavis30 0:22fc81041056 82 cb1+=current;
mdavis30 0:22fc81041056 83 cb2+=cb1;
mdavis30 0:22fc81041056 84 }
mdavis30 0:22fc81041056 85 data[count]=current;
mdavis30 0:22fc81041056 86 count++;
mdavis30 0:22fc81041056 87 }
mdavis30 0:22fc81041056 88 //Process packet! But only if checksums match
mdavis30 0:22fc81041056 89 if(count==packetlength&&data[packetlength-2]==cb1&&data[packetlength-1]==cb2)
mdavis30 0:22fc81041056 90 {
mdavis30 0:22fc81041056 91 //PC.printf("Are you processing the packet?");
mdavis30 0:22fc81041056 92 for(int i=0;i<NUMDESCRIPTS;i++)
mdavis30 0:22fc81041056 93 {
mdavis30 0:22fc81041056 94 count=4;
mdavis30 0:22fc81041056 95 //Search data vector for each subtopic
mdavis30 0:22fc81041056 96 while(count<packetlength-1)
mdavis30 0:22fc81041056 97 {
mdavis30 0:22fc81041056 98 if(data[count]==fieldlength&&data[count+1]==descripts[i])
mdavis30 0:22fc81041056 99 {
mdavis30 0:22fc81041056 100 if(i==0)
mdavis30 0:22fc81041056 101 timestamp=double_from_le_bytes(&data[count+2]);
mdavis30 0:22fc81041056 102 else if(i==1)
mdavis30 0:22fc81041056 103 {
mdavis30 0:22fc81041056 104 delta_theta[0]=float_from_le_bytes(&data[count+2+0])*SAMPLE_RATE;
mdavis30 0:22fc81041056 105 delta_theta[1]=float_from_le_bytes(&data[count+2+4])*SAMPLE_RATE;
mdavis30 0:22fc81041056 106 delta_theta[2]=float_from_le_bytes(&data[count+2+8])*SAMPLE_RATE;
mdavis30 0:22fc81041056 107 dt_pos=count+2;
mdavis30 0:22fc81041056 108 }
mdavis30 0:22fc81041056 109 else if(i==2)
mdavis30 0:22fc81041056 110 {
mdavis30 0:22fc81041056 111 delta_vel[0]=float_from_le_bytes(&data[count+2+0])*SAMPLE_RATE*GRAVITY;
mdavis30 0:22fc81041056 112 delta_vel[1]=float_from_le_bytes(&data[count+2+4])*SAMPLE_RATE*GRAVITY;
mdavis30 0:22fc81041056 113 delta_vel[2]=float_from_le_bytes(&data[count+2+8])*SAMPLE_RATE*GRAVITY;
mdavis30 0:22fc81041056 114 dv_pos=count+2;
mdavis30 0:22fc81041056 115 }
mdavis30 0:22fc81041056 116 else if(i==3)
mdavis30 0:22fc81041056 117 {
mdavis30 0:22fc81041056 118 stab_accel[0]=float_from_le_bytes(&data[count+2+0])*57.3;//*GRAVITY;
mdavis30 0:22fc81041056 119 stab_accel[1]=float_from_le_bytes(&data[count+2+4])*57.3;//GRAVITY;
mdavis30 0:22fc81041056 120 stab_accel[2]=float_from_le_bytes(&data[count+2+8])*57.3;//*GRAVITY;
mdavis30 0:22fc81041056 121 sa_pos=count+2;
mdavis30 0:22fc81041056 122 }
mdavis30 0:22fc81041056 123 count=packetlength;
mdavis30 0:22fc81041056 124 }
mdavis30 0:22fc81041056 125 count++;
mdavis30 0:22fc81041056 126 }
mdavis30 0:22fc81041056 127 }
mdavis30 0:22fc81041056 128 timestamp=double_from_le_bytes(&data[6]);
mdavis30 0:22fc81041056 129 //Relevant data to send back to ground station
mdavis30 1:0672f84101e4 130 //PC.printf("\nT: %f SA:(%d) Roll: %9.6f Pitch: %9.6f Yaw:%9.6f\n\n",timestamp,sa_pos,stab_accel[0],stab_accel[1],stab_accel[2]);
mdavis30 0:22fc81041056 131 //PC.printf("\nT: %f SA:(%d) Roll: %9.6f Pitch: %9.6f Yaw:%9.6f\n",timestamp,sa_pos,stab_accel[0],stab_accel[1],stab_accel[2]);
mdavis30 0:22fc81041056 132 char char_buffer [60];
tnhnrl 2:b00adea2187b 133 //sprintf(char_buffer,"T: %f SA:(%d) Roll: %9.6f Pitch: %9.6f Yaw: %9.6f",timestamp,sa_pos,stab_accel[0],stab_accel[1],stab_accel[2]);
tnhnrl 2:b00adea2187b 134 sprintf(char_buffer,">imu Time: %6.3f SA:(%d) Roll: %6.3f Pitch: %6.3f Yaw: %6.3f imu<",timestamp,sa_pos,stab_accel[0],stab_accel[1],stab_accel[2]);
mdavis30 0:22fc81041056 135 //PC.printf("cb: %s\n\n", char_buffer); //TROY: My way to double-check this
mdavis30 0:22fc81041056 136 //Sanity check
mdavis30 0:22fc81041056 137 //PC.printf("\nCheck1: %02x == %02x check2 %02x == %02x PL: %d T: %f DT: %f %f %f DV: %f %f %f SA: %f %f %f\n\n",data[packetlength-2],cb1, data[packetlength-1],cb2,packetlength,timestamp,delta_theta[0],delta_theta[1],delta_theta[2],
mdavis30 0:22fc81041056 138 //delta_vel[0],delta_vel[1],delta_vel[2],stab_accel[0],stab_accel[1],stab_accel[2]);
mdavis30 0:22fc81041056 139 count=MAXPACKETSIZE+1;
mdavis30 0:22fc81041056 140
mdavis30 0:22fc81041056 141 imu_string = char_buffer;
mdavis30 0:22fc81041056 142 return imu_string;
mdavis30 0:22fc81041056 143 }
mdavis30 0:22fc81041056 144 if(current==0x65&&last==0x75)
mdavis30 0:22fc81041056 145 {
mdavis30 0:22fc81041056 146 //return 0;
mdavis30 0:22fc81041056 147 cb1=1;
mdavis30 0:22fc81041056 148 cb2=0;
mdavis30 0:22fc81041056 149 mode=0;
mdavis30 0:22fc81041056 150 }
mdavis30 0:22fc81041056 151 }
mdavis30 0:22fc81041056 152 }
tnhnrl 2:b00adea2187b 153 //else if (IMU.readable() == 0) //doesn't work for some reason
tnhnrl 2:b00adea2187b 154 //return "no imu";
mdavis30 0:22fc81041056 155 }
mdavis30 1:0672f84101e4 156 }
mdavis30 1:0672f84101e4 157
mdavis30 1:0672f84101e4 158 float IMU_code::IMU_pitch()
mdavis30 1:0672f84101e4 159 {
tnhnrl 2:b00adea2187b 160 return stab_accel[2]; //using the yaw axis
mdavis30 0:22fc81041056 161 }
mdavis30 0:22fc81041056 162
mdavis30 0:22fc81041056 163 double double_from_le_bytes(unsigned char * p_to_double)
mdavis30 0:22fc81041056 164 {
mdavis30 0:22fc81041056 165 unsigned char temp[8];
mdavis30 0:22fc81041056 166 temp[0] = p_to_double[7];
mdavis30 0:22fc81041056 167 temp[1] = p_to_double[6];
mdavis30 0:22fc81041056 168 temp[2] = p_to_double[5];
mdavis30 0:22fc81041056 169 temp[3] = p_to_double[4];
mdavis30 0:22fc81041056 170 temp[4] = p_to_double[3];
mdavis30 0:22fc81041056 171 temp[5] = p_to_double[2];
mdavis30 0:22fc81041056 172 temp[6] = p_to_double[1];
mdavis30 0:22fc81041056 173 temp[7] = p_to_double[0];
mdavis30 0:22fc81041056 174 return *(double *) temp;
mdavis30 0:22fc81041056 175 }
mdavis30 0:22fc81041056 176
mdavis30 0:22fc81041056 177 float float_from_le_bytes(unsigned char * p_to_float)
mdavis30 0:22fc81041056 178 {
mdavis30 0:22fc81041056 179 unsigned char temp[4];
mdavis30 0:22fc81041056 180 temp[0] = p_to_float[3];
mdavis30 0:22fc81041056 181 temp[1] = p_to_float[2];
mdavis30 0:22fc81041056 182 temp[2] = p_to_float[1];
mdavis30 0:22fc81041056 183 temp[3] = p_to_float[0];
mdavis30 0:22fc81041056 184 return *(float *) temp;
mdavis30 0:22fc81041056 185 }