#include <stdio.h>
#include <getopt.h>
#include <signal.h>
#include <stdlib.h>
#define I2C_BUS 2
#define GPIO_INT_PIN_CHIP 3
#define GPIO_INT_PIN_PIN 21
static int running = 0;
static int silent_mode = 0;
static int show_accel = 0;
static int show_gyro = 0;
static int enable_mag = 0;
static int show_compass = 0;
static int show_temp = 0;
static int show_quat = 0;
static int show_tb = 0;
static int orientation_menu = 0;
static void __print_usage(void);
static void __print_data(void);
static void __print_header(void);
static void __print_usage(void)
{
printf("\n Options\n");
printf("-r {rate} Set sample rate in HZ (default 100)\n");
printf(" Sample rate must be a divisor of 200\n");
printf("-m Enable Magnetometer\n");
printf("-b Enable Reading Magnetometer before ISR (default after)\n");
printf("-c Show raw compass angle\n");
printf("-a Print Accelerometer Data\n");
printf("-g Print Gyro Data\n");
printf("-T Print Temperature\n");
printf("-t Print TaitBryan Angles\n");
printf("-q Print Quaternion Vector\n");
printf("-p {prio} Set Interrupt Priority and FIFO scheduling policy (requires root)\n");
printf("-w Print I2C bus warnings\n");
printf("-o Show a menu to select IMU orientation\n");
printf("-h Print this help message\n\n");
return;
}
static void __print_data(void)
{
printf("\r");
printf(" ");
if(show_compass){
}
if(show_quat && enable_mag){
}
else if(show_quat){
}
if(show_tb && enable_mag){
}
else if(show_tb){
}
if(show_accel){
printf(
" %5.2f %5.2f %5.2f |", data.
accel[0],\
}
if(show_gyro){
printf(
" %5.1f %5.1f %5.1f |", data.
gyro[0],\
}
if(show_temp){
printf(
" %6.2f |", data.
temp);
}
fflush(stdout);
return;
}
static void __print_header(void)
{
printf(" ");
if(show_compass){
printf("Raw Compass |");
printf("FilteredComp|");
}
if(enable_mag){
if(show_quat) printf(" Fused Quaternion |");
if(show_tb) printf(" FusedTaitBryan(deg) |");
} else{
if(show_quat) printf(" DMP Quaternion |");
if(show_tb) printf(" DMP TaitBryan (deg) |");
}
if(show_accel) printf(" Accel XYZ (m/s^2) |");
if(show_gyro) printf(" Gyro XYZ (deg/s) |");
if(show_temp) printf(" Temp(C)|");
printf("\n");
}
static void __signal_handler(__attribute__ ((unused)) int dummy)
{
running=0;
return;
}
int c;
printf("\n");
printf("Please select a number 1-6 corresponding to the\n");
printf("orientation you wish to use. Press 'q' to exit.\n\n");
printf(" 1: ORIENTATION_Z_UP\n");
printf(" 2: ORIENTATION_Z_DOWN\n");
printf(" 3: ORIENTATION_X_UP\n");
printf(" 4: ORIENTATION_X_DOWN\n");
printf(" 5: ORIENTATION_Y_UP\n");
printf(" 6: ORIENTATION_Y_DOWN\n");
printf(" 7: ORIENTATION_X_FORWARD\n");
printf(" 8: ORIENTATION_X_BACK\n");
while ((c = getchar()) != EOF){
switch(c){
case '1':
break;
case '2':
break;
case '3':
break;
case '4':
break;
case '5':
break;
case '6':
break;
case '7':
break;
case '8':
break;
case 'q':
printf("Quitting\n");
exit(0);
case '\n':
break;
default:
printf("invalid input\n");
break;
}
}
return 0;
}
int main(int argc, char *argv[])
{
int c, sample_rate, priority;
int show_something = 0;
opterr = 0;
while ((c=getopt(argc, argv, "sr:mbagrqTtcp:hwo"))!=-1 && argc>1){
switch (c){
case 's':
silent_mode = 1;
show_something = 1;
break;
case 'r':
sample_rate = atoi(optarg);
if(sample_rate>200 || sample_rate<4){
printf("sample_rate must be between 4 & 200");
return -1;
}
break;
case 'p':
priority = atoi(optarg);
break;
case 'm':
show_something = 1;
enable_mag = 1;
break;
case 'b':
break;
case 'c':
show_something = 1;
enable_mag = 1;
show_compass = 1;
break;
case 'a':
show_something = 1;
show_accel = 1;
break;
case 'g':
show_something = 1;
show_gyro = 1;
break;
case 'q':
show_something = 1;
show_quat = 1;
break;
case 't':
show_something = 1;
show_tb = 1;
break;
case 'T':
show_something = 1;
show_temp = 1;
break;
case 'w':
break;
case 'o':
orientation_menu=1;
break;
case 'h':
__print_usage();
return -1;
break;
default:
printf("opt: %c\n",c);
printf("invalid argument\n");
__print_usage();
return -1;
break;
}
}
if(show_something==0){
__print_usage();
printf("please enable an option to print some data\n");
return -1;
}
if(orientation_menu){
conf.
orient=__orientation_prompt();
}
signal(SIGINT, __signal_handler);
running = 1;
printf("rc_mpu_initialize_failed\n");
return -1;
}
__print_header();
printf("\n");
fflush(stdout);
return 0;
}
rc_mpu_orientation_t
Orientation of the sensor.
Definition: mpu.h:137
#define TB_ROLL_Y
Index of the dmp_TaitBryan[] array corresponding to the Roll (Y) axis.
Definition: mpu.h:50
#define TB_YAW_Z
Index of the dmp_TaitBryan[] array corresponding to the Yaw (Z) axis.
Definition: mpu.h:51
int rc_mpu_set_dmp_callback(void(*func)(void))
Sets the callback function that will be triggered when new DMP data is ready.
#define QUAT_W
First index of the dmp_quat[] quaternion vector.
Definition: mpu.h:52
#define TB_PITCH_X
Index of the dmp_TaitBryan[] array corresponding to the Pitch (X) axis.
Definition: mpu.h:49
int rc_mpu_read_temp(rc_mpu_data_t *data)
Reads thermometer data from the MPU.
#define QUAT_X
Second index of the dmp_quat[] quaternion vector.
Definition: mpu.h:53
#define QUAT_Z
Fourth index of the dmp_quat[] quaternion vector.
Definition: mpu.h:55
int rc_mpu_initialize_dmp(rc_mpu_data_t *data, rc_mpu_config_t conf)
Initializes the MPU in DMP mode, see rc_test_dmp example.
#define RAD_TO_DEG
multiply to convert radians to degrees
Definition: mpu.h:58
int rc_mpu_power_off(void)
Powers off the MPU.
#define QUAT_Y
Third index of the dmp_quat[] quaternion vector.
Definition: mpu.h:54
rc_mpu_config_t rc_mpu_default_config(void)
Returns an rc_mpu_config_t struct with default settings.
@ ORIENTATION_Z_UP
Definition: mpu.h:138
@ ORIENTATION_Y_UP
Definition: mpu.h:142
@ ORIENTATION_X_UP
Definition: mpu.h:140
@ ORIENTATION_Z_DOWN
Definition: mpu.h:139
@ ORIENTATION_X_BACK
Definition: mpu.h:145
@ ORIENTATION_X_DOWN
Definition: mpu.h:141
@ ORIENTATION_Y_DOWN
Definition: mpu.h:143
@ ORIENTATION_X_FORWARD
Definition: mpu.h:144
void rc_usleep(unsigned int us)
Sleep in microseconds.
configuration of the mpu sensor
Definition: mpu.h:155
rc_mpu_orientation_t orient
DMP orientation matrix, see rc_mpu_orientation_t.
Definition: mpu.h:179
int gpio_interrupt_pin
gpio pin, default 21 on Robotics Cape and BB Blue
Definition: mpu.h:159
int show_warnings
set to 1 to print i2c_bus warnings for debug
Definition: mpu.h:162
int dmp_fetch_accel_gyro
set to 1 to optionally raw accel/gyro when reading DMP quaternion, default: 0 (off)
Definition: mpu.h:177
int dmp_interrupt_priority
scheduler priority for DMP interrupt handler and user callback, default 0
Definition: mpu.h:182
int dmp_sample_rate
sample rate in hertz, 200,100,50,40,25,20,10,8,5,4
Definition: mpu.h:176
int dmp_interrupt_sched_policy
Scheduler policy for DMP interrupt handler and user callback, default SCHED_OTHER.
Definition: mpu.h:181
int read_mag_after_callback
reads magnetometer after DMP callback function to improve latency, default 1 (true)
Definition: mpu.h:183
int gpio_interrupt_pin_chip
gpio pin, default 3 on Robotics Cape and BB Blue
Definition: mpu.h:158
int enable_magnetometer
magnetometer use is optional, set to 1 to enable, default 0 (off)
Definition: mpu.h:171
int i2c_bus
which bus to use, default 2 on Robotics Cape and BB Blue
Definition: mpu.h:160
data struct populated with new sensor data
Definition: mpu.h:199
double dmp_quat[4]
normalized quaternion from DMP based on ONLY Accel/Gyro
Definition: mpu.h:218
double accel[3]
accelerometer (XYZ) in units of m/s^2
Definition: mpu.h:202
double fused_quat[4]
fused and normalized quaternion
Definition: mpu.h:227
double dmp_TaitBryan[3]
Tait-Bryan angles (roll pitch yaw) in radians from DMP based on ONLY Accel/Gyro.
Definition: mpu.h:219
double gyro[3]
gyroscope (XYZ) in units of degrees/s
Definition: mpu.h:203
double fused_TaitBryan[3]
fused Tait-Bryan angles (roll pitch yaw) in radians
Definition: mpu.h:228
double temp
thermometer, in units of degrees Celsius
Definition: mpu.h:205
double compass_heading
fused heading filtered with gyro and accel data, same as Tait-Bryan yaw
Definition: mpu.h:229
double compass_heading_raw
unfiltered heading from magnetometer
Definition: mpu.h:230