mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 01:58:29 -04:00
188 lines
6.1 KiB
C
188 lines
6.1 KiB
C
#pragma once
|
|
|
|
#include <AP_Logger/LogStructure.h>
|
|
|
|
#define LOG_IDS_FROM_AHRS \
|
|
LOG_AHR2_MSG, \
|
|
LOG_AOA_SSA_MSG, \
|
|
LOG_ATTITUDE_MSG, \
|
|
LOG_ORGN_MSG, \
|
|
LOG_POS_MSG, \
|
|
LOG_RATE_MSG
|
|
|
|
// @LoggerMessage: AHR2
|
|
// @Description: Backup AHRS data
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: Roll: Estimated roll
|
|
// @Field: Pitch: Estimated pitch
|
|
// @Field: Yaw: Estimated yaw
|
|
// @Field: Alt: Estimated altitude
|
|
// @Field: Lat: Estimated latitude
|
|
// @Field: Lng: Estimated longitude
|
|
// @Field: Q1: Estimated attitude quaternion component 1
|
|
// @Field: Q2: Estimated attitude quaternion component 2
|
|
// @Field: Q3: Estimated attitude quaternion component 3
|
|
// @Field: Q4: Estimated attitude quaternion component 4
|
|
struct PACKED log_AHRS {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
int16_t roll;
|
|
int16_t pitch;
|
|
uint16_t yaw;
|
|
float alt;
|
|
int32_t lat;
|
|
int32_t lng;
|
|
float q1, q2, q3, q4;
|
|
};
|
|
|
|
// @LoggerMessage: AOA
|
|
// @Description: Angle of attack and Side Slip Angle values
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: AOA: Angle of Attack calculated from airspeed, wind vector,velocity vector
|
|
// @Field: SSA: Side Slip Angle calculated from airspeed, wind vector,velocity vector
|
|
struct PACKED log_AOA_SSA {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
float AOA;
|
|
float SSA;
|
|
};
|
|
|
|
// @LoggerMessage: ATT
|
|
// @Description: Canonical vehicle attitude
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: DesRoll: vehicle desired roll
|
|
// @Field: Roll: achieved vehicle roll
|
|
// @Field: DesPitch: vehicle desired pitch
|
|
// @Field: Pitch: achieved vehicle pitch
|
|
// @Field: DesYaw: vehicle desired yaw
|
|
// @Field: Yaw: achieved vehicle yaw
|
|
// @Field: ErrRP: lowest estimated gyro drift error
|
|
// @Field: ErrYaw: difference between measured yaw and DCM yaw estimate
|
|
// @Field: AEKF: active EKF type
|
|
struct PACKED log_Attitude {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
int16_t control_roll;
|
|
int16_t roll;
|
|
int16_t control_pitch;
|
|
int16_t pitch;
|
|
uint16_t control_yaw;
|
|
uint16_t yaw;
|
|
uint16_t error_rp;
|
|
uint16_t error_yaw;
|
|
uint8_t active;
|
|
};
|
|
|
|
// @LoggerMessage: ORGN
|
|
// @Description: Vehicle navigation origin or other notable position
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: Type: Position type
|
|
// @Field: Lat: Position latitude
|
|
// @Field: Lng: Position longitude
|
|
// @Field: Alt: Position altitude
|
|
struct PACKED log_ORGN {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
uint8_t origin_type;
|
|
int32_t latitude;
|
|
int32_t longitude;
|
|
int32_t altitude;
|
|
};
|
|
|
|
// @LoggerMessage: POS
|
|
// @Description: Canonical vehicle position
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: Lat: Canonical vehicle latitude
|
|
// @Field: Lng: Canonical vehicle longitude
|
|
// @Field: Alt: Canonical vehicle altitude
|
|
// @Field: RelHomeAlt: Canonical vehicle altitude relative to home
|
|
// @Field: RelOriginAlt: Canonical vehicle altitude relative to navigation origin
|
|
struct PACKED log_POS {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
int32_t lat;
|
|
int32_t lng;
|
|
float alt;
|
|
float rel_home_alt;
|
|
float rel_origin_alt;
|
|
};
|
|
|
|
// @LoggerMessage: RATE
|
|
// @Description: Desired and achieved vehicle attitude rates. Not logged in Fixed Wing Plane modes.
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: RDes: vehicle desired roll rate
|
|
// @Field: R: achieved vehicle roll rate
|
|
// @Field: ROut: normalized output for Roll
|
|
// @Field: PDes: vehicle desired pitch rate
|
|
// @Field: P: vehicle pitch rate
|
|
// @Field: POut: normalized output for Pitch
|
|
// @Field: Y: achieved vehicle yaw rate
|
|
// @Field: YOut: normalized output for Yaw
|
|
// @Field: YDes: vehicle desired yaw rate
|
|
// @Field: ADes: desired vehicle vertical acceleration
|
|
// @Field: A: achieved vehicle vertical acceleration
|
|
// @Field: AOut: percentage of vertical thrust output current being used
|
|
struct PACKED log_Rate {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
float control_roll;
|
|
float roll;
|
|
float roll_out;
|
|
float control_pitch;
|
|
float pitch;
|
|
float pitch_out;
|
|
float control_yaw;
|
|
float yaw;
|
|
float yaw_out;
|
|
float control_accel;
|
|
float accel;
|
|
float accel_out;
|
|
};
|
|
|
|
// @LoggerMessage: VSTB
|
|
// @Description: Log message for video stabilisation software such as Gyroflow
|
|
// @Field: TimeUS: Time since system startup
|
|
// @Field: GyrX: measured rotation rate about X axis
|
|
// @Field: GyrY: measured rotation rate about Y axis
|
|
// @Field: GyrZ: measured rotation rate about Z axis
|
|
// @Field: AccX: acceleration along X axis
|
|
// @Field: AccY: acceleration along Y axis
|
|
// @Field: AccZ: acceleration along Z axis
|
|
// @Field: Q1: Estimated attitude quaternion component 1
|
|
// @Field: Q2: Estimated attitude quaternion component 2
|
|
// @Field: Q3: Estimated attitude quaternion component 3
|
|
// @Field: Q4: Estimated attitude quaternion component 4
|
|
|
|
struct PACKED log_Video_Stabilisation {
|
|
LOG_PACKET_HEADER;
|
|
uint64_t time_us;
|
|
float gyro_x;
|
|
float gyro_y;
|
|
float gyro_z;
|
|
float accel_x;
|
|
float accel_y;
|
|
float accel_z;
|
|
float Q1;
|
|
float Q2;
|
|
float Q3;
|
|
float Q4;
|
|
};
|
|
|
|
|
|
#define LOG_STRUCTURE_FROM_AHRS \
|
|
{ LOG_AHR2_MSG, sizeof(log_AHRS), \
|
|
"AHR2","QccCfLLffff","TimeUS,Roll,Pitch,Yaw,Alt,Lat,Lng,Q1,Q2,Q3,Q4","sddhmDU????", "FBBB0GG????" , true }, \
|
|
{ LOG_AOA_SSA_MSG, sizeof(log_AOA_SSA), \
|
|
"AOA", "Qff", "TimeUS,AOA,SSA", "sdd", "F00" , true }, \
|
|
{ LOG_ATTITUDE_MSG, sizeof(log_Attitude),\
|
|
"ATT", "QccccCCCCB", "TimeUS,DesRoll,Roll,DesPitch,Pitch,DesYaw,Yaw,ErrRP,ErrYaw,AEKF", "sddddhhdh-", "FBBBBBBBB-" , true }, \
|
|
{ LOG_ORGN_MSG, sizeof(log_ORGN), \
|
|
"ORGN","QBLLe","TimeUS,Type,Lat,Lng,Alt", "s#DUm", "F-GGB" }, \
|
|
{ LOG_POS_MSG, sizeof(log_POS), \
|
|
"POS","QLLfff","TimeUS,Lat,Lng,Alt,RelHomeAlt,RelOriginAlt", "sDUmmm", "FGG000" , true }, \
|
|
{ LOG_RATE_MSG, sizeof(log_Rate), \
|
|
"RATE", "Qffffffffffff", "TimeUS,RDes,R,ROut,PDes,P,POut,YDes,Y,YOut,ADes,A,AOut", "skk-kk-kk-oo-", "F?????????BB-" , true }, \
|
|
{ LOG_VIDEO_STABILISATION_MSG, sizeof(log_Video_Stabilisation), \
|
|
"VSTB", "Qffffffffff", "TimeUS,GyrX,GyrY,GyrZ,AccX,AccY,AccZ,Q1,Q2,Q3,Q4", "sEEEooo????", "F000000????" },
|
|
|