11/18

Dependencies:   mbed

sensor_fusion.cpp

Committer:
evenbrownie
Date:
2018-11-19
Revision:
3:461a9012682d
Parent:
2:a4d5e7f96e87

File content as of revision 3:461a9012682d:

/* 
 * @author: Natasha Sarkar, 2018
 */

#include "mbed.h"
#include "sensor_fusion.h"
 
MPU6050::MPU6050(PinName sda, PinName scl): i2c_object(sda, scl) {
    i2c_object.frequency(400000);
}
 
void MPU6050::start(void) {
    write_reg(ADDRESS, PWR_MGMT_1, 0x00);
    write_reg(ADDRESS, GYRO_CONFIG, 0x03 << 3);
    write_reg(ADDRESS, ACCEL_CONFIG, 0x00);
    write_reg(ADDRESS, CONFIG, 0x00);
}
 
bool MPU6050::read_raw(float *gx, float *gy, float *gz, float *ax, float *ay, float *az) {
    char raw_gyro[6];
    char raw_accel[6];
    if (read_reg(ADDRESS, GYRO_X, raw_gyro, 6)) {
        read_reg(ADDRESS, ACCEL_X, raw_accel, 6);
        *gx = float(short(raw_gyro[0] << 8 | raw_gyro[1])) + 13;
        *gy = float(short(raw_gyro[2] << 8 | raw_gyro[3])) - 18;
        *gz = float(short(raw_gyro[4] << 8 | raw_gyro[5])) + 80;
        *ax = float(short(raw_accel[0] << 8 | raw_accel[1])) - 1700;
        *ay = float(short(raw_accel[2] << 8 | raw_accel[3])) + 100;
        *az = float(short(raw_accel[4] << 8 | raw_accel[5])) - 14400;
        return true;
    }
    return false;
}

bool MPU6050::data_ready(void) {
    char int_status;
    read_reg(ADDRESS, INT_STATUS, &int_status, 1);
    return int_status & 1;
}

bool MPU6050::write_reg(int addr, char reg, char buf) {
    char data[2] = {reg, buf};
    return MPU6050::i2c_object.write(addr, data, 2) == 0;
}
 
bool MPU6050::read_reg(int addr, char reg, char *buf, int length) {
    return i2c_object.write(addr, &reg, 1, true) == 0 && 
           i2c_object.read(addr, buf, length) == 0;
}