download imu_v3.h
Language: C
LOC: 61
Project Info
paparazzi
Server: Savannah NonGNU
Type: cvs
...zzi\paparazzi3\sw\airborne\
   3dmg.c
   3dmg.h
   actuators.c
   actuators.h
   adc.h
   adc_generic.c
   adc_generic.h
   ahrs.c
   ahrs.h
   ahrs_new.c
   ahrs_new.h
   anemotaxis.c
   anemotaxis.h
   ap_downlink.h
   autopilot.h
   bomb.c
   bomb.h
   cam.c
   cam.h
   cam_roll.c
   cam_roll.h
   chemo_detect.c
   chemo_detect.h
   chemotaxis.c
   chemotaxis.h
   commands.c
   commands.h
   control_grz.c
   control_grz.h
   datalink.c
   datalink.h
   dc.c
   dc.h
   discsurvey.c
   discsurvey.h
   downlink.c
   downlink.h
   dpicco.c
   dpicco.h
   enose.c
   enose.h
   estimator.c
   estimator.h
   fbw_downlink.h
   frames.h
   fw_h_ctl.c
   fw_h_ctl.h
   fw_v_ctl.c
   fw_v_ctl.h
   gps.c
   gps.h
   gps_ubx.c
   gps_ubx.h
   gyro.c
   gyro.h
   i2c.c
   i2c.h
   imu.c
   imu.h
   imu_v3.c
   imu_v3.h
   infrared.c
   infrared.h
   inter_mcu.c
   inter_mcu.h
   latlong.c
   latlong.h
   led.h
   link_imu.c
   link_imu.h
   link_mcu.c
   link_mcu.h
   main.c
   main_antenna.c
   main_ap.c
   main_ap.h
   main_demo1.c
   main_demo2.c
   main_demo3.c
   main_demo4.c
   main_demo5.c
   main_demo6.c
   main_fbw.c
   main_fbw.h
   main_grz.c
   main_imu.c
   main_motor_bench.c
   modem.h
   nav.c
   nav.h
   nav_line.c
   nav_line.h
   nav_survey_rectangle.c
   nav_survey_rectangle.h
   paparazzi.h
   point.c
   point.h
   ppm.h
   pprz_transport.c
   pprz_transport.h
   print.h
   radio_control.c
   radio_control.h
   rc_settings.c
   rc_settings.h
   setup_actuators.c
   spi.c
   spi.h
   srf08.c
   srf08.h
   sys_time.c
   sys_time.h
   test_adcs.c
   traffic_info.c
   traffic_info.h
   uart.h
   usb_serial.h
   wavecard.c
   wavecard.h
   xbee.c
   xbee.h

#ifndef IMU_V3_H
#define IMU_V3_H

#include <inttypes.h>

#include "frames.h"

/* accelerometers in arbitrary unit */
extern float imu_accel[AXIS_NB];
/* gyros in rad/s                   */
extern float imu_gyro[AXIS_NB];
/* magnetometer in arbitrary unit   */
extern int16_t imu_mag[AXIS_NB];
/* battery in volts                 */
extern float imu_bat;

extern void imu_init(void);

extern struct adc_buf buf_ax;
extern struct adc_buf buf_ay;
extern struct adc_buf buf_az;
extern struct adc_buf buf_bat;

#define IMU_ACCEL_X_NEUTRAL 538
#define IMU_ACCEL_Y_NEUTRAL 506
#define IMU_ACCEL_Z_NEUTRAL 506

#if 0
#define ImuUpdateAccels() {						\
    int_disable();							\
    imu_accel[AXIS_X]= buf_ax.sum;					\
    imu_accel[AXIS_Y]= buf_ay.sum;					\
    imu_accel[AXIS_Z]= buf_az.sum;					\
    int_enable();							\
    imu_accel[AXIS_X] = -((imu_accel[AXIS_X] / DEFAULT_AV_NB_SAMPLE) - IMU_ACCEL_X_NEUTRAL); \
    imu_accel[AXIS_Y] = (imu_accel[AXIS_Y] / DEFAULT_AV_NB_SAMPLE) - IMU_ACCEL_Y_NEUTRAL;    \
    imu_accel[AXIS_Z] = (imu_accel[AXIS_Z] / DEFAULT_AV_NB_SAMPLE) - IMU_ACCEL_Z_NEUTRAL;    \
  }
#else
#define ImuUpdateAccels() {             					     \
    imu_accel[AXIS_X]= -((buf_ax.sum / DEFAULT_AV_NB_SAMPLE) - IMU_ACCEL_X_NEUTRAL); \
    imu_accel[AXIS_Y]= (buf_ay.sum / DEFAULT_AV_NB_SAMPLE) - IMU_ACCEL_Y_NEUTRAL;    \
    imu_accel[AXIS_Z]= (buf_az.sum / DEFAULT_AV_NB_SAMPLE) - IMU_ACCEL_Z_NEUTRAL;    \
}
#endif


#define IMU_GYRO_X_NEUTRAL 40867
#define IMU_GYRO_Y_NEUTRAL 40852
#define IMU_GYRO_Z_NEUTRAL 38915

#define IMU_GYRO_X_GAIN -0.000220177991888642784
#define IMU_GYRO_Y_GAIN -0.000214915108532129801
#define IMU_GYRO_Z_GAIN  0.0002104

#define ImuUpdateGyros() {					                \
    									        \
    imu_gyro[AXIS_X] = (float)((int32_t)max1167_values[0] - IMU_GYRO_X_NEUTRAL) \
                        * IMU_GYRO_X_GAIN;				        \
    imu_gyro[AXIS_Y] = (float)((int32_t)max1167_values[1] - IMU_GYRO_Y_NEUTRAL) \
                        * IMU_GYRO_Y_GAIN;				        \
    imu_gyro[AXIS_Z] = (float)((int32_t)max1167_values[2] - IMU_GYRO_Z_NEUTRAL) \
                        * IMU_GYRO_Z_GAIN;				        \
  }

#define ImuUpdateMag() {		   \
    imu_mag[AXIS_X] = -micromag_values[0]; \
    imu_mag[AXIS_Y] = -micromag_values[1]; \
    imu_mag[AXIS_Z] = micromag_values[2];  \
  }


#define IMU_BAT_NEUTRAL 2
#define IMU_BAT_GAIN .010101

#define ImuUpdateBat() {					       \
    imu_bat = ((buf_bat.sum / DEFAULT_AV_NB_SAMPLE) - IMU_BAT_NEUTRAL) \
      * IMU_BAT_GAIN;						       \
  }

#endif /* IMU_V3_H */

About Koders | Resources | Downloads | Support | Black Duck | Submit Project | Terms of Service | DMCA | Privacy Policy | Site Map| Contact Us