/* SITL handling This simulates a compass Andrew Tridgell November 2011 */ #include #if CONFIG_HAL_BOARD == HAL_BOARD_AVR_SITL #include #include #include "AP_HAL_AVR_SITL_Namespace.h" #include "HAL_AVR_SITL_Class.h" #include #include "../AP_Compass/AP_Compass.h" #include "../AP_Declination/AP_Declination.h" #include "../SITL/SITL.h" using namespace AVR_SITL; /* setup the compass with new input all inputs are in degrees */ void SITL_State::_update_compass(float rollDeg, float pitchDeg, float yawDeg) { if (_compass == NULL) { // no compass in this sketch return; } _compass->setHIL(radians(rollDeg), radians(pitchDeg), radians(yawDeg)); Vector3f noise = _rand_vec3f() * _sitl->mag_noise; _compass->mag_x += noise.x; _compass->mag_y += noise.y; _compass->mag_z += noise.z; } #endif