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:
Randy Mackay 2013-09-30 23:14:09 +09:00
parent d9fe099885
commit 7d73e62a23
2 changed files with 50 additions and 19 deletions

View File

@ -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;
} }

View File

@ -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;