pub struct SMART_BATTERY_INFO_DATA {Show 17 fields
pub capacity_full_specification: i32,
pub capacity_full: i32,
pub cycle_count: u16,
pub weight: u16,
pub discharge_minimum_voltage: u16,
pub charging_minimum_voltage: u16,
pub resting_minimum_voltage: u16,
pub id: u8,
pub battery_function: MavBatteryFunction,
pub mavtype: MavBatteryType,
pub serial_number: CharArray<16>,
pub device_name: CharArray<50>,
pub charging_maximum_voltage: u16,
pub cells_in_series: u8,
pub discharge_maximum_current: u32,
pub discharge_maximum_burst_current: u32,
pub manufacture_date: CharArray<11>,
}The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
dialect-matrixpilot only.Expand description
Smart Battery information (static/infrequent update). Use for updates from: smart battery to flight stack, flight stack to GCS. Use BATTERY_STATUS for the frequent battery updates.
ID: 370
Fields§
§capacity_full_specification: i32The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Capacity when full according to manufacturer, -1: field not provided.
capacity_full: i32The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Capacity when full (accounting for battery degradation), -1: field not provided.
cycle_count: u16The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Charge/discharge cycle count. UINT16_MAX: field not provided.
weight: u16The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Battery weight. 0: field not provided.
discharge_minimum_voltage: u16The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Minimum per-cell voltage when discharging. If not supplied set to UINT16_MAX value.
charging_minimum_voltage: u16The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Minimum per-cell voltage when charging. If not supplied set to UINT16_MAX value.
resting_minimum_voltage: u16The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Minimum per-cell voltage when resting. If not supplied set to UINT16_MAX value.
id: u8The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Battery ID
battery_function: MavBatteryFunctionThe BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Function of the battery
mavtype: MavBatteryTypeThe BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Type (chemistry) of the battery
serial_number: CharArray<16>The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Serial number in ASCII characters, 0 terminated. All 0: field not provided.
device_name: CharArray<50>The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Static device name in ASCII characters, 0 terminated. All 0: field not provided. Encode as manufacturer name then product name separated using an underscore.
charging_maximum_voltage: u16The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Maximum per-cell voltage when charged. 0: field not provided.
cells_in_series: u8The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Number of battery cells in series. 0: field not provided.
discharge_maximum_current: u32The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Maximum pack discharge current. 0: field not provided.
discharge_maximum_burst_current: u32The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Maximum pack discharge burst current. 0: field not provided.
manufacture_date: CharArray<11>The BATTERY_INFO message is better aligned with UAVCAN messages, and in any case is useful even if a battery is not “smart”. See BATTERY_INFO (Superseded since 2024-02)
Manufacture date (DD/MM/YYYY) in ASCII characters, 0 terminated. All 0: field not provided.
Implementations§
Trait Implementations§
Source§impl<'arbitrary> Arbitrary<'arbitrary> for SMART_BATTERY_INFO_DATA
impl<'arbitrary> Arbitrary<'arbitrary> for SMART_BATTERY_INFO_DATA
Source§fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>
fn arbitrary(u: &mut Unstructured<'arbitrary>) -> Result<Self>
Self from the given unstructured data. Read moreSource§fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>
fn arbitrary_take_rest(u: Unstructured<'arbitrary>) -> Result<Self>
Self from the entirety of the given
unstructured data. Read moreSource§impl Clone for SMART_BATTERY_INFO_DATA
impl Clone for SMART_BATTERY_INFO_DATA
Source§fn clone(&self) -> SMART_BATTERY_INFO_DATA
fn clone(&self) -> SMART_BATTERY_INFO_DATA
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for SMART_BATTERY_INFO_DATA
impl Debug for SMART_BATTERY_INFO_DATA
Source§impl Default for SMART_BATTERY_INFO_DATA
impl Default for SMART_BATTERY_INFO_DATA
Source§impl<'de> Deserialize<'de> for SMART_BATTERY_INFO_DATA
impl<'de> Deserialize<'de> for SMART_BATTERY_INFO_DATA
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl MessageData for SMART_BATTERY_INFO_DATA
impl MessageData for SMART_BATTERY_INFO_DATA
Source§impl PartialEq for SMART_BATTERY_INFO_DATA
impl PartialEq for SMART_BATTERY_INFO_DATA
Source§impl Serialize for SMART_BATTERY_INFO_DATA
impl Serialize for SMART_BATTERY_INFO_DATA
Source§impl TS for SMART_BATTERY_INFO_DATA
impl TS for SMART_BATTERY_INFO_DATA
Source§type WithoutGenerics = SMART_BATTERY_INFO_DATA
type WithoutGenerics = SMART_BATTERY_INFO_DATA
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = SMART_BATTERY_INFO_DATA
type OptionInnerType = SMART_BATTERY_INFO_DATA
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete() -> String
fn decl_concrete() -> String
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
TS::export_all]. Read more§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
To export only this type, without its dependencies, use [
TS::export]. Read more§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
To export only this type, without its dependencies, use [
TS::export]. Read more§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
§fn default_output_path() -> Option<PathBuf>
fn default_output_path() -> Option<PathBuf>
T should be exported. Read more