Browse Source

AP_NavEKF3: fixed gaps in EKF logging

timestamps should not be static as otherwise some lanes will not be
logged
c415-sdk
Andrew Tridgell 3 years ago committed by Randy Mackay
parent
commit
97cb2dd1c0
  1. 5
      libraries/AP_NavEKF3/AP_NavEKF3_Logging.cpp
  2. 1
      libraries/AP_NavEKF3/AP_NavEKF3_core.cpp
  3. 8
      libraries/AP_NavEKF3/AP_NavEKF3_core.h

5
libraries/AP_NavEKF3/AP_NavEKF3_Logging.cpp

@ -273,7 +273,6 @@ void NavEKF3_core::Log_Write_BodyOdom(uint64_t time_us) @@ -273,7 +273,6 @@ void NavEKF3_core::Log_Write_BodyOdom(uint64_t time_us)
return;
}
static uint32_t lastUpdateTime_ms = 0;
const uint32_t updateTime_ms = MAX(bodyOdmDataDelayed.time_ms,wheelOdmDataDelayed.time_ms);
if (updateTime_ms > lastUpdateTime_ms) {
const struct log_XKFD pkt11{
@ -293,14 +292,13 @@ void NavEKF3_core::Log_Write_BodyOdom(uint64_t time_us) @@ -293,14 +292,13 @@ void NavEKF3_core::Log_Write_BodyOdom(uint64_t time_us)
}
#endif
void NavEKF3_core::Log_Write_State_Variances(uint64_t time_us) const
void NavEKF3_core::Log_Write_State_Variances(uint64_t time_us)
{
if (core_index != frontend->primary) {
// log only primary instance for now
return;
}
static uint32_t lastEkfStateVarLogTime_ms = 0;
if (AP::dal().millis() - lastEkfStateVarLogTime_ms > 490) {
lastEkfStateVarLogTime_ms = AP::dal().millis();
const struct log_XKV pktv1{
@ -394,7 +392,6 @@ void NavEKF3_core::Log_Write(uint64_t time_us) @@ -394,7 +392,6 @@ void NavEKF3_core::Log_Write(uint64_t time_us)
void NavEKF3_core::Log_Write_Timing(uint64_t time_us)
{
// log EKF timing statistics every 5s
static uint32_t lastTimingLogTime_ms = 0;
if (AP::dal().millis() - lastTimingLogTime_ms <= 5000) {
return;
}

1
libraries/AP_NavEKF3/AP_NavEKF3_core.cpp

@ -2182,7 +2182,6 @@ void NavEKF3_core::verifyTiltErrorVariance() @@ -2182,7 +2182,6 @@ void NavEKF3_core::verifyTiltErrorVariance()
}
tiltErrorVarianceAlt = MIN(tiltErrorVarianceAlt, sq(radians(30.0f)));
static uint32_t lastLogTime_ms = 0;
if (imuSampleTime_ms - lastLogTime_ms > 500) {
lastLogTime_ms = imuSampleTime_ms;
const struct log_XKTV msg {

8
libraries/AP_NavEKF3/AP_NavEKF3_core.h

@ -1479,6 +1479,12 @@ private: @@ -1479,6 +1479,12 @@ private:
bool EKFGSF_run_filterbank; // true when the filter bank is active
uint8_t EKFGSF_yaw_valid_count; // number of updates since the last invalid yaw estimate
// logging timestamps
uint32_t lastLogTime_ms;
uint32_t lastUpdateTime_ms;
uint32_t lastEkfStateVarLogTime_ms;
uint32_t lastTimingLogTime_ms;
// bits in EK3_AFFINITY
enum ekf_affinity {
EKF_AFFINITY_GPS = (1U<<0),
@ -1519,7 +1525,7 @@ private: @@ -1519,7 +1525,7 @@ private:
void Log_Write_Quaternion(uint64_t time_us) const;
void Log_Write_Beacon(uint64_t time_us);
void Log_Write_BodyOdom(uint64_t time_us);
void Log_Write_State_Variances(uint64_t time_us) const;
void Log_Write_State_Variances(uint64_t time_us);
void Log_Write_Timing(uint64_t time_us);
void Log_Write_GSF(uint64_t time_us);
};

Loading…
Cancel
Save