xm Nan / Mbed 2 deprecated sensors_KL46Z_xmn

Dependencies:   EventFramework mbed

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers MAG3110.h Source File

MAG3110.h

00001 /*
00002  * MAG3110 Sensor Library for mbed
00003  * TODO: Add proper header
00004  */
00005 
00006 #ifndef MAG3110_H
00007 #define MAG3110_H
00008 
00009 #include "mbed.h"
00010 
00011 #define PI 3.14159265359
00012 
00013 #define MAG_ADDR 0x1D
00014 
00015 // define registers
00016 #define MAG_DR_STATUS 0x00
00017 #define MAG_OUT_X_MSB 0x01
00018 #define MAG_OUT_X_LSB 0x02
00019 #define MAG_OUT_Y_MSB 0x03
00020 #define MAG_OUT_Y_LSB 0x04
00021 #define MAG_OUT_Z_MSB 0x05
00022 #define MAG_OUT_Z_LSB 0x06
00023 #define MAG_WHO_AM_I  0x07
00024 #define MAG_SYSMOD    0x08
00025 #define MAG_OFF_X_MSB 0x09
00026 #define MAG_OFF_X_LSB 0x0A
00027 #define MAG_OFF_Y_MSB 0x0B
00028 #define MAG_OFF_Y_LSB 0x0C
00029 #define MAG_OFF_Z_MSB 0x0D
00030 #define MAG_OFF_Z_LSB 0x0E
00031 #define MAG_DIE_TEMP  0x0F
00032 #define MAG_CTRL_REG1 0x10
00033 #define MAG_CTRL_REG2 0x11
00034 
00035 // what should WHO_AM_I return?
00036 #define MAG_3110_WHO_AM_I_VALUE 0xC4
00037 
00038 
00039 // Fields in registers
00040 // CTRL_REG1: dr2,dr1,dr0  os1,os0  fr tm ac
00041 
00042 // Sampling rate from 80Hz down to 0.625Hz
00043 #define MAG_3110_SAMPLE80 0
00044 #define MAG_3110_SAMPLE40 0x20
00045 #define MAG_3110_SAMPLE20 0x40
00046 #define MAG_3110_SAMPLE10 0x60
00047 #define MAG_3110_SAMPLE5 0x80
00048 #define MAG_3110_SAMPLE2_5 0xA0
00049 #define MAG_3110_SAMPLE1_25 0xC0
00050 #define MAG_3110_SAMPLE0_625 0xE0
00051 
00052 // How many samples to average (lowers data rate)
00053 #define MAG_3110_OVERSAMPLE1 0         //16
00054 #define MAG_3110_OVERSAMPLE2 0x08      //32, sample rate decrease to half
00055 #define MAG_3110_OVERSAMPLE3 0x10      //64, sample rate decrease to 1/4
00056 #define MAG_3110_OVERSAMPLE4 0x18      //128 sample rate decrease to 1/8
00057 
00058 // read only 1 byte per axis
00059 #define MAG_3110_FASTREAD 0x04
00060 // do one measurement (even if in standby mode)
00061 #define MAG_3110_TRIGGER 0x02
00062 // put in active mode
00063 #define MAG_3110_ACTIVE 0x01
00064 
00065 // CTRL_REG2: AUTO_MRST_EN  _ RAW MAG_RST _ _ _ _ _
00066 // reset sensor after each reading
00067 #define MAG_3110_AUTO_MRST_EN 0x80
00068 // don't subtract user offsets
00069 #define MAG_3110_RAW 0x20
00070 // reset magnetic sensor after too-large field
00071 #define MAG_3110_MAG_RST 0x10
00072 
00073 // DR_STATUS Register ZYXOW ZOW YOW XOW ZYXDR ZDR YDR XDR
00074 #define MAG_3110_ZYXDR  0x08
00075 
00076 /**
00077  * MAG3110 Class to read X/Y/Z data from the magentometer
00078  *
00079  */
00080 class MAG3110
00081 {
00082 public:
00083     /**
00084      * Main constructor
00085      * @param sda SDA pin
00086      * @param sdl SCL pin
00087      * @param addr addr of the I2C peripheral
00088      */
00089     MAG3110(PinName sda, PinName scl);
00090     /**
00091      * Debug version of constructor
00092      * @param sda SDA pin
00093      * @param sdl SCL pin
00094      * @param addr Address of the I2C peripheral
00095      * @param pc Serial object to output debug messages
00096      */
00097     MAG3110(PinName sda, PinName scl, Serial *pc); //pass serial for debug
00098     /**
00099      * Setup the Magnetometer
00100      *
00101      */
00102     MAG3110(PinName sda, PinName scl,float dateRate, int overSample);
00103     void Overwrite_dr_osr(float dateRate,int overSample);
00104     void Setdr(float dateRate);
00105     void Setosr(int overSample);
00106     
00107     void begin();
00108     /**
00109      * Read a register, return its value as int
00110      * @param regAddr The address to read
00111      * @return value in register
00112      */
00113     int readReg(char regAddr);
00114     /**
00115      * Read a value from a pair of registers, return as int
00116      * @param regAddr The address to read
00117      * @return Value from 2 consecutive registers
00118      */
00119     int readVal(char regAddr);
00120     /**
00121      * Calculate the heading
00122      * @return heading in degrees
00123      */
00124     float getHeading();
00125     /**
00126      * Perform a read on the X, Y and Z values.
00127      * @param xVal Pointer to X value
00128      * @param yVal Pointer to Y value
00129      * @param zVal Pointer to Z value
00130      */
00131     void getValues(int *xVal, int *yVal, int *zVal);
00132     /**
00133      * Set the calibration parameters if required.
00134      * @param minX Minimum value for X range
00135      * @param maxX Maximum value for X range
00136      * @param minY Minimum value for Y range
00137      * @param maxY maximum value for Y range
00138      */
00139     void setCalibration(int minX, int maxX, int minY, int maxY);
00140 
00141 private:
00142     I2C _i2c;
00143     int _i2c_address;
00144     Serial *_pc;
00145     bool _debug;
00146     int _avgX, _avgY;
00147     char dr;       //date rate
00148     char osr;      //over sample rate
00149 
00150 };
00151 #endif