2
Dependencies: mbed
Fork of IMU_oo by
Revision 2:6bc2c5d68446, committed 2016-12-04
- Comitter:
- siwakon
- Date:
- Sun Dec 04 09:19:53 2016 +0000
- Parent:
- 0:77a7d1a1c6db
- Commit message:
- weewfd
Changed in this revision
main.cpp | Show annotated file Show diff for this revision Revisions of this file |
zmu9250.h | Show annotated file Show diff for this revision Revisions of this file |
diff -r 77a7d1a1c6db -r 6bc2c5d68446 main.cpp --- a/main.cpp Sat Dec 03 18:21:47 2016 +0000 +++ b/main.cpp Sun Dec 04 09:19:53 2016 +0000 @@ -5,7 +5,7 @@ ZMU9250 a; Serial pc(D1, D0); -float yaw_z, pitch_y, roll_x; +float yaaw_z, piitch_y, rooll_x; int ir,ip,iy; int l; int xlr,yfb,ztd; @@ -13,11 +13,11 @@ char rt; int cube1(int x, int y, int z); -int seccon(float roll ,float pitch, float yaw); +int seccon(float rooll ,float piitch, float yaaw); int round(int rt_x, int rt_y, int rt_z); -DigitalIn op_roll(USER_BUTTON); +DigitalIn op_rooll(USER_BUTTON); int main(){ @@ -25,22 +25,25 @@ while(1){ wait(0.1); a.Update(); - yaw_z = a.Yaw(); - pitch_y = a.Pitch(); - roll_x = a.Roll(); + yaaw_z = a.Yaw(); + piitch_y = a.Pitch(); + rooll_x = a.Roll(); -// pc.printf("Yaw_z %f\t Pitch_y %f\t Roll_x %f\n", yaw_z, pitch_y, roll_x); + // pc.printf("yaaw_z %f\t piitch_y %f\t rooll_x %f\n\n\n\r", yaaw_z, piitch_y, rooll_x); //l = cube1(3,3,3); - - //pc.printf("%d\t Yaw_z %f\t Pitch_y %f\t Roll_x %f\n",l , yaw_z, pitch_y, roll_x); //add - - pc.printf("%d\t Yaw_z %f\t Pitch_y %f\t Roll_x %f\t %d\t %c\t %d\t \r\n ",round(5,5,5), yaw_z, pitch_y, roll_x, sata, rt, l); //round +// +// pc.printf("%d\t yaaw_z %f\t piitch_y %f\t rooll_x %f\n\n\n\r",l , yaaw_z, piitch_y, rooll_x); //add +// + pc.printf("%d\t yaaw_z %f\t piitch_y %f\t rooll_x %f\t %d\t %c\t %d\t xlr %d\t yfb %d\t ztd %d\t \n\n\n\r ",round(5,5,5), yaaw_z, piitch_y, rooll_x, sata, rt, l,xlr ,yfb, ztd); //round - // pc.printf( "%d\n" ,seccon(roll_x, pitch_y, yaw_z)); -// pc.printf("========\n"); //it - if(op_roll == 0){ - + // pc.printf( "%d\n" ,seccon(rooll_x, piitch_y, yaaw_z)); + // pc.printf("========\n"); + //it + if(op_rooll == 0){ + xlr = 0; + yfb = 0; + ztd = 0; l = cube1(3,3,3); } @@ -48,59 +51,47 @@ } } - int cube1(int x, int y, int z){ - - if( ((pitch_y > -30) && (pitch_y < 30)) ){ // vCC L leg D - - if( ((yaw_z > 36) && (yaw_z < 113)) && ((roll_x > -40) && (roll_x < 40)) ){ - x++; //R x+ - xlr = 1; - - - } - if( ((yaw_z > -101) && (yaw_z < 35)) && ((roll_x > -40) && (roll_x < 40)) ){ - y--; //B y+ - yfb = -1; - } - if( ((yaw_z > 110) && (yaw_z < 179)) && ((roll_x > -40) && (roll_x < 40)) ){ - y++; //F y- - yfb = 1; - - } - if( ((yaw_z > -180) && (yaw_z < -100)) && ((roll_x > -40) && (roll_x < 40)) ){ - x--; //L x- - xlr = -1; - - } - if((roll_x > 41) && (roll_x < 130) ){ - z++; //T z+ - ztd = 1; - - } - if( (roll_x > -130) && (roll_x < -41)){ - z--; //D z- - ztd = -1; - - } + int cube1(int x, int y, int z){ + // vCC LEFT + if( ((yaaw_z > 36) && (yaaw_z < 113)) && ( ((rooll_x > -40) && (rooll_x < 40)) ) ){ + x++; //R + xlr = 1; } - - + if( ((yaaw_z > -74) && (yaaw_z < 35)) && ( ((rooll_x > -40) && (rooll_x < 40)) ) ){ + y--; //B + yfb = -1; + } + if( ((yaaw_z > 110) && (yaaw_z < 179)) &&( ((rooll_x > -40) && (rooll_x < 40)) ) ){ + y++; //F + yfb = 1; + } + if( ((yaaw_z > -180) && (yaaw_z < -75)) &&( ((rooll_x > -40) && (rooll_x < 40)) ) ){ + x--; //L + xlr = -1; + } + if((rooll_x > 41) && (rooll_x < 130) ){ + z++; //T + ztd = 1; + } + if( (rooll_x > -130) && (rooll_x < -41)){ + z--; //D + ztd = -1; + } return (x*100+y*10+z); } - - int seccon(float roll ,float pitch, float yaw){ - if( ( ((yaw > -50) && (yaw < -30)) || ((yaw > -145) && (yaw < -125)) || ((yaw > 140) && (yaw < 160))||((yaw > 0) && (yaw < -20)) ) - && ((roll_x > -10 )&& (roll_x < 10)) - && (( pitch > -10 )&&(pitch < 10)) //L T R D + int seccon(float rooll ,float piitch, float yaaw){ + if( ( ((yaaw > -50) && (yaaw < -30)) || ((yaaw > -145) && (yaaw < -125)) || ((yaaw > 140) && (yaaw < 160))||((yaaw > 0) && (yaaw < -20)) ) + && ((rooll_x > -10 )&& (rooll_x < 10)) + && (( piitch > -10 )&&(piitch < 10)) //L T R D ){ - ir = roll; - ip = pitch; - iy = yaw; + ir = rooll; + ip = piitch; + iy = yaaw; return 1; } else{ @@ -111,9 +102,9 @@ int round(int rt_x, int rt_y, int rt_z){ - if( (pitch_y > -30) && (pitch_y < 30) ){ // vCC L leg D + if( (piitch_y > -30) && (piitch_y < 30) ){ // vCC L leg D - if( ((yaw_z > 36) && (yaw_z < 113)) && ( ((roll_x > -40) && (roll_x < 40)) ) ){ + if( ((yaaw_z > 36) && (yaaw_z < 113)) && ( ((rooll_x > -40) && (rooll_x < 40)) ) ){ //R x+ if(xlr == 1){ sata = 0; @@ -139,8 +130,8 @@ sata = 90; //x rt ='x'; } - } - if( ((yaw_z > -74) && (yaw_z < 35)) && ( ((roll_x > -40) && (roll_x < 40)) ) ){ + } + if( ((yaaw_z > -74) && (yaaw_z < 35)) && ( ((rooll_x > -40) && (rooll_x < 40)) ) ){ //B y+ if(xlr == 1){ sata = 270; @@ -167,7 +158,7 @@ rt = 'x'; } } - if( ((yaw_z > 110) && (yaw_z < 179)) &&( ((roll_x > -40) && (roll_x < 40)) ) ){ + if( ((yaaw_z > 110) && (yaaw_z < 179)) &&( ((rooll_x > -40) && (rooll_x < 40)) ) ){ //F y- if(xlr == 1){ sata = 90; @@ -194,7 +185,7 @@ rt = 'x'; } } - if( ((yaw_z > -180) && (yaw_z < -75)) &&( ((roll_x > -40) && (roll_x < 40)) ) ){ + if( ((yaaw_z > -180) && (yaaw_z < -75)) &&( ((rooll_x > -40) && (rooll_x < 40)) ) ){ //L x- if(xlr == 1){ sata = 180; @@ -221,7 +212,7 @@ rt = 'x'; } } - if((roll_x > 41) && (roll_x < 130) ){ + if((rooll_x > 41) && (rooll_x < 130) ){ //T z+ if(xlr == 1){ sata = 90; //x @@ -248,7 +239,7 @@ rt = 'x'; } } - if( (roll_x > -130) && (roll_x < -41)){ + if( (rooll_x > -130) && (rooll_x < -41)){ //D z- if(xlr == 1){ sata = 270; @@ -277,29 +268,29 @@ } } - + int k1,k2,rtt_x,rtt_y,rtt_z; + k1 = sin(sata*PI/180); + k2 = cos(sata*PI/180); rt_x = rt_x - 3; rt_y = rt_y - 3; rt_z = rt_z - 3; if(rt == 'x'){ - rt_x = rt_x + 3; //x - rt_y = (rt_y * cos(sata*(PI/180))+ rt_z * sin(sata*(PI/180)) )+ 3; - rt_z = (-rt_y * sin(sata*(PI/180))+ rt_z * cos(sata*(PI/180)) ) + 3; + rtt_x = rt_x ; //x + rtt_y = ((rt_y * k2)- (rt_z * k1 )); + rtt_z = ((rt_y * k1)+ (rt_z * k2 )); } if(rt == 'y'){ - rt_x = (rt_x * cos(sata*(PI/180)) - rt_z * sin(sata*(PI/180)) )+ 3; // y - rt_y = rt_y + 3; - rt_z = (rt_x * sin(sata*(PI/180)) + rt_z * cos(sata*(PI/180)) )+ 3; + rtt_x = ((rt_x * k2) + (rt_z * k1 )); // y + rtt_y = rt_y ; + rtt_z = ((-rt_x * k1) + (rt_z * k2 )); } if(rt == 'z'){ - rt_x = (rt_x * cos(sata*(PI/180))+ rt_y * sin(sata*(PI/180)) )+ 3; //z - rt_y = (rt_y * cos(sata*(PI/180))- rt_x * sin(sata*(PI/180)) )+ 3; - rt_z = rt_z + 3; + rtt_x = ((rt_x * k2)- (rt_y * k1 )); //z + rtt_y = ((rt_x * k1)+ (rt_y * k2 )); + rtt_z = rt_z; } - pc.printf("rt_x %d\t", rt_x); - pc.printf("rt_y %d\t", rt_y); - pc.printf("rt_z %d \n\n\n\n\r", rt_z); + - return (rt_x*100 + rt_y*10 + rt_z); + return (rtt_x*100 + rtt_y*10 + rtt_z + 333); } \ No newline at end of file
diff -r 77a7d1a1c6db -r 6bc2c5d68446 zmu9250.h --- a/zmu9250.h Sat Dec 03 18:21:47 2016 +0000 +++ b/zmu9250.h Sun Dec 04 09:19:53 2016 +0000 @@ -18,7 +18,7 @@ // Read the WHO_AM_I register, this is a good test of communication uint8_t whoami = this->mpu9250.readByte(MPU9250_ADDRESS, WHO_AM_I_MPU9250); // Read WHO_AM_I register for MPU-9250 - if (whoami == 0x71) // WHO_AM_I should always be 0x68 + if ((whoami == 0x71)||(whoami == 0x73)) // WHO_AM_I should always be 0x68 { wait(1); this->mpu9250.resetMPU9250(); // Reset registers to default in preparation for device calibration