mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 10:08:28 -04:00
53 lines
1.6 KiB
C++
53 lines
1.6 KiB
C++
|
#include <AP_HAL/AP_HAL.h>
|
||
|
#include "AP_InertialSensor_ExternalAHRS.h"
|
||
|
#include <AP_ExternalAHRS/AP_ExternalAHRS.h>
|
||
|
|
||
|
#if HAL_EXTERNAL_AHRS_ENABLED
|
||
|
|
||
|
const extern AP_HAL::HAL& hal;
|
||
|
|
||
|
AP_InertialSensor_ExternalAHRS::AP_InertialSensor_ExternalAHRS(AP_InertialSensor &imu, uint8_t _serial_port) :
|
||
|
AP_InertialSensor_Backend(imu),
|
||
|
serial_port(_serial_port)
|
||
|
{
|
||
|
}
|
||
|
|
||
|
void AP_InertialSensor_ExternalAHRS::handle_external(const AP_ExternalAHRS::ins_data_message_t &pkt)
|
||
|
{
|
||
|
Vector3f accel = pkt.accel;
|
||
|
Vector3f gyro = pkt.gyro;
|
||
|
|
||
|
_rotate_and_correct_accel(accel_instance, accel);
|
||
|
_notify_new_accel_raw_sample(accel_instance, accel, AP_HAL::micros64());
|
||
|
|
||
|
_publish_temperature(accel_instance, pkt.temperature);
|
||
|
|
||
|
_notify_new_gyro_sensor_rate_sample(gyro_instance, gyro);
|
||
|
_rotate_and_correct_gyro(gyro_instance, gyro);
|
||
|
_notify_new_gyro_raw_sample(gyro_instance, gyro, AP_HAL::micros64());
|
||
|
}
|
||
|
|
||
|
bool AP_InertialSensor_ExternalAHRS::update(void)
|
||
|
{
|
||
|
update_accel(accel_instance);
|
||
|
update_gyro(gyro_instance);
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
void AP_InertialSensor_ExternalAHRS::start()
|
||
|
{
|
||
|
const float rate = AP::externalAHRS().get_IMU_rate();
|
||
|
gyro_instance = _imu.register_gyro(rate,
|
||
|
AP_HAL::Device::make_bus_id(AP_HAL::Device::BUS_TYPE_SERIAL, serial_port, 1, DEVTYPE_SERIAL));
|
||
|
accel_instance = _imu.register_accel(rate,
|
||
|
AP_HAL::Device::make_bus_id(AP_HAL::Device::BUS_TYPE_SERIAL, serial_port, 2, DEVTYPE_SERIAL));
|
||
|
}
|
||
|
|
||
|
void AP_InertialSensor_ExternalAHRS::accumulate()
|
||
|
{
|
||
|
AP::externalAHRS().update();
|
||
|
}
|
||
|
|
||
|
#endif // HAL_EXTERNAL_AHRS_ENABLED
|
||
|
|