mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_NavEKF3: fixed gaps in EKF logging
timestamps should not be static as otherwise some lanes will not be logged
This commit is contained in:
parent
2e6063495f
commit
221881c4ae
@ -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)
|
||||
}
|
||||
#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)
|
||||
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;
|
||||
}
|
||||
|
@ -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 {
|
||||
|
@ -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:
|
||||
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…
Reference in New Issue
Block a user