bno055

Dependents:   LPC1768-GPS-FUSION-17102018-1

Fork of BNO055 by Dave Turner

Committer:
RCMISbed
Date:
Wed Oct 17 11:35:39 2018 +0000
Revision:
4:fe45288757f6
Parent:
3:1db1628eb8b2
LPC1768-GPS-FUSION

Who changed what in which revision?

UserRevisionLine numberNew contents of line
StressedDave 0:24f23c36dd24 1 #include "BNO055.h"
StressedDave 0:24f23c36dd24 2 #include "mbed.h"
StressedDave 0:24f23c36dd24 3
StressedDave 0:24f23c36dd24 4 BNO055::BNO055(PinName SDA, PinName SCL) : _i2c(SDA,SCL){
StressedDave 0:24f23c36dd24 5 //Set I2C fast and bring reset line high
StressedDave 0:24f23c36dd24 6 _i2c.frequency(400000);
StressedDave 0:24f23c36dd24 7 address = BNOAddress;
StressedDave 0:24f23c36dd24 8 accel_scale = 1.0f;
StressedDave 0:24f23c36dd24 9 rate_scale = 1.0f/16.0f;
StressedDave 0:24f23c36dd24 10 angle_scale = 1.0f/16.0f;
StressedDave 1:2c3322a8d417 11 temp_scale = 1;
StressedDave 0:24f23c36dd24 12 }
RCMISbed 4:fe45288757f6 13
StressedDave 0:24f23c36dd24 14
StressedDave 0:24f23c36dd24 15 void BNO055::reset(){
RCMISbed 4:fe45288757f6 16 //Perform a power-on-reset
StressedDave 0:24f23c36dd24 17 readchar(BNO055_SYS_TRIGGER_ADDR);
StressedDave 0:24f23c36dd24 18 rx = rx | 0x20;
StressedDave 0:24f23c36dd24 19 writechar(BNO055_SYS_TRIGGER_ADDR,rx);
RCMISbed 4:fe45288757f6 20 //Wait for the system to come back up again (datasheet says 650ms)
StressedDave 0:24f23c36dd24 21 wait_ms(675);
RCMISbed 4:fe45288757f6 22 }
StressedDave 0:24f23c36dd24 23
StressedDave 0:24f23c36dd24 24 bool BNO055::check(){
RCMISbed 4:fe45288757f6 25 //Check we have communication link with the chip
StressedDave 0:24f23c36dd24 26 readchar(BNO055_CHIP_ID_ADDR);
StressedDave 0:24f23c36dd24 27 if (rx != 0xA0) return false;
RCMISbed 4:fe45288757f6 28 //Grab the chip ID and software versions
StressedDave 0:24f23c36dd24 29 tx[0] = BNO055_CHIP_ID_ADDR;
StressedDave 0:24f23c36dd24 30 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 31 _i2c.read(address+1,rawdata,7,false);
StressedDave 0:24f23c36dd24 32 ID.id = rawdata[0];
StressedDave 0:24f23c36dd24 33 ID.accel = rawdata[1];
StressedDave 0:24f23c36dd24 34 ID.mag = rawdata[2];
StressedDave 0:24f23c36dd24 35 ID.gyro = rawdata[3];
StressedDave 0:24f23c36dd24 36 ID.sw[0] = rawdata[4];
StressedDave 0:24f23c36dd24 37 ID.sw[1] = rawdata[5];
StressedDave 0:24f23c36dd24 38 ID.bootload = rawdata[6];
StressedDave 0:24f23c36dd24 39 setpage(1);
StressedDave 0:24f23c36dd24 40 tx[0] = BNO055_UNIQUE_ID_ADDR;
StressedDave 0:24f23c36dd24 41 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 42 _i2c.read(address+1,ID.serial,16,false);
StressedDave 0:24f23c36dd24 43 setpage(0);
StressedDave 0:24f23c36dd24 44 return true;
StressedDave 0:24f23c36dd24 45 }
StressedDave 0:24f23c36dd24 46
RCMISbed 4:fe45288757f6 47
StressedDave 0:24f23c36dd24 48 void BNO055::SetExternalCrystal(bool yn){
RCMISbed 4:fe45288757f6 49 // Read the current status from the device
StressedDave 0:24f23c36dd24 50 readchar(BNO055_SYS_TRIGGER_ADDR);
StressedDave 0:24f23c36dd24 51 if (yn) rx = rx | 0x80;
StressedDave 0:24f23c36dd24 52 else rx = rx & 0x7F;
StressedDave 0:24f23c36dd24 53 writechar(BNO055_SYS_TRIGGER_ADDR,rx);
RCMISbed 4:fe45288757f6 54 }
RCMISbed 4:fe45288757f6 55
StressedDave 0:24f23c36dd24 56
StressedDave 0:24f23c36dd24 57 void BNO055::set_accel_units(char units){
StressedDave 0:24f23c36dd24 58 readchar(BNO055_UNIT_SEL_ADDR);
StressedDave 0:24f23c36dd24 59 if(units == MPERSPERS){
StressedDave 0:24f23c36dd24 60 rx = rx & 0xFE;
StressedDave 0:24f23c36dd24 61 accel_scale = 0.01f;
StressedDave 0:24f23c36dd24 62 }
StressedDave 0:24f23c36dd24 63 else {
StressedDave 0:24f23c36dd24 64 rx = rx | units;
StressedDave 0:24f23c36dd24 65 accel_scale = 1.0f;
StressedDave 0:24f23c36dd24 66 }
StressedDave 0:24f23c36dd24 67 writechar(BNO055_UNIT_SEL_ADDR,rx);
RCMISbed 4:fe45288757f6 68 }
RCMISbed 4:fe45288757f6 69
StressedDave 0:24f23c36dd24 70
StressedDave 0:24f23c36dd24 71 void BNO055::set_anglerate_units(char units){
StressedDave 0:24f23c36dd24 72 readchar(BNO055_UNIT_SEL_ADDR);
StressedDave 0:24f23c36dd24 73 if (units == DEG_PER_SEC){
StressedDave 0:24f23c36dd24 74 rx = rx & 0xFD;
StressedDave 0:24f23c36dd24 75 rate_scale = 1.0f/16.0f;
StressedDave 0:24f23c36dd24 76 }
StressedDave 0:24f23c36dd24 77 else {
StressedDave 0:24f23c36dd24 78 rx = rx | units;
StressedDave 0:24f23c36dd24 79 rate_scale = 1.0f/900.0f;
StressedDave 0:24f23c36dd24 80 }
StressedDave 0:24f23c36dd24 81 writechar(BNO055_UNIT_SEL_ADDR,rx);
RCMISbed 4:fe45288757f6 82 }
RCMISbed 4:fe45288757f6 83
StressedDave 0:24f23c36dd24 84
StressedDave 0:24f23c36dd24 85 void BNO055::set_angle_units(char units){
StressedDave 0:24f23c36dd24 86 readchar(BNO055_UNIT_SEL_ADDR);
StressedDave 0:24f23c36dd24 87 if (units == DEGREES){
StressedDave 0:24f23c36dd24 88 rx = rx & 0xFB;
StressedDave 0:24f23c36dd24 89 angle_scale = 1.0f/16.0f;
StressedDave 0:24f23c36dd24 90 }
StressedDave 0:24f23c36dd24 91 else {
StressedDave 0:24f23c36dd24 92 rx = rx | units;
StressedDave 0:24f23c36dd24 93 rate_scale = 1.0f/900.0f;
StressedDave 0:24f23c36dd24 94 }
StressedDave 0:24f23c36dd24 95 writechar(BNO055_UNIT_SEL_ADDR,rx);
RCMISbed 4:fe45288757f6 96 }
RCMISbed 4:fe45288757f6 97
RCMISbed 4:fe45288757f6 98
StressedDave 0:24f23c36dd24 99
StressedDave 0:24f23c36dd24 100 void BNO055::set_temp_units(char units){
StressedDave 0:24f23c36dd24 101 readchar(BNO055_UNIT_SEL_ADDR);
StressedDave 0:24f23c36dd24 102 if (units == CENTIGRADE){
StressedDave 1:2c3322a8d417 103 rx = rx & 0xEF;
StressedDave 1:2c3322a8d417 104 temp_scale = 1;
StressedDave 0:24f23c36dd24 105 }
StressedDave 0:24f23c36dd24 106 else {
StressedDave 0:24f23c36dd24 107 rx = rx | units;
StressedDave 1:2c3322a8d417 108 temp_scale = 2;
StressedDave 0:24f23c36dd24 109 }
StressedDave 0:24f23c36dd24 110 writechar(BNO055_UNIT_SEL_ADDR,rx);
RCMISbed 4:fe45288757f6 111 }
RCMISbed 4:fe45288757f6 112
RCMISbed 4:fe45288757f6 113
StressedDave 0:24f23c36dd24 114
StressedDave 1:2c3322a8d417 115 void BNO055::set_orientation(char units){
StressedDave 1:2c3322a8d417 116 readchar(BNO055_UNIT_SEL_ADDR);
StressedDave 1:2c3322a8d417 117 if (units == WINDOWS) rx = rx &0x7F;
StressedDave 1:2c3322a8d417 118 else rx = rx | units;
StressedDave 1:2c3322a8d417 119 writechar(BNO055_UNIT_SEL_ADDR,rx);
StressedDave 1:2c3322a8d417 120 }
StressedDave 1:2c3322a8d417 121
StressedDave 0:24f23c36dd24 122 void BNO055::setmode(char omode){
StressedDave 0:24f23c36dd24 123 writechar(BNO055_OPR_MODE_ADDR,omode);
StressedDave 0:24f23c36dd24 124 op_mode = omode;
RCMISbed 4:fe45288757f6 125 }
RCMISbed 4:fe45288757f6 126
StressedDave 0:24f23c36dd24 127
StressedDave 0:24f23c36dd24 128 void BNO055::setpowermode(char pmode){
StressedDave 0:24f23c36dd24 129 writechar(BNO055_PWR_MODE_ADDR,pmode);
StressedDave 0:24f23c36dd24 130 pwr_mode = pmode;
RCMISbed 4:fe45288757f6 131 }
RCMISbed 4:fe45288757f6 132
StressedDave 0:24f23c36dd24 133
StressedDave 0:24f23c36dd24 134 void BNO055::get_accel(void){
StressedDave 0:24f23c36dd24 135 tx[0] = BNO055_ACCEL_DATA_X_LSB_ADDR;
StressedDave 0:24f23c36dd24 136 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 137 _i2c.read(address+1,rawdata,6,0);
StressedDave 0:24f23c36dd24 138 accel.rawx = (rawdata[1] << 8 | rawdata[0]);
StressedDave 0:24f23c36dd24 139 accel.rawy = (rawdata[3] << 8 | rawdata[2]);
StressedDave 0:24f23c36dd24 140 accel.rawz = (rawdata[5] << 8 | rawdata[4]);
StressedDave 0:24f23c36dd24 141 accel.x = float(accel.rawx)*accel_scale;
StressedDave 0:24f23c36dd24 142 accel.y = float(accel.rawy)*accel_scale;
StressedDave 0:24f23c36dd24 143 accel.z = float(accel.rawz)*accel_scale;
RCMISbed 4:fe45288757f6 144 }
RCMISbed 4:fe45288757f6 145
StressedDave 0:24f23c36dd24 146
StressedDave 0:24f23c36dd24 147 void BNO055::get_gyro(void){
StressedDave 0:24f23c36dd24 148 tx[0] = BNO055_GYRO_DATA_X_LSB_ADDR;
StressedDave 0:24f23c36dd24 149 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 150 _i2c.read(address+1,rawdata,6,0);
StressedDave 0:24f23c36dd24 151 gyro.rawx = (rawdata[1] << 8 | rawdata[0]);
StressedDave 0:24f23c36dd24 152 gyro.rawy = (rawdata[3] << 8 | rawdata[2]);
StressedDave 0:24f23c36dd24 153 gyro.rawz = (rawdata[5] << 8 | rawdata[4]);
StressedDave 0:24f23c36dd24 154 gyro.x = float(gyro.rawx)*rate_scale;
StressedDave 0:24f23c36dd24 155 gyro.y = float(gyro.rawy)*rate_scale;
StressedDave 0:24f23c36dd24 156 gyro.z = float(gyro.rawz)*rate_scale;
RCMISbed 4:fe45288757f6 157 }
RCMISbed 4:fe45288757f6 158
StressedDave 0:24f23c36dd24 159
StressedDave 0:24f23c36dd24 160 void BNO055::get_mag(void){
StressedDave 0:24f23c36dd24 161 tx[0] = BNO055_MAG_DATA_X_LSB_ADDR;
StressedDave 0:24f23c36dd24 162 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 163 _i2c.read(address+1,rawdata,6,0);
StressedDave 0:24f23c36dd24 164 mag.rawx = (rawdata[1] << 8 | rawdata[0]);
StressedDave 0:24f23c36dd24 165 mag.rawy = (rawdata[3] << 8 | rawdata[2]);
StressedDave 0:24f23c36dd24 166 mag.rawz = (rawdata[5] << 8 | rawdata[4]);
StressedDave 0:24f23c36dd24 167 mag.x = float(mag.rawx);
StressedDave 0:24f23c36dd24 168 mag.y = float(mag.rawy);
StressedDave 0:24f23c36dd24 169 mag.z = float(mag.rawz);
RCMISbed 4:fe45288757f6 170 }
RCMISbed 4:fe45288757f6 171
StressedDave 0:24f23c36dd24 172
StressedDave 0:24f23c36dd24 173 void BNO055::get_lia(void){
StressedDave 0:24f23c36dd24 174 tx[0] = BNO055_LINEAR_ACCEL_DATA_X_LSB_ADDR;
StressedDave 0:24f23c36dd24 175 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 176 _i2c.read(address+1,rawdata,6,0);
StressedDave 0:24f23c36dd24 177 lia.rawx = (rawdata[1] << 8 | rawdata[0]);
StressedDave 0:24f23c36dd24 178 lia.rawy = (rawdata[3] << 8 | rawdata[2]);
StressedDave 0:24f23c36dd24 179 lia.rawz = (rawdata[5] << 8 | rawdata[4]);
StressedDave 0:24f23c36dd24 180 lia.x = float(lia.rawx)*accel_scale;
StressedDave 0:24f23c36dd24 181 lia.y = float(lia.rawy)*accel_scale;
StressedDave 0:24f23c36dd24 182 lia.z = float(lia.rawz)*accel_scale;
RCMISbed 4:fe45288757f6 183 }
RCMISbed 4:fe45288757f6 184
StressedDave 0:24f23c36dd24 185
StressedDave 0:24f23c36dd24 186 void BNO055::get_grv(void){
StressedDave 0:24f23c36dd24 187 tx[0] = BNO055_GRAVITY_DATA_X_LSB_ADDR;
StressedDave 0:24f23c36dd24 188 _i2c.write(address,tx,1,true);
StressedDave 0:24f23c36dd24 189 _i2c.read(address+1,rawdata,6,0);
StressedDave 0:24f23c36dd24 190 gravity.rawx = (rawdata[1] << 8 | rawdata[0]);
StressedDave 0:24f23c36dd24 191 gravity.rawy = (rawdata[3] << 8 | rawdata[2]);
StressedDave 0:24f23c36dd24 192 gravity.rawz = (rawdata[5] << 8 | rawdata[4]);
StressedDave 0:24f23c36dd24 193 gravity.x = float(gravity.rawx)*accel_scale;
StressedDave 0:24f23c36dd24 194 gravity.y = float(gravity.rawy)*accel_scale;
StressedDave 0:24f23c36dd24 195 gravity.z = float(gravity.rawz)*accel_scale;
RCMISbed 4:fe45288757f6 196 }
RCMISbed 4:fe45288757f6 197
StressedDave 0:24f23c36dd24 198
StressedDave 1:2c3322a8d417 199 void BNO055::get_quat(void){
StressedDave 1:2c3322a8d417 200 tx[0] = BNO055_QUATERNION_DATA_W_LSB_ADDR;
StressedDave 1:2c3322a8d417 201 _i2c.write(address,tx,1,true);
StressedDave 1:2c3322a8d417 202 _i2c.read(address+1,rawdata,8,0);
StressedDave 1:2c3322a8d417 203 quat.raww = (rawdata[1] << 8 | rawdata[0]);
StressedDave 1:2c3322a8d417 204 quat.rawx = (rawdata[3] << 8 | rawdata[2]);
StressedDave 1:2c3322a8d417 205 quat.rawy = (rawdata[5] << 8 | rawdata[4]);
StressedDave 1:2c3322a8d417 206 quat.rawz = (rawdata[7] << 8 | rawdata[6]);
StressedDave 1:2c3322a8d417 207 quat.w = float(quat.raww)/16384.0f;
StressedDave 1:2c3322a8d417 208 quat.x = float(quat.rawx)/16384.0f;
StressedDave 1:2c3322a8d417 209 quat.y = float(quat.rawy)/16384.0f;
StressedDave 1:2c3322a8d417 210 quat.z = float(quat.rawz)/16384.0f;
RCMISbed 4:fe45288757f6 211 }
RCMISbed 4:fe45288757f6 212
StressedDave 1:2c3322a8d417 213
StressedDave 2:695c6e5d239a 214 void BNO055::get_angles(void){
StressedDave 2:695c6e5d239a 215 tx[0] = BNO055_EULER_H_LSB_ADDR;
StressedDave 2:695c6e5d239a 216 _i2c.write(address,tx,1,true);
StressedDave 2:695c6e5d239a 217 _i2c.read(address+1,rawdata,6,0);
StressedDave 3:1db1628eb8b2 218 euler.rawyaw = (rawdata[1] << 8 | rawdata[0]);
StressedDave 3:1db1628eb8b2 219 euler.rawroll = (rawdata[3] << 8 | rawdata[2]);
StressedDave 3:1db1628eb8b2 220 euler.rawpitch = (rawdata[5] << 8 | rawdata[4]);
StressedDave 3:1db1628eb8b2 221 euler.yaw = float(euler.rawyaw)*angle_scale;
StressedDave 3:1db1628eb8b2 222 euler.roll = float(euler.rawroll)*angle_scale;
StressedDave 3:1db1628eb8b2 223 euler.pitch = float(euler.rawpitch)*angle_scale;
RCMISbed 4:fe45288757f6 224 }
StressedDave 2:695c6e5d239a 225
StressedDave 2:695c6e5d239a 226
StressedDave 1:2c3322a8d417 227 void BNO055::get_temp(void){
StressedDave 1:2c3322a8d417 228 readchar(BNO055_TEMP_ADDR);
StressedDave 1:2c3322a8d417 229 temperature = rx / temp_scale;
RCMISbed 4:fe45288757f6 230 }
RCMISbed 4:fe45288757f6 231
StressedDave 1:2c3322a8d417 232
StressedDave 0:24f23c36dd24 233 void BNO055::get_calib(void){
StressedDave 0:24f23c36dd24 234 readchar(BNO055_CALIB_STAT_ADDR);
StressedDave 0:24f23c36dd24 235 calib = rx;
RCMISbed 4:fe45288757f6 236 }
RCMISbed 4:fe45288757f6 237
StressedDave 1:2c3322a8d417 238
StressedDave 1:2c3322a8d417 239 void BNO055::read_calibration_data(void){
StressedDave 1:2c3322a8d417 240 char tempmode = op_mode;
StressedDave 1:2c3322a8d417 241 setmode(OPERATION_MODE_CONFIG);
StressedDave 1:2c3322a8d417 242 wait_ms(20);
StressedDave 1:2c3322a8d417 243 tx[0] = ACCEL_OFFSET_X_LSB_ADDR;
StressedDave 1:2c3322a8d417 244 _i2c.write(address,tx,1,true);
StressedDave 1:2c3322a8d417 245 _i2c.read(address,calibration,22,false);
StressedDave 1:2c3322a8d417 246 setmode(tempmode);
StressedDave 1:2c3322a8d417 247 wait_ms(10);
RCMISbed 4:fe45288757f6 248 }
RCMISbed 4:fe45288757f6 249
StressedDave 1:2c3322a8d417 250
StressedDave 1:2c3322a8d417 251 void BNO055::write_calibration_data(void){
StressedDave 1:2c3322a8d417 252 char tempmode = op_mode;
StressedDave 1:2c3322a8d417 253 setmode(OPERATION_MODE_CONFIG);
StressedDave 1:2c3322a8d417 254 wait_ms(20);
StressedDave 1:2c3322a8d417 255 tx[0] = ACCEL_OFFSET_X_LSB_ADDR;
StressedDave 1:2c3322a8d417 256 _i2c.write(address,tx,1,true);
StressedDave 1:2c3322a8d417 257 _i2c.write(address,calibration,22,false);
StressedDave 1:2c3322a8d417 258 setmode(tempmode);
StressedDave 1:2c3322a8d417 259 wait_ms(10);
RCMISbed 4:fe45288757f6 260 }
RCMISbed 4:fe45288757f6 261
StressedDave 1:2c3322a8d417 262
StressedDave 1:2c3322a8d417 263 void BNO055::set_mapping(char orient){
StressedDave 1:2c3322a8d417 264 switch (orient){
StressedDave 1:2c3322a8d417 265 case 0:
StressedDave 1:2c3322a8d417 266 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x21);
StressedDave 1:2c3322a8d417 267 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x04);
StressedDave 1:2c3322a8d417 268 break;
StressedDave 1:2c3322a8d417 269 case 1:
StressedDave 1:2c3322a8d417 270 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x24);
StressedDave 1:2c3322a8d417 271 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x00);
StressedDave 1:2c3322a8d417 272 break;
StressedDave 1:2c3322a8d417 273 case 2:
StressedDave 1:2c3322a8d417 274 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x24);
StressedDave 1:2c3322a8d417 275 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x00);
StressedDave 1:2c3322a8d417 276 break;
StressedDave 1:2c3322a8d417 277 case 3:
StressedDave 1:2c3322a8d417 278 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x21);
StressedDave 1:2c3322a8d417 279 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x02);
StressedDave 1:2c3322a8d417 280 break;
StressedDave 1:2c3322a8d417 281 case 4:
StressedDave 1:2c3322a8d417 282 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x24);
StressedDave 1:2c3322a8d417 283 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x03);
StressedDave 1:2c3322a8d417 284 break;
StressedDave 1:2c3322a8d417 285 case 5:
StressedDave 1:2c3322a8d417 286 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x21);
StressedDave 1:2c3322a8d417 287 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x01);
StressedDave 1:2c3322a8d417 288 break;
StressedDave 1:2c3322a8d417 289 case 6:
StressedDave 1:2c3322a8d417 290 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x21);
StressedDave 1:2c3322a8d417 291 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x07);
StressedDave 1:2c3322a8d417 292 break;
StressedDave 1:2c3322a8d417 293 case 7:
StressedDave 1:2c3322a8d417 294 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x24);
StressedDave 1:2c3322a8d417 295 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x05);
StressedDave 1:2c3322a8d417 296 break;
StressedDave 1:2c3322a8d417 297 default:
StressedDave 1:2c3322a8d417 298 writechar(BNO055_AXIS_MAP_CONFIG_ADDR,0x24);
StressedDave 1:2c3322a8d417 299 writechar(BNO055_AXIS_MAP_SIGN_ADDR,0x00);
StressedDave 1:2c3322a8d417 300 }
RCMISbed 4:fe45288757f6 301 }