AP_ExternalAHRS: Populate orientation from filter
* Populating AHRS orientation from IMU was not correct Signed-off-by: Ryan Friedman <ryanfriedman5410+github@gmail.com>
This commit is contained in:
parent
aefa41f22a
commit
3cb4d2ec3b
@ -90,7 +90,7 @@ public:
|
|||||||
|
|
||||||
Vector3f accel;
|
Vector3f accel;
|
||||||
Vector3f gyro;
|
Vector3f gyro;
|
||||||
Quaternion quat;
|
Quaternion quat; // NED
|
||||||
Location location;
|
Location location;
|
||||||
Vector3f velocity;
|
Vector3f velocity;
|
||||||
Location origin;
|
Location origin;
|
||||||
|
@ -134,9 +134,6 @@ void AP_ExternalAHRS_MicroStrain7::post_imu() const
|
|||||||
WITH_SEMAPHORE(state.sem);
|
WITH_SEMAPHORE(state.sem);
|
||||||
state.accel = imu_data.accel;
|
state.accel = imu_data.accel;
|
||||||
state.gyro = imu_data.gyro;
|
state.gyro = imu_data.gyro;
|
||||||
|
|
||||||
state.quat = imu_data.quat;
|
|
||||||
state.have_quaternion = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -188,6 +185,9 @@ void AP_ExternalAHRS_MicroStrain7::post_filter() const
|
|||||||
// Use GNSS 0 even though it may be bad.
|
// Use GNSS 0 even though it may be bad.
|
||||||
state.location = Location{filter_data.lat, filter_data.lon, gnss_data[0].msl_altitude, Location::AltFrame::ABSOLUTE};
|
state.location = Location{filter_data.lat, filter_data.lon, gnss_data[0].msl_altitude, Location::AltFrame::ABSOLUTE};
|
||||||
state.have_location = true;
|
state.have_location = true;
|
||||||
|
|
||||||
|
state.quat = filter_data.attitude_quat;
|
||||||
|
state.have_quaternion = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int instance = 0; instance < NUM_GNSS_INSTANCES; instance++) {
|
for (int instance = 0; instance < NUM_GNSS_INSTANCES; instance++) {
|
||||||
|
@ -58,6 +58,8 @@ enum class FilterPacketField {
|
|||||||
FILTER_STATUS = 0x10,
|
FILTER_STATUS = 0x10,
|
||||||
LLH_POSITION = 0x01,
|
LLH_POSITION = 0x01,
|
||||||
NED_VELOCITY = 0x02,
|
NED_VELOCITY = 0x02,
|
||||||
|
// https://s3.amazonaws.com/files.microstrain.com/GQ7+User+Manual/external_content/dcp/Data/filter_data/data/mip_field_filter_attitude_quaternion.htm
|
||||||
|
ATTITUDE_QUAT = 0x03,
|
||||||
// https://s3.amazonaws.com/files.microstrain.com/GQ7+User+Manual/external_content/dcp/Data/shared_data/data/mip_field_shared_gps_timestamp.htm
|
// https://s3.amazonaws.com/files.microstrain.com/GQ7+User+Manual/external_content/dcp/Data/shared_data/data/mip_field_shared_gps_timestamp.htm
|
||||||
GPS_TIMESTAMP = 0xD3,
|
GPS_TIMESTAMP = 0xD3,
|
||||||
};
|
};
|
||||||
@ -288,6 +290,11 @@ void AP_MicroStrain::handle_filter(const MicroStrain_Packet &packet)
|
|||||||
filter_data.ned_velocity_down = be32tofloat_ptr(packet.payload, i+10);
|
filter_data.ned_velocity_down = be32tofloat_ptr(packet.payload, i+10);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case FilterPacketField::ATTITUDE_QUAT: {
|
||||||
|
filter_data.attitude_quat = populate_quaternion(packet.payload, i+2);
|
||||||
|
filter_data.attitude_quat.normalize();
|
||||||
|
break;
|
||||||
|
}
|
||||||
case FilterPacketField::FILTER_STATUS: {
|
case FilterPacketField::FILTER_STATUS: {
|
||||||
filter_status.state = be16toh_ptr(&packet.payload[i+2]);
|
filter_status.state = be16toh_ptr(&packet.payload[i+2]);
|
||||||
filter_status.mode = be16toh_ptr(&packet.payload[i+4]);
|
filter_status.mode = be16toh_ptr(&packet.payload[i+4]);
|
||||||
@ -309,6 +316,9 @@ Vector3f AP_MicroStrain::populate_vector3f(const uint8_t *data, uint8_t offset)
|
|||||||
|
|
||||||
Quaternion AP_MicroStrain::populate_quaternion(const uint8_t *data, uint8_t offset)
|
Quaternion AP_MicroStrain::populate_quaternion(const uint8_t *data, uint8_t offset)
|
||||||
{
|
{
|
||||||
|
// https://github.com/clemense/quaternion-conventions
|
||||||
|
// AP follows W + Xi + Yj + Zk format.
|
||||||
|
// Microstrain follows the same
|
||||||
return Quaternion {
|
return Quaternion {
|
||||||
be32tofloat_ptr(data, offset),
|
be32tofloat_ptr(data, offset),
|
||||||
be32tofloat_ptr(data, offset+4),
|
be32tofloat_ptr(data, offset+4),
|
||||||
|
@ -86,6 +86,9 @@ protected:
|
|||||||
float ned_velocity_east;
|
float ned_velocity_east;
|
||||||
float ned_velocity_down;
|
float ned_velocity_down;
|
||||||
float speed_accuracy;
|
float speed_accuracy;
|
||||||
|
// 4x1 vector representation of the quaternion describing the orientation of the device with respect to the NED local-level frame.
|
||||||
|
// NED [Qw, Qx, Qy, Qz]
|
||||||
|
Quaternion attitude_quat;
|
||||||
} filter_data;
|
} filter_data;
|
||||||
|
|
||||||
enum class DescriptorSet {
|
enum class DescriptorSet {
|
||||||
|
Loading…
Reference in New Issue
Block a user