mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-14 20:58:30 -04:00
8bd26dffac
Since, the frontend takes care of rotating sensor frame target vector to body frame, the sitl backend should return unit vector in sensor frame instead of body frame. This is to have homogeneity among backends.
58 lines
1.9 KiB
C++
58 lines
1.9 KiB
C++
#include <AP_HAL/AP_HAL.h>
|
|
#include "AC_PrecLand_SITL.h"
|
|
|
|
#if CONFIG_HAL_BOARD == HAL_BOARD_SITL
|
|
|
|
#include "AP_AHRS/AP_AHRS.h"
|
|
// init - perform initialisation of this backend
|
|
void AC_PrecLand_SITL::init()
|
|
{
|
|
_sitl = AP::sitl();
|
|
}
|
|
|
|
// update - give chance to driver to get updates from sensor
|
|
void AC_PrecLand_SITL::update()
|
|
{
|
|
_state.healthy = _sitl->precland_sim.healthy();
|
|
|
|
if (_state.healthy && _sitl->precland_sim.last_update_ms() != _los_meas_time_ms) {
|
|
const Vector3d position = _sitl->precland_sim.get_target_position();
|
|
const Matrix3d body_to_ned = AP::ahrs().get_rotation_body_to_ned().todouble();
|
|
_los_meas_body = body_to_ned.mul_transpose(-position).tofloat();
|
|
_distance_to_target = _sitl->precland_sim.option_enabled(SITL::SIM_Precland::Option::ENABLE_TARGET_DISTANCE) ? _los_meas_body.length() : 0.0f;
|
|
_los_meas_body /= _los_meas_body.length();
|
|
|
|
if (_frontend._orient != Rotation::ROTATION_PITCH_270) {
|
|
// rotate body frame vector based on orientation
|
|
// this is done to have homogeneity among backends
|
|
// frontend rotates it back to get correct body frame vector
|
|
_los_meas_body.rotate_inverse(_frontend._orient);
|
|
_los_meas_body.rotate_inverse(ROTATION_PITCH_90);
|
|
}
|
|
|
|
_have_los_meas = true;
|
|
_los_meas_time_ms = _sitl->precland_sim.last_update_ms();
|
|
} else {
|
|
_have_los_meas = false;
|
|
}
|
|
|
|
_have_los_meas = _have_los_meas && AP_HAL::millis() - _los_meas_time_ms <= 1000;
|
|
}
|
|
|
|
bool AC_PrecLand_SITL::have_los_meas() {
|
|
return AP_HAL::millis() - _los_meas_time_ms < 1000;
|
|
}
|
|
|
|
// provides a unit vector towards the target in body frame
|
|
// returns same as have_los_meas()
|
|
bool AC_PrecLand_SITL::get_los_body(Vector3f& ret) {
|
|
if (AP_HAL::millis() - _los_meas_time_ms > 1000) {
|
|
// no measurement for a full second; no vector available
|
|
return false;
|
|
}
|
|
ret = _los_meas_body;
|
|
return true;
|
|
}
|
|
|
|
#endif
|