mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
BattMonitor: add exhausted method
Current total calculations changed to use micros instead of millis for improved accuracy Removed unused pack_capacity accessor Initialise private members
This commit is contained in:
parent
d9fe099885
commit
7d73e62a23
@ -60,7 +60,10 @@ const AP_Param::GroupInfo AP_BattMonitor::var_info[] PROGMEM = {
|
|||||||
// their values.
|
// their values.
|
||||||
//
|
//
|
||||||
AP_BattMonitor::AP_BattMonitor(void) :
|
AP_BattMonitor::AP_BattMonitor(void) :
|
||||||
_voltage(AP_BATT_INITIAL_VOLTAGE)
|
_voltage(0),
|
||||||
|
_current_amps(0),
|
||||||
|
_current_total_mah(0),
|
||||||
|
_last_time_micros(0)
|
||||||
{
|
{
|
||||||
AP_Param::setup_object_defaults(this, var_info);
|
AP_Param::setup_object_defaults(this, var_info);
|
||||||
}
|
}
|
||||||
@ -78,7 +81,6 @@ void
|
|||||||
AP_BattMonitor::read()
|
AP_BattMonitor::read()
|
||||||
{
|
{
|
||||||
if (_monitoring == AP_BATT_MONITOR_DISABLED) {
|
if (_monitoring == AP_BATT_MONITOR_DISABLED) {
|
||||||
_voltage = 0;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,21 +93,54 @@ AP_BattMonitor::read()
|
|||||||
|
|
||||||
// read current
|
// read current
|
||||||
if (_monitoring == AP_BATT_MONITOR_VOLTAGE_AND_CURRENT) {
|
if (_monitoring == AP_BATT_MONITOR_VOLTAGE_AND_CURRENT) {
|
||||||
uint32_t tnow = hal.scheduler->millis();
|
uint32_t tnow = hal.scheduler->micros();
|
||||||
float dt = tnow - _last_time_ms;
|
float dt = tnow - _last_time_micros;
|
||||||
// this copes with changing the pin at runtime
|
// this copes with changing the pin at runtime
|
||||||
_curr_pin_analog_source->set_pin(_curr_pin);
|
_curr_pin_analog_source->set_pin(_curr_pin);
|
||||||
_current_amps = (_curr_pin_analog_source->voltage_average()-_curr_amp_offset)*_curr_amp_per_volt;
|
_current_amps = (_curr_pin_analog_source->voltage_average()-_curr_amp_offset)*_curr_amp_per_volt;
|
||||||
if (_last_time_ms != 0 && dt < 2000) {
|
if (_last_time_micros != 0 && dt < 2000000.0f) {
|
||||||
// .0002778 is 1/3600 (conversion to hours)
|
// .0002778 is 1/3600 (conversion to hours)
|
||||||
_current_total_mah += _current_amps * dt * 0.0002778f;
|
_current_total_mah += _current_amps * dt * 0.2778f;
|
||||||
}
|
}
|
||||||
_last_time_ms = tnow;
|
_last_time_micros = tnow;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// capacity_remaining_pct - returns the % battery capacity remaining (0 ~ 100)
|
/// capacity_remaining_pct - returns the % battery capacity remaining (0 ~ 100)
|
||||||
uint8_t AP_BattMonitor::capacity_remaining_pct() const
|
uint8_t AP_BattMonitor::capacity_remaining_pct() const
|
||||||
{
|
{
|
||||||
return (100.0 * (_pack_capacity - _current_total_mah) / _pack_capacity);
|
return (100.0f * (_pack_capacity - _current_total_mah) / _pack_capacity);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// exhausted - returns true if the voltage remains below the low_voltage for 10 seconds or remaining capacity falls below min_capacity_mah
|
||||||
|
bool AP_BattMonitor::exhausted(float low_voltage, float min_capacity_mah)
|
||||||
|
{
|
||||||
|
// return immediately if disabled
|
||||||
|
if (_monitoring == AP_BATT_MONITOR_DISABLED) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// get current time
|
||||||
|
uint32_t tnow = hal.scheduler->millis();
|
||||||
|
|
||||||
|
// check voltage
|
||||||
|
if ((_voltage != 0) && (low_voltage > 0) && (_voltage < low_voltage)) {
|
||||||
|
// this is the first time our voltage has dropped below minimum so start timer
|
||||||
|
if (_low_voltage_start_ms == 0) {
|
||||||
|
_low_voltage_start_ms = tnow;
|
||||||
|
}else if (tnow - _low_voltage_start_ms > AP_BATT_LOW_VOLT_TIMEOUT_MS) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
// acceptable voltage so reset timer
|
||||||
|
_low_voltage_start_ms = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check capacity if current monitoring is enabled
|
||||||
|
if ((_monitoring == AP_BATT_MONITOR_VOLTAGE_AND_CURRENT) && (min_capacity_mah>0) && (_pack_capacity - _current_total_mah < min_capacity_mah)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// if we've gotten this far battery is ok
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -64,10 +64,8 @@
|
|||||||
// # define AP_BATT_CURR_AMP_PERVOLT_DEFAULT 27.32 // Amp/Volt for AttoPilot 50V/90A sensor
|
// # define AP_BATT_CURR_AMP_PERVOLT_DEFAULT 27.32 // Amp/Volt for AttoPilot 50V/90A sensor
|
||||||
// # define AP_BATT_CURR_AMP_PERVOLT_DEFAULT 13.66 // Amp/Volt for AttoPilot 13.6V/45A sensor
|
// # define AP_BATT_CURR_AMP_PERVOLT_DEFAULT 13.66 // Amp/Volt for AttoPilot 13.6V/45A sensor
|
||||||
|
|
||||||
|
|
||||||
#define AP_BATT_CAPACITY_DEFAULT 3300
|
#define AP_BATT_CAPACITY_DEFAULT 3300
|
||||||
|
#define AP_BATT_LOW_VOLT_TIMEOUT_MS 10000 // low voltage of 10 seconds will cause battery_exhausted to return true
|
||||||
#define AP_BATT_INITIAL_VOLTAGE 99 // initial voltage set on start-up to avoid low voltage alarms
|
|
||||||
|
|
||||||
class AP_BattMonitor
|
class AP_BattMonitor
|
||||||
{
|
{
|
||||||
@ -85,9 +83,6 @@ public:
|
|||||||
/// monitoring - returns whether we are monitoring voltage only or voltage and current
|
/// monitoring - returns whether we are monitoring voltage only or voltage and current
|
||||||
int8_t monitoring() const { return _monitoring; }
|
int8_t monitoring() const { return _monitoring; }
|
||||||
|
|
||||||
/// pack_capacity - battery pack capacity in mAh less reserve
|
|
||||||
float pack_capacity() const { return _pack_capacity; }
|
|
||||||
|
|
||||||
/// Battery voltage. Initialized to 99 to prevent low voltage events at startup
|
/// Battery voltage. Initialized to 99 to prevent low voltage events at startup
|
||||||
float voltage() const { return _voltage; }
|
float voltage() const { return _voltage; }
|
||||||
|
|
||||||
@ -95,14 +90,14 @@ public:
|
|||||||
float current_amps() const { return _current_amps; }
|
float current_amps() const { return _current_amps; }
|
||||||
|
|
||||||
/// Total current drawn since start-up (Amp-hours)
|
/// Total current drawn since start-up (Amp-hours)
|
||||||
float current_total_mah() const { return _current_total_mah; }
|
float current_total_mah() const { return _current_total_mah; }\
|
||||||
|
|
||||||
/// time when current was last read
|
|
||||||
uint32_t last_time_ms() const { return _last_time_ms; }
|
|
||||||
|
|
||||||
/// capacity_remaining_pct - returns the % battery capacity remaining (0 ~ 100)
|
/// capacity_remaining_pct - returns the % battery capacity remaining (0 ~ 100)
|
||||||
uint8_t capacity_remaining_pct() const;
|
uint8_t capacity_remaining_pct() const;
|
||||||
|
|
||||||
|
/// exhausted - returns true if the voltage remains below the low_voltage for 10 seconds or remaining capacity falls below min_capacity
|
||||||
|
bool exhausted(float low_voltage, float min_capacity_mah);
|
||||||
|
|
||||||
static const struct AP_Param::GroupInfo var_info[];
|
static const struct AP_Param::GroupInfo var_info[];
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -120,7 +115,8 @@ protected:
|
|||||||
float _voltage; /// last read voltage
|
float _voltage; /// last read voltage
|
||||||
float _current_amps; /// last read current drawn
|
float _current_amps; /// last read current drawn
|
||||||
float _current_total_mah; /// total current drawn since startup (Amp-hours)
|
float _current_total_mah; /// total current drawn since startup (Amp-hours)
|
||||||
uint32_t _last_time_ms; /// time when current was last read
|
uint32_t _last_time_micros; /// time when current was last read
|
||||||
|
uint32_t _low_voltage_start_ms; /// time when voltage dropped below the minimum
|
||||||
|
|
||||||
AP_HAL::AnalogSource *_volt_pin_analog_source;
|
AP_HAL::AnalogSource *_volt_pin_analog_source;
|
||||||
AP_HAL::AnalogSource *_curr_pin_analog_source;
|
AP_HAL::AnalogSource *_curr_pin_analog_source;
|
||||||
|
Loading…
Reference in New Issue
Block a user