pub type Model64410 = DcSimInterface;
struct Counts {
n_pt: u16,
n_prof: u16,
}
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct DcSimInterface {
pub v_max_lim: Option<u16>,
pub p_max_lim: Option<u16>,
pub i_max_lim: Option<u16>,
pub mode: Option<Mode>,
pub ena: Option<Ena>,
pub reset: Option<Reset>,
pub v_set: Option<u16>,
pub p_set: Option<u16>,
pub i_set: Option<u16>,
pub en50530: Option<En50530>,
pub vmpp: Option<u16>,
pub pmpp: Option<u16>,
pub g_set: Option<u16>,
pub v_slew_rate: Option<u16>,
pub p_slew_rate: Option<u16>,
pub i_slew_rate: Option<u16>,
pub ena_prof: Option<EnaProf>,
pub adpt_prof_req: Option<u16>,
pub adpt_prof_rslt: AdptProfRslt,
pub v: Option<i32>,
pub p: Option<i32>,
pub i: Option<i32>,
pub errors: Option<String>,
pub n_pt: u16,
pub n_prof: u16,
pub w_sf: i16,
pub v_sf: i16,
pub a_sf: i16,
pub g_sf: i16,
pub tms_sf: i16,
pub v_slew_sf: i16,
pub p_slew_sf: i16,
pub i_slew_sf: i16,
pub pct_sf: i16,
pub prof: Vec<Prof>,
}
#[allow(missing_docs)]
impl DcSimInterface {
pub const V_MAX_LIM: crate::Point<Self, Option<u16>> = crate::Point::new(0, 1, true);
pub const P_MAX_LIM: crate::Point<Self, Option<u16>> = crate::Point::new(1, 1, true);
pub const I_MAX_LIM: crate::Point<Self, Option<u16>> = crate::Point::new(2, 1, true);
pub const MODE: crate::Point<Self, Option<Mode>> = crate::Point::new(3, 1, true);
pub const ENA: crate::Point<Self, Option<Ena>> = crate::Point::new(4, 1, true);
pub const RESET: crate::Point<Self, Option<Reset>> = crate::Point::new(5, 1, true);
pub const V_SET: crate::Point<Self, Option<u16>> = crate::Point::new(6, 1, true);
pub const P_SET: crate::Point<Self, Option<u16>> = crate::Point::new(7, 1, true);
pub const I_SET: crate::Point<Self, Option<u16>> = crate::Point::new(8, 1, true);
pub const EN50530: crate::Point<Self, Option<En50530>> = crate::Point::new(9, 1, true);
pub const VMPP: crate::Point<Self, Option<u16>> = crate::Point::new(10, 1, true);
pub const PMPP: crate::Point<Self, Option<u16>> = crate::Point::new(11, 1, true);
pub const G_SET: crate::Point<Self, Option<u16>> = crate::Point::new(12, 1, true);
pub const V_SLEW_RATE: crate::Point<Self, Option<u16>> = crate::Point::new(13, 1, true);
pub const P_SLEW_RATE: crate::Point<Self, Option<u16>> = crate::Point::new(14, 1, true);
pub const I_SLEW_RATE: crate::Point<Self, Option<u16>> = crate::Point::new(15, 1, true);
pub const ENA_PROF: crate::Point<Self, Option<EnaProf>> = crate::Point::new(16, 1, true);
pub const ADPT_PROF_REQ: crate::Point<Self, Option<u16>> = crate::Point::new(17, 1, true);
pub const ADPT_PROF_RSLT: crate::Point<Self, AdptProfRslt> = crate::Point::new(18, 1, false);
pub const V: crate::Point<Self, Option<i32>> = crate::Point::new(19, 2, false);
pub const P: crate::Point<Self, Option<i32>> = crate::Point::new(21, 2, false);
pub const I: crate::Point<Self, Option<i32>> = crate::Point::new(23, 2, false);
pub const ERRORS: crate::Point<Self, Option<String>> = crate::Point::new(25, 32, false);
pub const N_PT: crate::Point<Self, u16> = crate::Point::new(57, 1, false);
pub const N_PROF: crate::Point<Self, u16> = crate::Point::new(58, 1, false);
pub const W_SF: crate::Point<Self, i16> = crate::Point::new(59, 1, true);
pub const V_SF: crate::Point<Self, i16> = crate::Point::new(60, 1, true);
pub const A_SF: crate::Point<Self, i16> = crate::Point::new(61, 1, true);
pub const G_SF: crate::Point<Self, i16> = crate::Point::new(62, 1, true);
pub const TMS_SF: crate::Point<Self, i16> = crate::Point::new(63, 1, true);
pub const V_SLEW_SF: crate::Point<Self, i16> = crate::Point::new(64, 1, true);
pub const P_SLEW_SF: crate::Point<Self, i16> = crate::Point::new(65, 1, true);
pub const I_SLEW_SF: crate::Point<Self, i16> = crate::Point::new(66, 1, true);
pub const PCT_SF: crate::Point<Self, i16> = crate::Point::new(67, 1, true);
}
impl crate::Group for DcSimInterface {
const LEN: u16 = 68;
}
impl DcSimInterface {
fn parse_group(data: &[u16]) -> Result<(&[u16], Self), crate::DecodeError> {
let nested_data = data
.get(usize::from(<Self as crate::Group>::LEN)..)
.unwrap_or(&[]);
let counts = Counts {
n_pt: Self::N_PT.from_data(data)?,
n_prof: Self::N_PROF.from_data(data)?,
};
let (nested_data, prof) = Prof::parse_multiple(nested_data, &counts)?;
Ok((
nested_data,
Self {
v_max_lim: Self::V_MAX_LIM.from_data(data)?,
p_max_lim: Self::P_MAX_LIM.from_data(data)?,
i_max_lim: Self::I_MAX_LIM.from_data(data)?,
mode: Self::MODE.from_data(data)?,
ena: Self::ENA.from_data(data)?,
reset: Self::RESET.from_data(data)?,
v_set: Self::V_SET.from_data(data)?,
p_set: Self::P_SET.from_data(data)?,
i_set: Self::I_SET.from_data(data)?,
en50530: Self::EN50530.from_data(data)?,
vmpp: Self::VMPP.from_data(data)?,
pmpp: Self::PMPP.from_data(data)?,
g_set: Self::G_SET.from_data(data)?,
v_slew_rate: Self::V_SLEW_RATE.from_data(data)?,
p_slew_rate: Self::P_SLEW_RATE.from_data(data)?,
i_slew_rate: Self::I_SLEW_RATE.from_data(data)?,
ena_prof: Self::ENA_PROF.from_data(data)?,
adpt_prof_req: Self::ADPT_PROF_REQ.from_data(data)?,
adpt_prof_rslt: Self::ADPT_PROF_RSLT.from_data(data)?,
v: Self::V.from_data(data)?,
p: Self::P.from_data(data)?,
i: Self::I.from_data(data)?,
errors: Self::ERRORS.from_data(data)?,
n_pt: Self::N_PT.from_data(data)?,
n_prof: Self::N_PROF.from_data(data)?,
w_sf: Self::W_SF.from_data(data)?,
v_sf: Self::V_SF.from_data(data)?,
a_sf: Self::A_SF.from_data(data)?,
g_sf: Self::G_SF.from_data(data)?,
tms_sf: Self::TMS_SF.from_data(data)?,
v_slew_sf: Self::V_SLEW_SF.from_data(data)?,
p_slew_sf: Self::P_SLEW_SF.from_data(data)?,
i_slew_sf: Self::I_SLEW_SF.from_data(data)?,
pct_sf: Self::PCT_SF.from_data(data)?,
prof,
},
))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum Mode {
Cv,
Cc,
Invalid(u16),
}
impl crate::EnumValue for Mode {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::Cv,
1 => Self::Cc,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Cv => 0,
Self::Cc => 1,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for Mode {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum Ena {
On,
Off,
Invalid(u16),
}
impl crate::EnumValue for Ena {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
1 => Self::On,
0 => Self::Off,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::On => 1,
Self::Off => 0,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for Ena {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum Reset {
Reset,
DoNotReset,
Invalid(u16),
}
impl crate::EnumValue for Reset {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
1 => Self::Reset,
0 => Self::DoNotReset,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Reset => 1,
Self::DoNotReset => 0,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for Reset {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum En50530 {
En50530,
DoNotEn50530,
Invalid(u16),
}
impl crate::EnumValue for En50530 {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
1 => Self::En50530,
0 => Self::DoNotEn50530,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::En50530 => 1,
Self::DoNotEn50530 => 0,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for En50530 {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum EnaProf {
Start,
Stop,
Invalid(u16),
}
impl crate::EnumValue for EnaProf {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
1 => Self::Start,
0 => Self::Stop,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Start => 1,
Self::Stop => 0,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for EnaProf {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum AdptProfRslt {
InProgress,
Completed,
Failed,
Invalid(u16),
}
impl crate::EnumValue for AdptProfRslt {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::InProgress,
1 => Self::Completed,
2 => Self::Failed,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::InProgress => 0,
Self::Completed => 1,
Self::Failed => 2,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for AdptProfRslt {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct Prof {
pub act_pt: u16,
pub dept_ref: ProfDeptRef,
pub pt: Vec<Pt>,
}
#[allow(missing_docs)]
impl Prof {
pub const ACT_PT: crate::Point<Self, u16> = crate::Point::new(0, 1, true);
pub const DEPT_REF: crate::Point<Self, ProfDeptRef> = crate::Point::new(1, 1, true);
}
impl crate::Group for Prof {
const LEN: u16 = 2;
}
impl Prof {
fn parse_group<'a>(
data: &'a [u16],
counts: &Counts,
) -> Result<(&'a [u16], Self), crate::DecodeError> {
let nested_data = data
.get(usize::from(<Self as crate::Group>::LEN)..)
.unwrap_or(&[]);
let (nested_data, pt) = Pt::parse_multiple(nested_data, counts)?;
Ok((
nested_data,
Self {
act_pt: Self::ACT_PT.from_data(data)?,
dept_ref: Self::DEPT_REF.from_data(data)?,
pt,
},
))
}
fn parse_multiple<'a>(
data: &'a [u16],
counts: &Counts,
) -> Result<(&'a [u16], Vec<Self>), crate::DecodeError> {
let (data, groups) =
(0..counts.n_prof).try_fold((data, Vec::new()), |(data, mut groups), _| {
let (data, group) = Prof::parse_group(data, counts)?;
groups.push(group);
Ok::<_, crate::DecodeError>((data, groups))
})?;
Ok((data, groups))
}
}
bitflags::bitflags! {
#[doc = " Dependent References"] #[doc = " "] #[doc = " Profile references."]
#[derive(Copy, Clone, Debug, Eq, PartialEq)] #[cfg_attr(feature = "serde",
derive(::serde::Serialize, ::serde::Deserialize))] pub struct ProfDeptRef : u32 {
#[doc = " Voltage"] const Voltage = 1; #[doc = " Power"] const Power = 2; #[doc =
" Current"] const Current = 4; #[doc = " Irradiance"] const Irradiance = 8; }
}
impl crate::Value for ProfDeptRef {
fn decode(data: &[u16]) -> Result<Self, crate::DecodeError> {
let value = u32::decode(data)?;
Ok(Self::from_bits_retain(value))
}
fn encode(self) -> Box<[u16]> {
self.bits().encode()
}
}
impl crate::FixedSize for ProfDeptRef {
const SIZE: u16 = 2u16;
const INVALID: Self = Self::from_bits_retain(4294967295u32);
fn is_invalid(&self) -> bool {
self.bits() == 4294967295u32
}
}
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct Pt {
pub tms: Option<u16>,
pub v: Option<u16>,
pub p: Option<u16>,
pub i: Option<u16>,
pub g: Option<u16>,
}
#[allow(missing_docs)]
impl Pt {
pub const TMS: crate::Point<Self, Option<u16>> = crate::Point::new(0, 1, true);
pub const V: crate::Point<Self, Option<u16>> = crate::Point::new(1, 1, true);
pub const P: crate::Point<Self, Option<u16>> = crate::Point::new(2, 1, true);
pub const I: crate::Point<Self, Option<u16>> = crate::Point::new(3, 1, true);
pub const G: crate::Point<Self, Option<u16>> = crate::Point::new(4, 1, true);
}
impl crate::Group for Pt {
const LEN: u16 = 5;
}
impl Pt {
fn parse_group(data: &[u16]) -> Result<(&[u16], Self), crate::DecodeError> {
let nested_data = data
.get(usize::from(<Self as crate::Group>::LEN)..)
.unwrap_or(&[]);
Ok((
nested_data,
Self {
tms: Self::TMS.from_data(data)?,
v: Self::V.from_data(data)?,
p: Self::P.from_data(data)?,
i: Self::I.from_data(data)?,
g: Self::G.from_data(data)?,
},
))
}
fn parse_multiple<'a>(
data: &'a [u16],
counts: &Counts,
) -> Result<(&'a [u16], Vec<Self>), crate::DecodeError> {
let (data, groups) =
(0..counts.n_pt).try_fold((data, Vec::new()), |(data, mut groups), _| {
let (data, group) = Pt::parse_group(data)?;
groups.push(group);
Ok::<_, crate::DecodeError>((data, groups))
})?;
Ok((data, groups))
}
}
impl crate::Model for DcSimInterface {
const ID: u16 = 64410;
fn addr(models: &crate::Models) -> crate::ModelAddr<Self> {
models.m64410
}
fn parse(data: &[u16]) -> Result<Self, crate::ParseError<Self>> {
let (_, model) = Self::parse_group(data)?;
Ok(model)
}
}