Skip to content
GitLab
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
a307f934
Commit
a307f934
authored
Mar 03, 2015
by
Lorenz Meier
Browse files
Remove old battery estimation cruft
parent
a255b8d9
Changes
2
Hide whitespace changes
Inline
Side-by-side
src/uas/UAS.cc
View file @
a307f934
...
...
@@ -34,6 +34,8 @@
Q_LOGGING_CATEGORY
(
UASLog
,
"UASLog"
)
#define UAS_DEFAULT_BATTERY_WARNLEVEL 20
/**
* Gets the settings from the previous UAS (name, airframe, autopilot, battery specs)
* by calling readSettings. This means the new UAS will have the same settings
...
...
@@ -70,20 +72,14 @@ UAS::UAS(MAVLinkProtocol* protocol, int id) : UASInterface(),
thrustSum
(
0
),
thrustMax
(
10
),
// batteryType not initialized
// cells not initialized
// fullVoltage not initialized
// emptyVoltage not initialized
startVoltage
(
-
1.0
f
),
tickVoltage
(
10.5
f
),
lastTickVoltageValue
(
13.0
f
),
tickLowpassVoltage
(
12.0
f
),
warnVoltage
(
9.5
f
),
warnLevelPercent
(
20.0
f
),
warnLevelPercent
(
UAS_DEFAULT_BATTERY_WARNLEVEL
),
currentVoltage
(
12.6
f
),
lpVoltage
(
12.0
f
),
currentCurrent
(
0.4
f
),
batteryRemainingEstimateEnabled
(
false
),
chargeLevel
(
-
1
),
timeRemaining
(
0
),
lowBattAlarm
(
false
),
...
...
@@ -230,7 +226,6 @@ UAS::UAS(MAVLinkProtocol* protocol, int id) : UASInterface(),
actions
.
append
(
newAction
);
color
=
UASInterface
::
getNextColor
();
setBatterySpecs
(
QString
(
""
));
connect
(
&
statusTimeout
,
SIGNAL
(
timeout
()),
this
,
SLOT
(
updateState
()));
connect
(
this
,
SIGNAL
(
systemSpecsChanged
(
int
)),
this
,
SLOT
(
writeSettings
()));
statusTimeout
.
start
(
500
);
...
...
@@ -294,7 +289,7 @@ void UAS::deleteSettings()
this
->
name
=
""
;
this
->
airframe
=
QGC_AIRFRAME_GENERIC
;
this
->
autopilot
=
-
1
;
setBatterySpecs
(
QString
(
"9V,9.5V,12.6V"
))
;
warnLevelPercent
=
UAS_DEFAULT_BATTERY_WARNLEVEL
;
}
/**
...
...
@@ -629,10 +624,7 @@ void UAS::receiveMessage(LinkInterface* link, mavlink_message_t message)
if
(
startVoltage
==
-
1.0
f
&&
currentVoltage
>
0.1
f
)
startVoltage
=
currentVoltage
;
timeRemaining
=
calculateTimeRemaining
();
if
(
!
batteryRemainingEstimateEnabled
&&
chargeLevel
!=
-
1
)
{
chargeLevel
=
state
.
battery_remaining
;
}
chargeLevel
=
state
.
battery_remaining
;
emit
batteryChanged
(
this
,
lpVoltage
,
currentCurrent
,
getChargeLevel
(),
timeRemaining
);
emit
valueChanged
(
uasId
,
name
.
arg
(
"battery_remaining"
),
"%"
,
getChargeLevel
(),
time
);
...
...
@@ -647,7 +639,7 @@ void UAS::receiveMessage(LinkInterface* link, mavlink_message_t message)
}
// LOW BATTERY ALARM
if
(
lpVoltage
<
warnVoltage
&&
(
currentVoltage
-
0.2
f
)
<
warnVoltage
&&
(
currentVoltage
>
3.3
))
if
(
chargeLevel
>=
0
&&
(
getChargeLevel
()
<
warnLevelPercent
))
{
// An audio alarm. Does not generate any signals.
startLowBattAlarm
();
...
...
@@ -3318,81 +3310,24 @@ QMap<int, QString> UAS::getComponents()
return
components
;
}
/**
* Set the battery type and the number of cells.
* @param type of the battery
* @param cells Number of cells.
*/
void
UAS
::
setBattery
(
BatteryType
type
,
int
cells
)
{
this
->
batteryType
=
type
;
this
->
cells
=
cells
;
switch
(
batteryType
)
{
case
NICD
:
break
;
case
NIMH
:
break
;
case
LIION
:
break
;
case
LIPOLY
:
fullVoltage
=
this
->
cells
*
lipoFull
;
emptyVoltage
=
this
->
cells
*
lipoEmpty
;
break
;
case
LIFE
:
break
;
case
AGZN
:
break
;
}
}
/**
* Set the battery specificaitons: empty voltage, warning voltage, and full voltage.
* @param specifications of the battery
*/
void
UAS
::
setBatterySpecs
(
const
QString
&
specs
)
{
if
(
specs
.
length
()
==
0
||
specs
.
contains
(
"%"
))
batteryRemainingEstimateEnabled
=
false
;
bool
ok
;
QString
percent
=
specs
;
percent
=
percent
.
remove
(
"%"
);
float
temp
=
percent
.
toFloat
(
&
ok
);
if
(
ok
)
{
batteryRemainingEstimateEnabled
=
false
;
bool
ok
;
QString
percent
=
specs
;
percent
=
percent
.
remove
(
"%"
);
float
temp
=
percent
.
toFloat
(
&
ok
);
if
(
ok
)
{
warnLevelPercent
=
temp
;
}
else
{
emit
textMessageReceived
(
0
,
0
,
MAV_SEVERITY_WARNING
,
"Could not set battery options, format is wrong"
);
}
warnLevelPercent
=
temp
;
}
else
{
batteryRemainingEstimateEnabled
=
true
;
QString
stringList
=
specs
;
stringList
=
stringList
.
remove
(
"V"
);
stringList
=
stringList
.
remove
(
"v"
);
QStringList
parts
=
stringList
.
split
(
","
);
if
(
parts
.
length
()
==
3
)
{
float
temp
;
bool
ok
;
// Get the empty voltage
temp
=
parts
.
at
(
0
).
toFloat
(
&
ok
);
if
(
ok
)
emptyVoltage
=
temp
;
// Get the warning voltage
temp
=
parts
.
at
(
1
).
toFloat
(
&
ok
);
if
(
ok
)
warnVoltage
=
temp
;
// Get the full voltage
temp
=
parts
.
at
(
2
).
toFloat
(
&
ok
);
if
(
ok
)
fullVoltage
=
temp
;
}
else
{
emit
textMessageReceived
(
0
,
0
,
MAV_SEVERITY_WARNING
,
"Could not set battery options, format is wrong"
);
}
emit
textMessageReceived
(
0
,
0
,
MAV_SEVERITY_WARNING
,
"Could not set battery options, format is wrong"
);
}
}
...
...
@@ -3401,14 +3336,7 @@ void UAS::setBatterySpecs(const QString& specs)
*/
QString
UAS
::
getBatterySpecs
()
{
if
(
batteryRemainingEstimateEnabled
)
{
return
QString
(
"%1V,%2V,%3V"
).
arg
(
emptyVoltage
).
arg
(
warnVoltage
).
arg
(
fullVoltage
);
}
else
{
return
QString
(
"%1%"
).
arg
(
warnLevelPercent
);
}
return
QString
(
"%1%"
).
arg
(
warnLevelPercent
);
}
/**
...
...
@@ -3416,15 +3344,8 @@ QString UAS::getBatterySpecs()
*/
int
UAS
::
calculateTimeRemaining
()
{
quint64
dt
=
QGC
::
groundTimeMilliseconds
()
-
startTime
;
double
seconds
=
dt
/
1000.0
f
;
double
voltDifference
=
startVoltage
-
currentVoltage
;
if
(
voltDifference
<=
0
)
voltDifference
=
0.00000000001
f
;
double
dischargePerSecond
=
voltDifference
/
seconds
;
int
remaining
=
static_cast
<
int
>
((
currentVoltage
-
emptyVoltage
)
/
dischargePerSecond
);
// Can never be below 0
if
(
remaining
<
0
)
remaining
=
0
;
return
remaining
;
// XXX needs fixing
return
0
;
}
/**
...
...
@@ -3432,21 +3353,6 @@ int UAS::calculateTimeRemaining()
*/
float
UAS
::
getChargeLevel
()
{
if
(
batteryRemainingEstimateEnabled
)
{
if
(
lpVoltage
<
emptyVoltage
)
{
chargeLevel
=
0.0
f
;
}
else
if
(
lpVoltage
>
fullVoltage
)
{
chargeLevel
=
100.0
f
;
}
else
{
chargeLevel
=
100.0
f
*
((
lpVoltage
-
emptyVoltage
)
/
(
fullVoltage
-
emptyVoltage
));
}
}
return
chargeLevel
;
}
...
...
src/uas/UAS.h
View file @
a307f934
...
...
@@ -372,15 +372,10 @@ protected: //COMMENTS FOR TEST UNIT
// dongfang: This looks like a candidate for being moved off to a separate class.
/// BATTERY / ENERGY
BatteryType
batteryType
;
///< The battery type
int
cells
;
///< Number of cells
float
fullVoltage
;
///< Voltage of the fully charged battery (100%)
float
emptyVoltage
;
///< Voltage of the empty battery (0%)
float
startVoltage
;
///< Voltage at system start
float
tickVoltage
;
///< Voltage where 0.1 V ticks are told
float
lastTickVoltageValue
;
///< The last voltage where a tick was announced
float
tickLowpassVoltage
;
///< Lowpass-filtered voltage for the tick announcement
float
warnVoltage
;
///< Voltage where QGC will start to warn about low battery
float
warnLevelPercent
;
///< Warning level, in percent
double
currentVoltage
;
///< Voltage currently measured
float
lpVoltage
;
///< Low-pass filtered voltage
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment