2019-07-02 20:52:45 -03:00
# include "AP_NavEKF3.h"
2020-11-10 07:51:23 -04:00
# include "AP_NavEKF3_core.h"
2019-07-02 20:52:45 -03:00
# include <AP_HAL/HAL.h>
# include <AP_Logger/AP_Logger.h>
2020-11-05 19:30:16 -04:00
# include <AP_DAL/AP_DAL.h>
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_XKF1 ( uint64_t time_us ) const
2019-07-02 20:52:45 -03:00
{
2020-11-05 19:30:16 -04:00
// Write first EKF packet
2019-07-02 20:52:45 -03:00
Vector3f euler ;
Vector2f posNE ;
float posD ;
Vector3f velNED ;
Vector3f gyroBias ;
float posDownDeriv ;
Location originLLH ;
2020-11-10 07:51:23 -04:00
getEulerAngles ( euler ) ;
getVelNED ( velNED ) ;
getPosNE ( posNE ) ;
getPosD ( posD ) ;
getGyroBias ( gyroBias ) ;
posDownDeriv = getPosDownDerivative ( ) ;
if ( ! getOriginLLH ( originLLH ) ) {
2019-07-02 20:52:45 -03:00
originLLH . alt = 0 ;
}
2020-12-03 06:13:12 -04:00
const struct log_XKF1 pkt {
2019-12-06 03:16:12 -04:00
LOG_PACKET_HEADER_INIT ( LOG_XKF1_MSG ) ,
2019-07-02 20:52:45 -03:00
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
2019-07-02 20:52:45 -03:00
roll : ( int16_t ) ( 100 * degrees ( euler . x ) ) , // roll angle (centi-deg, displayed as deg due to format string)
pitch : ( int16_t ) ( 100 * degrees ( euler . y ) ) , // pitch angle (centi-deg, displayed as deg due to format string)
yaw : ( uint16_t ) wrap_360_cd ( 100 * degrees ( euler . z ) ) , // yaw angle (centi-deg, displayed as deg due to format string)
velN : ( float ) ( velNED . x ) , // velocity North (m/s)
velE : ( float ) ( velNED . y ) , // velocity East (m/s)
velD : ( float ) ( velNED . z ) , // velocity Down (m/s)
posD_dot : ( float ) ( posDownDeriv ) , // first derivative of down position
posN : ( float ) ( posNE . x ) , // metres North
posE : ( float ) ( posNE . y ) , // metres East
posD : ( float ) ( posD ) , // metres Down
gyrX : ( int16_t ) ( 100 * degrees ( gyroBias . x ) ) , // cd/sec, displayed as deg/sec due to format string
gyrY : ( int16_t ) ( 100 * degrees ( gyroBias . y ) ) , // cd/sec, displayed as deg/sec due to format string
gyrZ : ( int16_t ) ( 100 * degrees ( gyroBias . z ) ) , // cd/sec, displayed as deg/sec due to format string
originHgt : originLLH . alt // WGS-84 altitude of EKF origin in cm
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pkt , sizeof ( pkt ) ) ;
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_XKF2 ( uint64_t time_us ) const
2019-07-02 22:48:50 -03:00
{
2019-07-02 20:52:45 -03:00
// Write second EKF packet
Vector3f accelBias ;
Vector3f wind ;
Vector3f magNED ;
Vector3f magXYZ ;
2020-11-10 07:51:23 -04:00
getAccelBias ( accelBias ) ;
getWind ( wind ) ;
getMagNED ( magNED ) ;
getMagXYZ ( magXYZ ) ;
2020-11-20 17:39:04 -04:00
Vector2f dragInnov ;
float betaInnov = 0 ;
getSynthAirDataInnovations ( dragInnov , betaInnov ) ;
2020-03-29 19:52:10 -03:00
const struct log_XKF2 pkt2 {
2019-12-06 03:16:12 -04:00
LOG_PACKET_HEADER_INIT ( LOG_XKF2_MSG ) ,
2019-07-02 20:52:45 -03:00
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
2019-07-02 20:52:45 -03:00
accBiasX : ( int16_t ) ( 100 * accelBias . x ) ,
accBiasY : ( int16_t ) ( 100 * accelBias . y ) ,
accBiasZ : ( int16_t ) ( 100 * accelBias . z ) ,
windN : ( int16_t ) ( 100 * wind . x ) ,
windE : ( int16_t ) ( 100 * wind . y ) ,
magN : ( int16_t ) ( magNED . x ) ,
magE : ( int16_t ) ( magNED . y ) ,
magD : ( int16_t ) ( magNED . z ) ,
magX : ( int16_t ) ( magXYZ . x ) ,
magY : ( int16_t ) ( magXYZ . y ) ,
2020-11-20 17:39:04 -04:00
magZ : ( int16_t ) ( magXYZ . z ) ,
innovDragX : dragInnov . x ,
innovDragY : dragInnov . y ,
innovSideslip : betaInnov
2019-07-02 20:52:45 -03:00
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pkt2 , sizeof ( pkt2 ) ) ;
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_XKFS ( uint64_t time_us ) const
2020-06-23 13:35:34 -03:00
{
// Write sensor selection EKF packet
2020-12-01 20:49:19 -04:00
const struct log_XKFS pkt {
2020-06-23 13:35:34 -03:00
LOG_PACKET_HEADER_INIT ( LOG_XKFS_MSG ) ,
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
mag_index : magSelectIndex ,
baro_index : selected_baro ,
gps_index : selected_gps ,
airspeed_index : getActiveAirspeed ( )
2020-06-23 13:35:34 -03:00
} ;
AP : : logger ( ) . WriteBlock ( & pkt , sizeof ( pkt ) ) ;
}
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_XKF3 ( uint64_t time_us ) const
2019-07-02 22:48:50 -03:00
{
2019-07-02 20:52:45 -03:00
// Write third EKF packet
Vector3f velInnov ;
Vector3f posInnov ;
Vector3f magInnov ;
float tasInnov = 0 ;
float yawInnov = 0 ;
2020-11-10 07:51:23 -04:00
getInnovations ( velInnov , posInnov , magInnov , tasInnov , yawInnov ) ;
2020-12-01 20:49:19 -04:00
const struct log_XKF3 pkt3 {
2019-12-06 03:16:12 -04:00
LOG_PACKET_HEADER_INIT ( LOG_XKF3_MSG ) ,
2019-07-02 20:52:45 -03:00
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
2019-07-02 20:52:45 -03:00
innovVN : ( int16_t ) ( 100 * velInnov . x ) ,
innovVE : ( int16_t ) ( 100 * velInnov . y ) ,
innovVD : ( int16_t ) ( 100 * velInnov . z ) ,
innovPN : ( int16_t ) ( 100 * posInnov . x ) ,
innovPE : ( int16_t ) ( 100 * posInnov . y ) ,
innovPD : ( int16_t ) ( 100 * posInnov . z ) ,
innovMX : ( int16_t ) ( magInnov . x ) ,
innovMY : ( int16_t ) ( magInnov . y ) ,
innovMZ : ( int16_t ) ( magInnov . z ) ,
innovYaw : ( int16_t ) ( 100 * degrees ( yawInnov ) ) ,
2020-06-19 03:21:46 -03:00
innovVT : ( int16_t ) ( 100 * tasInnov ) ,
2020-11-10 07:51:23 -04:00
rerr : frontend - > coreRelativeErrors [ core_index ] ,
errorScore : frontend - > coreErrorScores [ core_index ]
2019-07-02 20:52:45 -03:00
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pkt3 , sizeof ( pkt3 ) ) ;
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_XKF4 ( uint64_t time_us ) const
2019-07-02 22:48:50 -03:00
{
2019-07-02 20:52:45 -03:00
// Write fourth EKF packet
float velVar = 0 ;
float posVar = 0 ;
float hgtVar = 0 ;
Vector3f magVar ;
float tasVar = 0 ;
2020-11-10 07:51:23 -04:00
uint16_t _faultStatus = 0 ;
2019-07-02 20:52:45 -03:00
Vector2f offset ;
uint8_t timeoutStatus = 0 ;
nav_filter_status solutionStatus { } ;
nav_gps_status gpsStatus { } ;
2020-11-10 07:51:23 -04:00
getVariances ( velVar , posVar , hgtVar , magVar , tasVar , offset ) ;
2019-07-02 20:52:45 -03:00
float tempVar = fmaxf ( fmaxf ( magVar . x , magVar . y ) , magVar . z ) ;
2020-11-10 07:51:23 -04:00
getFilterFaults ( _faultStatus ) ;
getFilterTimeouts ( timeoutStatus ) ;
getFilterStatus ( solutionStatus ) ;
getFilterGpsStatus ( gpsStatus ) ;
2019-07-02 20:52:45 -03:00
float tiltError ;
2020-11-10 07:51:23 -04:00
getTiltError ( tiltError ) ;
2019-07-02 22:48:50 -03:00
const struct log_NKF4 pkt4 {
2019-12-06 03:16:12 -04:00
LOG_PACKET_HEADER_INIT ( LOG_XKF4_MSG ) ,
2019-07-02 20:52:45 -03:00
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
2019-07-02 20:52:45 -03:00
sqrtvarV : ( int16_t ) ( 100 * velVar ) ,
sqrtvarP : ( int16_t ) ( 100 * posVar ) ,
sqrtvarH : ( int16_t ) ( 100 * hgtVar ) ,
sqrtvarM : ( int16_t ) ( 100 * tempVar ) ,
sqrtvarVT : ( int16_t ) ( 100 * tasVar ) ,
2020-11-10 07:51:23 -04:00
tiltErr : tiltError ,
2019-07-02 20:52:45 -03:00
offsetNorth : ( int8_t ) ( offset . x ) ,
offsetEast : ( int8_t ) ( offset . y ) ,
2020-11-10 07:51:23 -04:00
faults : _faultStatus ,
timeouts : timeoutStatus ,
solution : solutionStatus . value ,
gps : gpsStatus . value ,
primary : frontend - > getPrimaryCoreIndex ( )
2019-07-02 20:52:45 -03:00
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pkt4 , sizeof ( pkt4 ) ) ;
}
2019-07-02 20:52:45 -03:00
2019-07-02 22:48:50 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_XKF5 ( uint64_t time_us ) const
2019-07-02 22:48:50 -03:00
{
2020-11-10 07:51:23 -04:00
if ( core_index ! = frontend - > primary ) {
2020-11-05 19:30:16 -04:00
// log only primary instance for now
return ;
}
2019-07-02 22:48:50 -03:00
const struct log_NKF5 pkt5 {
2019-07-02 20:52:45 -03:00
LOG_PACKET_HEADER_INIT ( LOG_XKF5_MSG ) ,
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
normInnov : ( uint8_t ) ( MIN ( 100 * MAX ( flowTestRatio [ 0 ] , flowTestRatio [ 1 ] ) , 255 ) ) , // normalised innovation variance ratio for optical flow observations fused by the main nav filter
FIX : ( int16_t ) ( 1000 * innovOptFlow [ 0 ] ) , // optical flow LOS rate vector innovations from the main nav filter
FIY : ( int16_t ) ( 1000 * innovOptFlow [ 1 ] ) , // optical flow LOS rate vector innovations from the main nav filter
AFI : ( int16_t ) ( 1000 * norm ( auxFlowObsInnov . x , auxFlowObsInnov . y ) ) , // optical flow LOS rate innovation from terrain offset estimator
HAGL : ( int16_t ) ( 100 * ( terrainState - stateStruct . position . z ) ) , // height above ground level
offset : ( int16_t ) ( 100 * terrainState ) , // filter ground offset state error
RI : ( int16_t ) ( 100 * innovRng ) , // range finder innovations
meaRng : ( uint16_t ) ( 100 * rangeDataDelayed . rng ) , // measured range
errHAGL : ( uint16_t ) ( 100 * sqrtf ( Popt ) ) , // note Popt is constrained to be non-negative in EstimateTerrainOffset()
angErr : ( float ) outputTrackError . x , // output predictor angle error
velErr : ( float ) outputTrackError . y , // output predictor velocity error
posErr : ( float ) outputTrackError . z // output predictor position tracking error
2020-06-19 03:21:46 -03:00
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pkt5 , sizeof ( pkt5 ) ) ;
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_Quaternion ( uint64_t time_us ) const
2019-07-02 22:48:50 -03:00
{
2019-07-02 20:52:45 -03:00
// log quaternion
Quaternion quat ;
2020-11-10 07:51:23 -04:00
getQuaternion ( quat ) ;
2020-12-01 20:49:19 -04:00
const struct log_XKQ pktq1 {
2019-12-06 03:16:12 -04:00
LOG_PACKET_HEADER_INIT ( LOG_XKQ_MSG ) ,
2019-07-02 20:52:45 -03:00
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
2019-07-02 20:52:45 -03:00
q1 : quat . q1 ,
q2 : quat . q2 ,
q3 : quat . q3 ,
q4 : quat . q4
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pktq1 , sizeof ( pktq1 ) ) ;
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
// logs beacon information, one beacon per call
void NavEKF3_core : : Log_Write_Beacon ( uint64_t time_us )
2019-07-02 22:48:50 -03:00
{
2020-11-10 07:51:23 -04:00
if ( core_index ! = frontend - > primary ) {
2020-11-05 19:30:16 -04:00
// log only primary instance for now
return ;
}
2020-11-26 19:55:09 -04:00
if ( ! statesInitialised | | N_beacons = = 0 | | rngBcnFusionReport = = nullptr ) {
2020-11-10 07:51:23 -04:00
return ;
}
// Ensure that beacons are not skipped due to calling this function at a rate lower than the updates
if ( rngBcnFuseDataReportIndex > = N_beacons ) {
rngBcnFuseDataReportIndex = 0 ;
}
const rngBcnFusionReport_t & report = rngBcnFusionReport [ rngBcnFuseDataReportIndex ] ;
2019-07-02 20:52:45 -03:00
// write range beacon fusion debug packet if the range value is non-zero
2020-11-10 07:51:23 -04:00
if ( report . rng < = 0.0f ) {
rngBcnFuseDataReportIndex + + ;
return ;
2019-07-02 20:52:45 -03:00
}
2020-11-10 07:51:23 -04:00
2020-12-01 20:49:19 -04:00
const struct log_XKF0 pkt10 {
2020-12-02 19:43:39 -04:00
LOG_PACKET_HEADER_INIT ( LOG_XKF0_MSG ) ,
2020-11-10 07:51:23 -04:00
time_us : time_us ,
core : DAL_CORE ( core_index ) ,
ID : rngBcnFuseDataReportIndex ,
rng : ( int16_t ) ( 100 * report . rng ) ,
innov : ( int16_t ) ( 100 * report . innov ) ,
sqrtInnovVar : ( uint16_t ) ( 100 * sqrtf ( report . innovVar ) ) ,
testRatio : ( uint16_t ) ( 100 * constrain_float ( report . testRatio , 0.0f , 650.0f ) ) ,
beaconPosN : ( int16_t ) ( 100 * report . beaconPosNED . x ) ,
beaconPosE : ( int16_t ) ( 100 * report . beaconPosNED . y ) ,
beaconPosD : ( int16_t ) ( 100 * report . beaconPosNED . z ) ,
offsetHigh : ( int16_t ) ( 100 * bcnPosDownOffsetMax ) ,
offsetLow : ( int16_t ) ( 100 * bcnPosDownOffsetMin ) ,
posN : ( int16_t ) ( 100 * receiverPos . x ) ,
posE : ( int16_t ) ( 100 * receiverPos . y ) ,
posD : ( int16_t ) ( 100 * receiverPos . z )
} ;
AP : : logger ( ) . WriteBlock ( & pkt10 , sizeof ( pkt10 ) ) ;
rngBcnFuseDataReportIndex + + ;
2019-07-02 22:48:50 -03:00
}
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_BodyOdom ( uint64_t time_us )
2019-07-02 22:48:50 -03:00
{
2020-11-10 07:51:23 -04:00
if ( core_index ! = frontend - > primary ) {
2020-11-05 19:30:16 -04:00
// log only primary instance for now
return ;
}
2019-07-02 20:52:45 -03:00
Vector3f velBodyInnov , velBodyInnovVar ;
static uint32_t lastUpdateTime_ms = 0 ;
2020-11-10 07:51:23 -04:00
uint32_t updateTime_ms = getBodyFrameOdomDebug ( velBodyInnov , velBodyInnovVar ) ;
2019-07-02 20:52:45 -03:00
if ( updateTime_ms > lastUpdateTime_ms ) {
2020-12-01 20:49:19 -04:00
const struct log_XKFD pkt11 {
2019-07-02 20:52:45 -03:00
LOG_PACKET_HEADER_INIT ( LOG_XKFD_MSG ) ,
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
2019-07-02 20:52:45 -03:00
velInnovX : velBodyInnov . x ,
velInnovY : velBodyInnov . y ,
velInnovZ : velBodyInnov . z ,
velInnovVarX : velBodyInnovVar . x ,
velInnovVarY : velBodyInnovVar . y ,
velInnovVarZ : velBodyInnovVar . z
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pkt11 , sizeof ( pkt11 ) ) ;
2019-07-02 20:52:45 -03:00
lastUpdateTime_ms = updateTime_ms ;
}
2019-07-02 22:48:50 -03:00
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_State_Variances ( uint64_t time_us ) const
2019-07-02 22:48:50 -03:00
{
2020-11-10 07:51:23 -04:00
if ( core_index ! = frontend - > primary ) {
2020-11-05 19:30:16 -04:00
// log only primary instance for now
return ;
}
2019-07-02 20:52:45 -03:00
static uint32_t lastEkfStateVarLogTime_ms = 0 ;
2020-11-05 19:30:16 -04:00
if ( AP : : dal ( ) . millis ( ) - lastEkfStateVarLogTime_ms > 490 ) {
lastEkfStateVarLogTime_ms = AP : : dal ( ) . millis ( ) ;
2020-12-01 20:49:19 -04:00
const struct log_XKV pktv1 {
2019-07-02 20:52:45 -03:00
LOG_PACKET_HEADER_INIT ( LOG_XKV1_MSG ) ,
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
v00 : P [ 0 ] [ 0 ] ,
v01 : P [ 1 ] [ 1 ] ,
v02 : P [ 2 ] [ 2 ] ,
v03 : P [ 3 ] [ 3 ] ,
v04 : P [ 4 ] [ 4 ] ,
v05 : P [ 5 ] [ 5 ] ,
v06 : P [ 6 ] [ 6 ] ,
v07 : P [ 7 ] [ 7 ] ,
v08 : P [ 8 ] [ 8 ] ,
v09 : P [ 9 ] [ 9 ] ,
v10 : P [ 10 ] [ 10 ] ,
v11 : P [ 11 ] [ 11 ]
2019-07-02 20:52:45 -03:00
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pktv1 , sizeof ( pktv1 ) ) ;
2020-12-01 20:49:19 -04:00
const struct log_XKV pktv2 {
2019-07-02 20:52:45 -03:00
LOG_PACKET_HEADER_INIT ( LOG_XKV2_MSG ) ,
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : DAL_CORE ( core_index ) ,
v00 : P [ 12 ] [ 12 ] ,
v01 : P [ 13 ] [ 13 ] ,
v02 : P [ 14 ] [ 14 ] ,
v03 : P [ 15 ] [ 15 ] ,
v04 : P [ 16 ] [ 16 ] ,
v05 : P [ 17 ] [ 17 ] ,
v06 : P [ 18 ] [ 18 ] ,
v07 : P [ 19 ] [ 19 ] ,
v08 : P [ 20 ] [ 20 ] ,
v09 : P [ 21 ] [ 21 ] ,
v10 : P [ 22 ] [ 22 ] ,
v11 : P [ 23 ] [ 23 ]
2019-07-02 20:52:45 -03:00
} ;
2019-07-02 22:48:50 -03:00
AP : : logger ( ) . WriteBlock ( & pktv2 , sizeof ( pktv2 ) ) ;
}
}
void NavEKF3 : : Log_Write ( )
{
// only log if enabled
if ( activeCores ( ) < = 0 ) {
return ;
}
2020-11-05 20:02:55 -04:00
if ( lastLogWrite_us = = imuSampleTime_us ) {
// vehicle is doubling up on logging
return ;
}
lastLogWrite_us = imuSampleTime_us ;
2019-07-02 22:48:50 -03:00
2020-11-05 19:30:16 -04:00
uint64_t time_us = AP : : dal ( ) . micros64 ( ) ;
2019-07-02 22:48:50 -03:00
2019-12-06 03:16:12 -04:00
for ( uint8_t i = 0 ; i < activeCores ( ) ; i + + ) {
2020-11-10 07:51:23 -04:00
core [ i ] . Log_Write ( time_us ) ;
}
AP : : dal ( ) . start_frame ( AP_DAL : : FrameType : : LogWriteEKF3 ) ;
}
2020-11-05 19:30:16 -04:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write ( uint64_t time_us )
{
// note that several of these functions exit-early if they're not
// attempting to log the primary core.
Log_Write_XKF1 ( time_us ) ;
Log_Write_XKF2 ( time_us ) ;
Log_Write_XKF3 ( time_us ) ;
Log_Write_XKF4 ( time_us ) ;
Log_Write_XKF5 ( time_us ) ;
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
Log_Write_XKFS ( time_us ) ;
Log_Write_Quaternion ( time_us ) ;
Log_Write_GSF ( time_us ) ;
2020-11-05 19:30:16 -04:00
2020-11-10 07:51:23 -04:00
// write range beacon fusion debug packet if the range value is non-zero
Log_Write_Beacon ( time_us ) ;
2019-07-02 22:48:50 -03:00
2020-11-10 07:51:23 -04:00
// write debug data for body frame odometry fusion
Log_Write_BodyOdom ( time_us ) ;
2019-07-02 22:48:50 -03:00
2020-11-10 07:51:23 -04:00
// log state variances every 0.49s
Log_Write_State_Variances ( time_us ) ;
2020-11-05 19:30:16 -04:00
2020-11-10 07:51:23 -04:00
Log_Write_Timing ( time_us ) ;
2020-11-05 19:30:16 -04:00
}
2019-07-02 20:52:45 -03:00
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_Timing ( uint64_t time_us )
2020-11-05 19:30:16 -04:00
{
2019-07-02 20:52:45 -03:00
// log EKF timing statistics every 5s
static uint32_t lastTimingLogTime_ms = 0 ;
2020-11-05 19:30:16 -04:00
if ( AP : : dal ( ) . millis ( ) - lastTimingLogTime_ms < = 5000 ) {
return ;
2019-07-02 20:52:45 -03:00
}
2020-11-05 19:30:16 -04:00
lastTimingLogTime_ms = AP : : dal ( ) . millis ( ) ;
const struct log_XKT xkt {
LOG_PACKET_HEADER_INIT ( LOG_XKT_MSG ) ,
time_us : time_us ,
2020-11-10 07:51:23 -04:00
core : core_index ,
2020-11-05 19:30:16 -04:00
timing_count : timing . count ,
dtIMUavg_min : timing . dtIMUavg_min ,
dtIMUavg_max : timing . dtIMUavg_max ,
dtEKFavg_min : timing . dtEKFavg_min ,
dtEKFavg_max : timing . dtEKFavg_max ,
delAngDT_min : timing . delAngDT_min ,
delAngDT_max : timing . delAngDT_max ,
delVelDT_min : timing . delVelDT_min ,
delVelDT_max : timing . delVelDT_max ,
} ;
2020-11-10 07:51:23 -04:00
memset ( & timing , 0 , sizeof ( timing ) ) ;
2020-11-05 19:30:16 -04:00
AP : : logger ( ) . WriteBlock ( & xkt , sizeof ( xkt ) ) ;
2019-07-02 20:52:45 -03:00
}
2020-11-10 07:51:23 -04:00
void NavEKF3_core : : Log_Write_GSF ( uint64_t time_us )
2020-03-10 03:48:08 -03:00
{
2020-11-10 07:51:23 -04:00
if ( yawEstimator = = nullptr ) {
return ;
}
2020-03-10 03:48:08 -03:00
float yaw_composite ;
float yaw_composite_variance ;
float yaw [ N_MODELS_EKFGSF ] ;
float ivn [ N_MODELS_EKFGSF ] ;
float ive [ N_MODELS_EKFGSF ] ;
float wgt [ N_MODELS_EKFGSF ] ;
2020-11-10 07:51:23 -04:00
if ( ! yawEstimator - > getLogData ( yaw_composite , yaw_composite_variance , yaw , ivn , ive , wgt ) ) {
return ;
}
2020-04-23 18:11:54 -03:00
2020-11-15 17:58:48 -04:00
const struct log_XKY0 xky0 {
LOG_PACKET_HEADER_INIT ( LOG_XKY0_MSG ) ,
time_us : time_us ,
core : DAL_CORE ( core_index ) ,
yaw_composite : yaw_composite ,
yaw_composite_variance : sqrtf ( MAX ( yaw_composite_variance , 0.0f ) ) ,
yaw0 : yaw [ 0 ] ,
yaw1 : yaw [ 1 ] ,
yaw2 : yaw [ 2 ] ,
yaw3 : yaw [ 3 ] ,
yaw4 : yaw [ 4 ] ,
wgt0 : wgt [ 0 ] ,
wgt1 : wgt [ 1 ] ,
wgt2 : wgt [ 2 ] ,
wgt3 : wgt [ 3 ] ,
wgt4 : wgt [ 4 ] ,
} ;
AP : : logger ( ) . WriteBlock ( & xky0 , sizeof ( xky0 ) ) ;
const struct log_XKY1 xky1 {
LOG_PACKET_HEADER_INIT ( LOG_XKY1_MSG ) ,
time_us : time_us ,
core : DAL_CORE ( core_index ) ,
ivn0 : ivn [ 0 ] ,
ivn1 : ivn [ 1 ] ,
ivn2 : ivn [ 2 ] ,
ivn3 : ivn [ 3 ] ,
ivn4 : ivn [ 4 ] ,
ive0 : ive [ 0 ] ,
ive1 : ive [ 1 ] ,
ive2 : ive [ 2 ] ,
ive3 : ive [ 3 ] ,
ive4 : ive [ 4 ] ,
} ;
AP : : logger ( ) . WriteBlock ( & xky1 , sizeof ( xky1 ) ) ;
2020-04-23 19:32:21 -03:00
}