Show and save the set values of PWM limits into flash store instead of machine value #127
@ -16,7 +16,7 @@ class Client:
|
|||||||
pwm_report = self.get_pwm()
|
pwm_report = self.get_pwm()
|
||||||
for pwm_channel in pwm_report:
|
for pwm_channel in pwm_report:
|
||||||
for limit in ["max_i_neg", "max_i_pos", "max_v"]:
|
for limit in ["max_i_neg", "max_i_pos", "max_v"]:
|
||||||
if pwm_channel[limit]["value"] == 0.0:
|
if pwm_channel[limit] == 0.0:
|
||||||
logging.warning("`{}` limit is set to zero on channel {}".format(limit, pwm_channel["channel"]))
|
logging.warning("`{}` limit is set to zero on channel {}".format(limit, pwm_channel["channel"]))
|
||||||
|
|
||||||
def _read_line(self):
|
def _read_line(self):
|
||||||
@ -53,17 +53,17 @@ class Client:
|
|||||||
Example::
|
Example::
|
||||||
[{'channel': 0,
|
[{'channel': 0,
|
||||||
'center': 'vref',
|
'center': 'vref',
|
||||||
'i_set': {'max': 2.9802790335151985, 'value': -0.02002179650216762},
|
'i_set': -0.02002179650216762,
|
||||||
'max_i_neg': {'max': 3.0, 'value': 3.0},
|
'max_i_neg': 2.0,
|
||||||
'max_v': {'max': 5.988, 'value': 5.988},
|
'max_v': 3.988,
|
||||||
'max_i_pos': {'max': 3.0, 'value': 3.0}},
|
'max_i_pos': 2.0,
|
||||||
'polarity': 'normal',
|
'polarity': 'normal',
|
||||||
{'channel': 1,
|
{'channel': 1,
|
||||||
'center': 'vref',
|
'center': 'vref',
|
||||||
'i_set': {'max': 2.9802790335151985, 'value': -0.02002179650216762},
|
'i_set': -0.02002179650216762,
|
||||||
'max_i_neg': {'max': 3.0, 'value': 3.0},
|
'max_i_neg': 2.0,
|
||||||
'max_v': {'max': 5.988, 'value': 5.988},
|
'max_v': 3.988,
|
||||||
'max_i_pos': {'max': 3.0, 'value': 3.0}}
|
'max_i_pos': 2.0}
|
||||||
'polarity': 'normal',
|
'polarity': 'normal',
|
||||||
]
|
]
|
||||||
"""
|
"""
|
||||||
|
@ -383,26 +383,26 @@ impl Channels {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_max_v(&mut self, channel: usize) -> (ElectricPotential, ElectricPotential) {
|
pub fn get_max_v(&mut self, channel: usize) -> ElectricPotential {
|
||||||
let max = 4.0 * ElectricPotential::new::<volt>(3.3);
|
let max = 4.0 * ElectricPotential::new::<volt>(3.3);
|
||||||
let duty = self.get_pwm(channel, PwmPin::MaxV);
|
let duty = self.get_pwm(channel, PwmPin::MaxV);
|
||||||
(duty * max, MAX_TEC_V)
|
duty * max
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_max_i_pos(&mut self, channel: usize) -> (ElectricCurrent, ElectricCurrent) {
|
pub fn get_max_i_pos(&mut self, channel: usize) -> ElectricCurrent {
|
||||||
let duty = match self.channel_state(channel).polarity {
|
let duty = match self.channel_state(channel).polarity {
|
||||||
Polarity::Normal => self.get_pwm(channel, PwmPin::MaxIPos),
|
Polarity::Normal => self.get_pwm(channel, PwmPin::MaxIPos),
|
||||||
Polarity::Reversed => self.get_pwm(channel, PwmPin::MaxINeg),
|
Polarity::Reversed => self.get_pwm(channel, PwmPin::MaxINeg),
|
||||||
};
|
};
|
||||||
(duty * MAX_TEC_I_DUTY_TO_CURRENT_RATE, MAX_TEC_I)
|
duty * MAX_TEC_I_DUTY_TO_CURRENT_RATE
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_max_i_neg(&mut self, channel: usize) -> (ElectricCurrent, ElectricCurrent) {
|
pub fn get_max_i_neg(&mut self, channel: usize) -> ElectricCurrent {
|
||||||
let duty = match self.channel_state(channel).polarity {
|
let duty = match self.channel_state(channel).polarity {
|
||||||
Polarity::Normal => self.get_pwm(channel, PwmPin::MaxINeg),
|
Polarity::Normal => self.get_pwm(channel, PwmPin::MaxINeg),
|
||||||
Polarity::Reversed => self.get_pwm(channel, PwmPin::MaxIPos),
|
Polarity::Reversed => self.get_pwm(channel, PwmPin::MaxIPos),
|
||||||
};
|
};
|
||||||
(duty * MAX_TEC_I_DUTY_TO_CURRENT_RATE, MAX_TEC_I)
|
duty * MAX_TEC_I_DUTY_TO_CURRENT_RATE
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get current passing through TEC
|
// Get current passing through TEC
|
||||||
@ -476,8 +476,8 @@ impl Channels {
|
|||||||
pub fn set_polarity(&mut self, channel: usize, polarity: Polarity) {
|
pub fn set_polarity(&mut self, channel: usize, polarity: Polarity) {
|
||||||
if self.channel_state(channel).polarity != polarity {
|
if self.channel_state(channel).polarity != polarity {
|
||||||
let i_set = self.channel_state(channel).i_set;
|
let i_set = self.channel_state(channel).i_set;
|
||||||
let max_i_pos = self.get_max_i_pos(channel).0;
|
let max_i_pos = self.get_max_i_pos(channel);
|
||||||
let max_i_neg = self.get_max_i_neg(channel).0;
|
let max_i_neg = self.get_max_i_neg(channel);
|
||||||
self.channel_state(channel).polarity = polarity;
|
self.channel_state(channel).polarity = polarity;
|
||||||
|
|
||||||
self.set_i(channel, i_set);
|
self.set_i(channel, i_set);
|
||||||
@ -541,10 +541,10 @@ impl Channels {
|
|||||||
PwmSummary {
|
PwmSummary {
|
||||||
channel,
|
channel,
|
||||||
center: CenterPointJson(self.channel_state(channel).center.clone()),
|
center: CenterPointJson(self.channel_state(channel).center.clone()),
|
||||||
i_set: (self.get_i(channel), MAX_TEC_I).into(),
|
i_set: self.get_i(channel),
|
||||||
max_v: self.get_max_v(channel).into(),
|
max_v: self.get_max_v(channel),
|
||||||
max_i_pos: self.get_max_i_pos(channel).into(),
|
max_i_pos: self.get_max_i_pos(channel),
|
||||||
max_i_neg: self.get_max_i_neg(channel).into(),
|
max_i_neg: self.get_max_i_neg(channel),
|
||||||
polarity: PolarityJson(self.channel_state(channel).polarity.clone()),
|
polarity: PolarityJson(self.channel_state(channel).polarity.clone()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -642,26 +642,14 @@ impl Serialize for PolarityJson {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize)]
|
|
||||||
pub struct PwmSummaryField<T: Serialize> {
|
|
||||||
value: T,
|
|
||||||
max: T,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: Serialize> From<(T, T)> for PwmSummaryField<T> {
|
|
||||||
fn from((value, max): (T, T)) -> Self {
|
|
||||||
PwmSummaryField { value, max }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Serialize)]
|
#[derive(Serialize)]
|
||||||
pub struct PwmSummary {
|
pub struct PwmSummary {
|
||||||
channel: usize,
|
channel: usize,
|
||||||
center: CenterPointJson,
|
center: CenterPointJson,
|
||||||
i_set: PwmSummaryField<ElectricCurrent>,
|
i_set: ElectricCurrent,
|
||||||
max_v: PwmSummaryField<ElectricPotential>,
|
max_v: ElectricPotential,
|
||||||
max_i_pos: PwmSummaryField<ElectricCurrent>,
|
max_i_pos: ElectricCurrent,
|
||||||
max_i_neg: PwmSummaryField<ElectricCurrent>,
|
max_i_neg: ElectricCurrent,
|
||||||
polarity: PolarityJson,
|
polarity: PolarityJson,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -83,9 +83,9 @@ struct PwmLimits {
|
|||||||
|
|
||||||
impl PwmLimits {
|
impl PwmLimits {
|
||||||
pub fn new(channels: &mut Channels, channel: usize) -> Self {
|
pub fn new(channels: &mut Channels, channel: usize) -> Self {
|
||||||
let (max_v, _) = channels.get_max_v(channel);
|
let max_v = channels.get_max_v(channel);
|
||||||
let (max_i_pos, _) = channels.get_max_i_pos(channel);
|
let max_i_pos = channels.get_max_i_pos(channel);
|
||||||
let (max_i_neg, _) = channels.get_max_i_neg(channel);
|
let max_i_neg = channels.get_max_i_neg(channel);
|
||||||
PwmLimits {
|
PwmLimits {
|
||||||
max_v: max_v.get::<volt>(),
|
max_v: max_v.get::<volt>(),
|
||||||
max_i_pos: max_i_pos.get::<ampere>(),
|
max_i_pos: max_i_pos.get::<ampere>(),
|
||||||
|
Loading…
Reference in New Issue
Block a user