2011-02-14 00:27:07 -04:00
|
|
|
/*
|
2012-08-17 03:19:22 -03:00
|
|
|
* AP_Compass_HIL.cpp - Arduino Library for HIL model of HMC5843 I2C Magnetometer
|
|
|
|
* Code by James Goppert. DIYDrones.com
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and / or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*/
|
2011-02-14 00:27:07 -04:00
|
|
|
|
|
|
|
|
2012-10-11 17:48:39 -03:00
|
|
|
#include <AP_HAL.h>
|
2011-02-14 00:27:07 -04:00
|
|
|
#include "AP_Compass_HIL.h"
|
|
|
|
|
2012-10-11 17:48:39 -03:00
|
|
|
extern const AP_HAL::HAL& hal;
|
|
|
|
|
2011-02-14 00:27:07 -04:00
|
|
|
// Public Methods //////////////////////////////////////////////////////////////
|
|
|
|
|
2011-12-28 05:31:36 -04:00
|
|
|
bool AP_Compass_HIL::read()
|
2011-02-14 00:27:07 -04:00
|
|
|
{
|
2013-03-01 10:58:55 -04:00
|
|
|
// get offsets
|
|
|
|
Vector3f ofs = _offset.get();
|
|
|
|
|
2013-03-03 10:02:12 -04:00
|
|
|
// apply motor compensation
|
|
|
|
if(_motor_comp_type != AP_COMPASS_MOT_COMP_DISABLED && _thr_or_curr != 0.0f) {
|
|
|
|
_motor_offset = _motor_compensation.get() * _thr_or_curr;
|
|
|
|
}else{
|
|
|
|
_motor_offset.x = 0;
|
|
|
|
_motor_offset.y = 0;
|
|
|
|
_motor_offset.z = 0;
|
|
|
|
}
|
2013-03-01 10:58:55 -04:00
|
|
|
|
|
|
|
// return last values provided by setHIL function
|
|
|
|
mag_x = _hil_mag.x + ofs.x + _motor_offset.x;
|
|
|
|
mag_y = _hil_mag.y + ofs.y + _motor_offset.y;
|
|
|
|
mag_z = _hil_mag.z + ofs.z + _motor_offset.z;
|
|
|
|
|
2012-08-17 03:19:22 -03:00
|
|
|
// values set by setHIL function
|
2012-10-11 17:48:39 -03:00
|
|
|
last_update = hal.scheduler->micros(); // record time of update
|
2012-08-17 03:19:22 -03:00
|
|
|
return true;
|
2011-02-14 00:27:07 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// Update raw magnetometer values from HIL data
|
|
|
|
//
|
|
|
|
void AP_Compass_HIL::setHIL(float _mag_x, float _mag_y, float _mag_z)
|
|
|
|
{
|
2013-03-01 10:58:55 -04:00
|
|
|
_hil_mag.x = _mag_x;
|
|
|
|
_hil_mag.y = _mag_y;
|
|
|
|
_hil_mag.z = _mag_z;
|
2013-05-01 23:27:35 -03:00
|
|
|
|
|
|
|
// apply default board orientation for this compass type. This is
|
|
|
|
// a noop on most boards
|
|
|
|
_hil_mag.rotate(MAG_BOARD_ORIENTATION);
|
|
|
|
|
|
|
|
// add user selectable orientation
|
|
|
|
_hil_mag.rotate((enum Rotation)_orientation.get());
|
|
|
|
|
|
|
|
// and add in AHRS_ORIENTATION setting
|
|
|
|
_hil_mag.rotate(_board_orientation);
|
|
|
|
|
2012-08-17 03:19:22 -03:00
|
|
|
healthy = true;
|
2011-02-14 00:27:07 -04:00
|
|
|
}
|
2012-08-26 00:42:00 -03:00
|
|
|
|
|
|
|
void AP_Compass_HIL::accumulate(void)
|
|
|
|
{
|
|
|
|
// nothing to do
|
|
|
|
}
|