Commit 6103a554 authored by Lorenz Meier's avatar Lorenz Meier

UAS: Fix battery status lowpass and only publish values when battery measurements are valid

parent 9b75d0dc
...@@ -73,7 +73,7 @@ UAS::UAS(MAVLinkProtocol* protocol, Vehicle* vehicle) : UASInterface(), ...@@ -73,7 +73,7 @@ UAS::UAS(MAVLinkProtocol* protocol, Vehicle* vehicle) : UASInterface(),
tickLowpassVoltage(12.0f), tickLowpassVoltage(12.0f),
warnLevelPercent(UAS_DEFAULT_BATTERY_WARNLEVEL), warnLevelPercent(UAS_DEFAULT_BATTERY_WARNLEVEL),
currentVoltage(12.6f), currentVoltage(12.6f),
lpVoltage(12.0f), lpVoltage(-1.0f),
currentCurrent(0.4f), currentCurrent(0.4f),
chargeLevel(-1), chargeLevel(-1),
lowBattAlarm(false), lowBattAlarm(false),
...@@ -495,11 +495,11 @@ void UAS::receiveMessage(mavlink_message_t message) ...@@ -495,11 +495,11 @@ void UAS::receiveMessage(mavlink_message_t message)
emit loadChanged(this,state.load/10.0f); emit loadChanged(this,state.load/10.0f);
emit valueChanged(uasId, name.arg("load"), "%", state.load/10.0f, time); emit valueChanged(uasId, name.arg("load"), "%", state.load/10.0f, time);
if (state.voltage_battery != UINT16_MAX) { if (state.voltage_battery > 0.0f && state.voltage_battery != UINT16_MAX) {
// Battery charge/time remaining/voltage calculations // Battery charge/time remaining/voltage calculations
currentVoltage = state.voltage_battery/1000.0f; currentVoltage = state.voltage_battery/1000.0f;
lpVoltage = filterVoltage(currentVoltage); filterVoltage(currentVoltage);
tickLowpassVoltage = tickLowpassVoltage*0.8f + 0.2f*currentVoltage; tickLowpassVoltage = tickLowpassVoltage * 0.8f + 0.2f * currentVoltage;
// We don't want to tick above the threshold // We don't want to tick above the threshold
if (tickLowpassVoltage > tickVoltage) if (tickLowpassVoltage > tickVoltage)
...@@ -514,10 +514,10 @@ void UAS::receiveMessage(mavlink_message_t message) ...@@ -514,10 +514,10 @@ void UAS::receiveMessage(mavlink_message_t message)
&& (currentVoltage > 3.3f) && (currentVoltage > 3.3f)
/* warn only if current voltage is really still lower by a reasonable amount */ /* warn only if current voltage is really still lower by a reasonable amount */
&& ((currentVoltage - 0.2f) < tickVoltage) && ((currentVoltage - 0.2f) < tickVoltage)
/* warn only every 12 seconds */ /* warn only every 20 seconds */
&& (QGC::groundTimeUsecs() - lastVoltageWarning) > 12000000) && (QGC::groundTimeUsecs() - lastVoltageWarning) > 20000000)
{ {
_say(QString("Voltage warning for system %1: %2 volts").arg(getUASID()).arg(lpVoltage, 0, 'f', 1, QChar(' '))); _say(QString("Low battery system %1: %2 volts").arg(getUASID()).arg(lpVoltage, 0, 'f', 1, QChar(' ')));
lastVoltageWarning = QGC::groundTimeUsecs(); lastVoltageWarning = QGC::groundTimeUsecs();
lastTickVoltageValue = tickLowpassVoltage; lastTickVoltageValue = tickLowpassVoltage;
} }
...@@ -1557,9 +1557,14 @@ quint64 UAS::getUnixTime(quint64 time) ...@@ -1557,9 +1557,14 @@ quint64 UAS::getUnixTime(quint64 time)
/** /**
* @param value battery voltage * @param value battery voltage
*/ */
float UAS::filterVoltage(float value) const float UAS::filterVoltage(float value)
{ {
return lpVoltage * 0.6f + value * 0.4f; if (lpVoltage < 0.0f) {
lpVoltage = value;
}
lpVoltage = lpVoltage * 0.6f + value * 0.4f;
return lpVoltage;
} }
/** /**
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment