pub enum Error {
InvalidCurve,
NumericalError,
InvalidTemperature,
}Expand description
Errors that can occur during battery SOC estimation
This enum represents all possible error conditions that may arise when using the battery estimator library.
§Examples
use battery_estimator::{BatteryChemistry, SocEstimator, Error};
let estimator = SocEstimator::new(BatteryChemistry::LiPo);
match estimator.estimate_soc(3.7) {
Ok(soc) => println!("SOC: {:.1}%", soc),
Err(Error::InvalidCurve) => eprintln!("Invalid battery curve"),
Err(Error::NumericalError) => eprintln!("Calculation error"),
Err(Error::InvalidTemperature) => eprintln!("Invalid temperature"),
}Variants§
InvalidCurve
The voltage curve data is invalid
This error occurs when:
- The curve has fewer than 2 points (cannot interpolate)
- The curve points are not properly ordered
- The curve has duplicate voltage values
§Examples
use battery_estimator::{Curve, CurvePoint, Error};
// Invalid: Only one point
let invalid_curve = Curve::new(&[CurvePoint::new(3.7, 50.0)]);
let result = invalid_curve.voltage_to_soc(3.7);
assert!(matches!(result, Err(Error::InvalidCurve)));NumericalError
A numerical error occurred during calculation
This error occurs when:
- Division by zero in interpolation
- Overflow or underflow in calculations
- Invalid floating-point operations
§Examples
use battery_estimator::{Curve, CurvePoint, Error};
// This could occur if curve points have the same voltage
let problematic_curve = Curve::new(&[
CurvePoint::new(3.7, 50.0),
CurvePoint::new(3.7, 60.0), // Duplicate voltage!
]);InvalidTemperature
The temperature value is invalid
This error occurs when:
- Temperature is NaN (Not a Number)
- Temperature is infinity
- Temperature is outside reasonable bounds
§Examples
use battery_estimator::{BatteryChemistry, SocEstimator, Error};
let estimator = SocEstimator::new(BatteryChemistry::LiPo);
// Invalid temperature
let result = estimator.estimate_soc_with_temp(3.7, f32::NAN);Trait Implementations§
Source§impl Error for Error
impl Error for Error
1.30.0 · Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
👎Deprecated since 1.42.0: use the Display impl or to_string()
impl Copy for Error
impl Eq for Error
impl StructuralPartialEq for Error
Auto Trait Implementations§
impl Freeze for Error
impl RefUnwindSafe for Error
impl Send for Error
impl Sync for Error
impl Unpin for Error
impl UnwindSafe for Error
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more