Implemented first Hangar-Service
Dependencies: CalibrateMagneto QuaternionMath
Fork of SML2 by
Accelerometer.cpp
- Committer:
- pvaibhav
- Date:
- 2015-03-12
- Revision:
- 11:d21275e60ebb
- Parent:
- 9:a0ae9e68f95d
- Child:
- 12:1632d7391453
File content as of revision 11:d21275e60ebb:
#include "Accelerometer.h" #define DEBUG "BMX055-Acc" #include "Logger.h" #include "Vector3.h" Accelerometer::Accelerometer(I2C &i2c) : I2CPeripheral(i2c, 0x18 << 1 /* address */) { if (powerOn()) { INFO("Bosch Sensortec BMX055-Accel found"); powerOff(); } else { WARN("Bosch Sensortec BMX055-Accel not found"); } } bool Accelerometer::powerOn() { write_reg(0x14, 0xB6); // reset wait_ms(2); // page 11 says only 1.3ms, nothing for startup time, so assuming 2ms write_reg(0x11, 0); // set power normal mode write_reg(0x10, 15); // set bandwidth = 250 Hz return read_reg(0x00) == 0xfa; // verify chip ID } void Accelerometer::powerOff() { write_reg(0x11, 1); // deep suspend mode LOG("deep sleep"); } void Accelerometer::start() { // nothing to do right now } void Accelerometer::stop() { // nothing to do right now } Vector3 Accelerometer::read() { // Check comments in the read() function of the Gyroscope for more info why we read bytes one by one. union { uint8_t bytes[6]; struct { int16_t z; int16_t y; int16_t x; } val; } buffer; size_t i = 6; while (i --> 0) { buffer.bytes[i] = read_reg(0x02 + i); }; const int16_t x = buffer.val.x / 16; const int16_t y = buffer.val.y / 16; const int16_t z = buffer.val.z / 16; const float accel_resolution = 0.0009765625; return Vector3(x, y, z) * accel_resolution; }