#![allow(unused, clippy::comparison_to_empty, clippy::manual_range_patterns)]
use crate::profile::{ProfileType, typedef};
use crate::proto::*;
fn is_expanded(state: &[u8], num: u8) -> bool {
match num {
124 | 125 | 126 | 127 | 128 | 169 | 170 | 180 => {
(state[num as usize >> 3] >> (num & 7)) & 1 == 1
}
_ => false,
}
}
#[derive(Debug, Clone)]
pub struct Session {
pub message_index: typedef::MessageIndex,
pub timestamp: typedef::DateTime,
pub event: typedef::Event,
pub event_type: typedef::EventType,
pub start_time: typedef::DateTime,
pub start_position_lat: i32,
pub start_position_long: i32,
pub sport: typedef::Sport,
pub sub_sport: typedef::SubSport,
pub total_elapsed_time: u32,
pub total_timer_time: u32,
pub total_distance: u32,
pub total_cycles: u32,
pub total_calories: u16,
pub total_fat_calories: u16,
pub avg_speed: u16,
pub max_speed: u16,
pub avg_heart_rate: u8,
pub max_heart_rate: u8,
pub avg_cadence: u8,
pub max_cadence: u8,
pub avg_power: u16,
pub max_power: u16,
pub total_ascent: u16,
pub total_descent: u16,
pub total_training_effect: u8,
pub first_lap_index: u16,
pub num_laps: u16,
pub event_group: u8,
pub trigger: typedef::SessionTrigger,
pub nec_lat: i32,
pub nec_long: i32,
pub swc_lat: i32,
pub swc_long: i32,
pub num_lengths: u16,
pub normalized_power: u16,
pub training_stress_score: u16,
pub intensity_factor: u16,
pub left_right_balance: typedef::LeftRightBalance100,
pub end_position_lat: i32,
pub end_position_long: i32,
pub avg_stroke_count: u32,
pub avg_stroke_distance: u16,
pub swim_stroke: typedef::SwimStroke,
pub pool_length: u16,
pub threshold_power: u16,
pub pool_length_unit: typedef::DisplayMeasure,
pub num_active_lengths: u16,
pub total_work: u32,
pub avg_altitude: u16,
pub max_altitude: u16,
pub gps_accuracy: u8,
pub avg_grade: i16,
pub avg_pos_grade: i16,
pub avg_neg_grade: i16,
pub max_pos_grade: i16,
pub max_neg_grade: i16,
pub avg_temperature: i8,
pub max_temperature: i8,
pub total_moving_time: u32,
pub avg_pos_vertical_speed: i16,
pub avg_neg_vertical_speed: i16,
pub max_pos_vertical_speed: i16,
pub max_neg_vertical_speed: i16,
pub min_heart_rate: u8,
pub time_in_hr_zone: Vec<u32>,
pub time_in_speed_zone: Vec<u32>,
pub time_in_cadence_zone: Vec<u32>,
pub time_in_power_zone: Vec<u32>,
pub avg_lap_time: u32,
pub best_lap_index: u16,
pub min_altitude: u16,
pub player_score: u16,
pub opponent_score: u16,
pub opponent_name: String,
pub stroke_count: Vec<u16>,
pub zone_count: Vec<u16>,
pub max_ball_speed: u16,
pub avg_ball_speed: u16,
pub avg_vertical_oscillation: u16,
pub avg_stance_time_percent: u16,
pub avg_stance_time: u16,
pub avg_fractional_cadence: u8,
pub max_fractional_cadence: u8,
pub total_fractional_cycles: u8,
pub avg_total_hemoglobin_conc: Vec<u16>,
pub min_total_hemoglobin_conc: Vec<u16>,
pub max_total_hemoglobin_conc: Vec<u16>,
pub avg_saturated_hemoglobin_percent: Vec<u16>,
pub min_saturated_hemoglobin_percent: Vec<u16>,
pub max_saturated_hemoglobin_percent: Vec<u16>,
pub avg_left_torque_effectiveness: u8,
pub avg_right_torque_effectiveness: u8,
pub avg_left_pedal_smoothness: u8,
pub avg_right_pedal_smoothness: u8,
pub avg_combined_pedal_smoothness: u8,
pub sport_profile_name: String,
pub sport_index: u8,
pub time_standing: u32,
pub stand_count: u16,
pub avg_left_pco: i8,
pub avg_right_pco: i8,
pub avg_left_power_phase: Vec<u8>,
pub avg_left_power_phase_peak: Vec<u8>,
pub avg_right_power_phase: Vec<u8>,
pub avg_right_power_phase_peak: Vec<u8>,
pub avg_power_position: Vec<u16>,
pub max_power_position: Vec<u16>,
pub avg_cadence_position: Vec<u8>,
pub max_cadence_position: Vec<u8>,
pub enhanced_avg_speed: u32,
pub enhanced_max_speed: u32,
pub enhanced_avg_altitude: u32,
pub enhanced_min_altitude: u32,
pub enhanced_max_altitude: u32,
pub avg_lev_motor_power: u16,
pub max_lev_motor_power: u16,
pub lev_battery_consumption: u8,
pub avg_vertical_ratio: u16,
pub avg_stance_time_balance: u16,
pub avg_step_length: u16,
pub total_anaerobic_training_effect: u8,
pub avg_vam: u16,
pub avg_depth: u32,
pub max_depth: u32,
pub surface_interval: u32,
pub start_cns: u8,
pub end_cns: u8,
pub start_n2: u16,
pub end_n2: u16,
pub avg_respiration_rate: u8,
pub max_respiration_rate: u8,
pub min_respiration_rate: u8,
pub min_temperature: i8,
pub o2_toxicity: u16,
pub dive_number: u32,
pub training_load_peak: i32,
pub enhanced_avg_respiration_rate: u16,
pub enhanced_max_respiration_rate: u16,
pub enhanced_min_respiration_rate: u16,
pub total_grit: f32,
pub total_flow: f32,
pub jump_count: u16,
pub avg_grit: f32,
pub avg_flow: f32,
pub workout_feel: u8,
pub workout_rpe: u8,
pub avg_spo2: u8,
pub avg_stress: u8,
pub metabolic_calories: u16,
pub sdrr_hrv: u8,
pub rmssd_hrv: u8,
pub total_fractional_ascent: u8,
pub total_fractional_descent: u8,
pub avg_core_temperature: u16,
pub min_core_temperature: u16,
pub max_core_temperature: u16,
state: [u8; 23], pub unknown_fields: Vec<Field>,
pub developer_fields: Vec<DeveloperField>,
}
impl Session {
pub const MESSAGE_INDEX: u8 = 254;
pub const TIMESTAMP: u8 = 253;
pub const EVENT: u8 = 0;
pub const EVENT_TYPE: u8 = 1;
pub const START_TIME: u8 = 2;
pub const START_POSITION_LAT: u8 = 3;
pub const START_POSITION_LONG: u8 = 4;
pub const SPORT: u8 = 5;
pub const SUB_SPORT: u8 = 6;
pub const TOTAL_ELAPSED_TIME: u8 = 7;
pub const TOTAL_TIMER_TIME: u8 = 8;
pub const TOTAL_DISTANCE: u8 = 9;
pub const TOTAL_CYCLES: u8 = 10;
pub const TOTAL_CALORIES: u8 = 11;
pub const TOTAL_FAT_CALORIES: u8 = 13;
pub const AVG_SPEED: u8 = 14;
pub const MAX_SPEED: u8 = 15;
pub const AVG_HEART_RATE: u8 = 16;
pub const MAX_HEART_RATE: u8 = 17;
pub const AVG_CADENCE: u8 = 18;
pub const MAX_CADENCE: u8 = 19;
pub const AVG_POWER: u8 = 20;
pub const MAX_POWER: u8 = 21;
pub const TOTAL_ASCENT: u8 = 22;
pub const TOTAL_DESCENT: u8 = 23;
pub const TOTAL_TRAINING_EFFECT: u8 = 24;
pub const FIRST_LAP_INDEX: u8 = 25;
pub const NUM_LAPS: u8 = 26;
pub const EVENT_GROUP: u8 = 27;
pub const TRIGGER: u8 = 28;
pub const NEC_LAT: u8 = 29;
pub const NEC_LONG: u8 = 30;
pub const SWC_LAT: u8 = 31;
pub const SWC_LONG: u8 = 32;
pub const NUM_LENGTHS: u8 = 33;
pub const NORMALIZED_POWER: u8 = 34;
pub const TRAINING_STRESS_SCORE: u8 = 35;
pub const INTENSITY_FACTOR: u8 = 36;
pub const LEFT_RIGHT_BALANCE: u8 = 37;
pub const END_POSITION_LAT: u8 = 38;
pub const END_POSITION_LONG: u8 = 39;
pub const AVG_STROKE_COUNT: u8 = 41;
pub const AVG_STROKE_DISTANCE: u8 = 42;
pub const SWIM_STROKE: u8 = 43;
pub const POOL_LENGTH: u8 = 44;
pub const THRESHOLD_POWER: u8 = 45;
pub const POOL_LENGTH_UNIT: u8 = 46;
pub const NUM_ACTIVE_LENGTHS: u8 = 47;
pub const TOTAL_WORK: u8 = 48;
pub const AVG_ALTITUDE: u8 = 49;
pub const MAX_ALTITUDE: u8 = 50;
pub const GPS_ACCURACY: u8 = 51;
pub const AVG_GRADE: u8 = 52;
pub const AVG_POS_GRADE: u8 = 53;
pub const AVG_NEG_GRADE: u8 = 54;
pub const MAX_POS_GRADE: u8 = 55;
pub const MAX_NEG_GRADE: u8 = 56;
pub const AVG_TEMPERATURE: u8 = 57;
pub const MAX_TEMPERATURE: u8 = 58;
pub const TOTAL_MOVING_TIME: u8 = 59;
pub const AVG_POS_VERTICAL_SPEED: u8 = 60;
pub const AVG_NEG_VERTICAL_SPEED: u8 = 61;
pub const MAX_POS_VERTICAL_SPEED: u8 = 62;
pub const MAX_NEG_VERTICAL_SPEED: u8 = 63;
pub const MIN_HEART_RATE: u8 = 64;
pub const TIME_IN_HR_ZONE: u8 = 65;
pub const TIME_IN_SPEED_ZONE: u8 = 66;
pub const TIME_IN_CADENCE_ZONE: u8 = 67;
pub const TIME_IN_POWER_ZONE: u8 = 68;
pub const AVG_LAP_TIME: u8 = 69;
pub const BEST_LAP_INDEX: u8 = 70;
pub const MIN_ALTITUDE: u8 = 71;
pub const PLAYER_SCORE: u8 = 82;
pub const OPPONENT_SCORE: u8 = 83;
pub const OPPONENT_NAME: u8 = 84;
pub const STROKE_COUNT: u8 = 85;
pub const ZONE_COUNT: u8 = 86;
pub const MAX_BALL_SPEED: u8 = 87;
pub const AVG_BALL_SPEED: u8 = 88;
pub const AVG_VERTICAL_OSCILLATION: u8 = 89;
pub const AVG_STANCE_TIME_PERCENT: u8 = 90;
pub const AVG_STANCE_TIME: u8 = 91;
pub const AVG_FRACTIONAL_CADENCE: u8 = 92;
pub const MAX_FRACTIONAL_CADENCE: u8 = 93;
pub const TOTAL_FRACTIONAL_CYCLES: u8 = 94;
pub const AVG_TOTAL_HEMOGLOBIN_CONC: u8 = 95;
pub const MIN_TOTAL_HEMOGLOBIN_CONC: u8 = 96;
pub const MAX_TOTAL_HEMOGLOBIN_CONC: u8 = 97;
pub const AVG_SATURATED_HEMOGLOBIN_PERCENT: u8 = 98;
pub const MIN_SATURATED_HEMOGLOBIN_PERCENT: u8 = 99;
pub const MAX_SATURATED_HEMOGLOBIN_PERCENT: u8 = 100;
pub const AVG_LEFT_TORQUE_EFFECTIVENESS: u8 = 101;
pub const AVG_RIGHT_TORQUE_EFFECTIVENESS: u8 = 102;
pub const AVG_LEFT_PEDAL_SMOOTHNESS: u8 = 103;
pub const AVG_RIGHT_PEDAL_SMOOTHNESS: u8 = 104;
pub const AVG_COMBINED_PEDAL_SMOOTHNESS: u8 = 105;
pub const SPORT_PROFILE_NAME: u8 = 110;
pub const SPORT_INDEX: u8 = 111;
pub const TIME_STANDING: u8 = 112;
pub const STAND_COUNT: u8 = 113;
pub const AVG_LEFT_PCO: u8 = 114;
pub const AVG_RIGHT_PCO: u8 = 115;
pub const AVG_LEFT_POWER_PHASE: u8 = 116;
pub const AVG_LEFT_POWER_PHASE_PEAK: u8 = 117;
pub const AVG_RIGHT_POWER_PHASE: u8 = 118;
pub const AVG_RIGHT_POWER_PHASE_PEAK: u8 = 119;
pub const AVG_POWER_POSITION: u8 = 120;
pub const MAX_POWER_POSITION: u8 = 121;
pub const AVG_CADENCE_POSITION: u8 = 122;
pub const MAX_CADENCE_POSITION: u8 = 123;
pub const ENHANCED_AVG_SPEED: u8 = 124;
pub const ENHANCED_MAX_SPEED: u8 = 125;
pub const ENHANCED_AVG_ALTITUDE: u8 = 126;
pub const ENHANCED_MIN_ALTITUDE: u8 = 127;
pub const ENHANCED_MAX_ALTITUDE: u8 = 128;
pub const AVG_LEV_MOTOR_POWER: u8 = 129;
pub const MAX_LEV_MOTOR_POWER: u8 = 130;
pub const LEV_BATTERY_CONSUMPTION: u8 = 131;
pub const AVG_VERTICAL_RATIO: u8 = 132;
pub const AVG_STANCE_TIME_BALANCE: u8 = 133;
pub const AVG_STEP_LENGTH: u8 = 134;
pub const TOTAL_ANAEROBIC_TRAINING_EFFECT: u8 = 137;
pub const AVG_VAM: u8 = 139;
pub const AVG_DEPTH: u8 = 140;
pub const MAX_DEPTH: u8 = 141;
pub const SURFACE_INTERVAL: u8 = 142;
pub const START_CNS: u8 = 143;
pub const END_CNS: u8 = 144;
pub const START_N2: u8 = 145;
pub const END_N2: u8 = 146;
pub const AVG_RESPIRATION_RATE: u8 = 147;
pub const MAX_RESPIRATION_RATE: u8 = 148;
pub const MIN_RESPIRATION_RATE: u8 = 149;
pub const MIN_TEMPERATURE: u8 = 150;
pub const O2_TOXICITY: u8 = 155;
pub const DIVE_NUMBER: u8 = 156;
pub const TRAINING_LOAD_PEAK: u8 = 168;
pub const ENHANCED_AVG_RESPIRATION_RATE: u8 = 169;
pub const ENHANCED_MAX_RESPIRATION_RATE: u8 = 170;
pub const ENHANCED_MIN_RESPIRATION_RATE: u8 = 180;
pub const TOTAL_GRIT: u8 = 181;
pub const TOTAL_FLOW: u8 = 182;
pub const JUMP_COUNT: u8 = 183;
pub const AVG_GRIT: u8 = 186;
pub const AVG_FLOW: u8 = 187;
pub const WORKOUT_FEEL: u8 = 192;
pub const WORKOUT_RPE: u8 = 193;
pub const AVG_SPO2: u8 = 194;
pub const AVG_STRESS: u8 = 195;
pub const METABOLIC_CALORIES: u8 = 196;
pub const SDRR_HRV: u8 = 197;
pub const RMSSD_HRV: u8 = 198;
pub const TOTAL_FRACTIONAL_ASCENT: u8 = 199;
pub const TOTAL_FRACTIONAL_DESCENT: u8 = 200;
pub const AVG_CORE_TEMPERATURE: u8 = 208;
pub const MIN_CORE_TEMPERATURE: u8 = 209;
pub const MAX_CORE_TEMPERATURE: u8 = 210;
pub const fn new() -> Self {
Self {
message_index: typedef::MessageIndex(u16::MAX),
timestamp: typedef::DateTime(u32::MAX),
event: typedef::Event(u8::MAX),
event_type: typedef::EventType(u8::MAX),
start_time: typedef::DateTime(u32::MAX),
start_position_lat: i32::MAX,
start_position_long: i32::MAX,
sport: typedef::Sport(u8::MAX),
sub_sport: typedef::SubSport(u8::MAX),
total_elapsed_time: u32::MAX,
total_timer_time: u32::MAX,
total_distance: u32::MAX,
total_cycles: u32::MAX,
total_calories: u16::MAX,
total_fat_calories: u16::MAX,
avg_speed: u16::MAX,
max_speed: u16::MAX,
avg_heart_rate: u8::MAX,
max_heart_rate: u8::MAX,
avg_cadence: u8::MAX,
max_cadence: u8::MAX,
avg_power: u16::MAX,
max_power: u16::MAX,
total_ascent: u16::MAX,
total_descent: u16::MAX,
total_training_effect: u8::MAX,
first_lap_index: u16::MAX,
num_laps: u16::MAX,
event_group: u8::MAX,
trigger: typedef::SessionTrigger(u8::MAX),
nec_lat: i32::MAX,
nec_long: i32::MAX,
swc_lat: i32::MAX,
swc_long: i32::MAX,
num_lengths: u16::MAX,
normalized_power: u16::MAX,
training_stress_score: u16::MAX,
intensity_factor: u16::MAX,
left_right_balance: typedef::LeftRightBalance100(u16::MAX),
end_position_lat: i32::MAX,
end_position_long: i32::MAX,
avg_stroke_count: u32::MAX,
avg_stroke_distance: u16::MAX,
swim_stroke: typedef::SwimStroke(u8::MAX),
pool_length: u16::MAX,
threshold_power: u16::MAX,
pool_length_unit: typedef::DisplayMeasure(u8::MAX),
num_active_lengths: u16::MAX,
total_work: u32::MAX,
avg_altitude: u16::MAX,
max_altitude: u16::MAX,
gps_accuracy: u8::MAX,
avg_grade: i16::MAX,
avg_pos_grade: i16::MAX,
avg_neg_grade: i16::MAX,
max_pos_grade: i16::MAX,
max_neg_grade: i16::MAX,
avg_temperature: i8::MAX,
max_temperature: i8::MAX,
total_moving_time: u32::MAX,
avg_pos_vertical_speed: i16::MAX,
avg_neg_vertical_speed: i16::MAX,
max_pos_vertical_speed: i16::MAX,
max_neg_vertical_speed: i16::MAX,
min_heart_rate: u8::MAX,
time_in_hr_zone: Vec::<u32>::new(),
time_in_speed_zone: Vec::<u32>::new(),
time_in_cadence_zone: Vec::<u32>::new(),
time_in_power_zone: Vec::<u32>::new(),
avg_lap_time: u32::MAX,
best_lap_index: u16::MAX,
min_altitude: u16::MAX,
player_score: u16::MAX,
opponent_score: u16::MAX,
opponent_name: String::new(),
stroke_count: Vec::<u16>::new(),
zone_count: Vec::<u16>::new(),
max_ball_speed: u16::MAX,
avg_ball_speed: u16::MAX,
avg_vertical_oscillation: u16::MAX,
avg_stance_time_percent: u16::MAX,
avg_stance_time: u16::MAX,
avg_fractional_cadence: u8::MAX,
max_fractional_cadence: u8::MAX,
total_fractional_cycles: u8::MAX,
avg_total_hemoglobin_conc: Vec::<u16>::new(),
min_total_hemoglobin_conc: Vec::<u16>::new(),
max_total_hemoglobin_conc: Vec::<u16>::new(),
avg_saturated_hemoglobin_percent: Vec::<u16>::new(),
min_saturated_hemoglobin_percent: Vec::<u16>::new(),
max_saturated_hemoglobin_percent: Vec::<u16>::new(),
avg_left_torque_effectiveness: u8::MAX,
avg_right_torque_effectiveness: u8::MAX,
avg_left_pedal_smoothness: u8::MAX,
avg_right_pedal_smoothness: u8::MAX,
avg_combined_pedal_smoothness: u8::MAX,
sport_profile_name: String::new(),
sport_index: u8::MAX,
time_standing: u32::MAX,
stand_count: u16::MAX,
avg_left_pco: i8::MAX,
avg_right_pco: i8::MAX,
avg_left_power_phase: Vec::<u8>::new(),
avg_left_power_phase_peak: Vec::<u8>::new(),
avg_right_power_phase: Vec::<u8>::new(),
avg_right_power_phase_peak: Vec::<u8>::new(),
avg_power_position: Vec::<u16>::new(),
max_power_position: Vec::<u16>::new(),
avg_cadence_position: Vec::<u8>::new(),
max_cadence_position: Vec::<u8>::new(),
enhanced_avg_speed: u32::MAX,
enhanced_max_speed: u32::MAX,
enhanced_avg_altitude: u32::MAX,
enhanced_min_altitude: u32::MAX,
enhanced_max_altitude: u32::MAX,
avg_lev_motor_power: u16::MAX,
max_lev_motor_power: u16::MAX,
lev_battery_consumption: u8::MAX,
avg_vertical_ratio: u16::MAX,
avg_stance_time_balance: u16::MAX,
avg_step_length: u16::MAX,
total_anaerobic_training_effect: u8::MAX,
avg_vam: u16::MAX,
avg_depth: u32::MAX,
max_depth: u32::MAX,
surface_interval: u32::MAX,
start_cns: u8::MAX,
end_cns: u8::MAX,
start_n2: u16::MAX,
end_n2: u16::MAX,
avg_respiration_rate: u8::MAX,
max_respiration_rate: u8::MAX,
min_respiration_rate: u8::MAX,
min_temperature: i8::MAX,
o2_toxicity: u16::MAX,
dive_number: u32::MAX,
training_load_peak: i32::MAX,
enhanced_avg_respiration_rate: u16::MAX,
enhanced_max_respiration_rate: u16::MAX,
enhanced_min_respiration_rate: u16::MAX,
total_grit: f32::MAX,
total_flow: f32::MAX,
jump_count: u16::MAX,
avg_grit: f32::MAX,
avg_flow: f32::MAX,
workout_feel: u8::MAX,
workout_rpe: u8::MAX,
avg_spo2: u8::MAX,
avg_stress: u8::MAX,
metabolic_calories: u16::MAX,
sdrr_hrv: u8::MAX,
rmssd_hrv: u8::MAX,
total_fractional_ascent: u8::MAX,
total_fractional_descent: u8::MAX,
avg_core_temperature: u16::MAX,
min_core_temperature: u16::MAX,
max_core_temperature: u16::MAX,
state: [0u8; 23],
unknown_fields: Vec::new(),
developer_fields: Vec::new(),
}
}
pub fn total_elapsed_time_scaled(&self) -> f64 {
if self.total_elapsed_time == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.total_elapsed_time as f64 / 1000.0 - 0.0
}
pub fn set_total_elapsed_time_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.total_elapsed_time = u32::MAX;
return self;
}
self.total_elapsed_time = unscaled as u32;
self
}
pub fn total_timer_time_scaled(&self) -> f64 {
if self.total_timer_time == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.total_timer_time as f64 / 1000.0 - 0.0
}
pub fn set_total_timer_time_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.total_timer_time = u32::MAX;
return self;
}
self.total_timer_time = unscaled as u32;
self
}
pub fn total_distance_scaled(&self) -> f64 {
if self.total_distance == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.total_distance as f64 / 100.0 - 0.0
}
pub fn set_total_distance_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.total_distance = u32::MAX;
return self;
}
self.total_distance = unscaled as u32;
self
}
pub fn avg_speed_scaled(&self) -> f64 {
if self.avg_speed == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_speed as f64 / 1000.0 - 0.0
}
pub fn set_avg_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_speed = u16::MAX;
return self;
}
self.avg_speed = unscaled as u16;
self
}
pub fn max_speed_scaled(&self) -> f64 {
if self.max_speed == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_speed as f64 / 1000.0 - 0.0
}
pub fn set_max_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.max_speed = u16::MAX;
return self;
}
self.max_speed = unscaled as u16;
self
}
pub fn total_training_effect_scaled(&self) -> f64 {
if self.total_training_effect == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.total_training_effect as f64 / 10.0 - 0.0
}
pub fn set_total_training_effect_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.total_training_effect = u8::MAX;
return self;
}
self.total_training_effect = unscaled as u8;
self
}
pub fn training_stress_score_scaled(&self) -> f64 {
if self.training_stress_score == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.training_stress_score as f64 / 10.0 - 0.0
}
pub fn set_training_stress_score_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.training_stress_score = u16::MAX;
return self;
}
self.training_stress_score = unscaled as u16;
self
}
pub fn intensity_factor_scaled(&self) -> f64 {
if self.intensity_factor == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.intensity_factor as f64 / 1000.0 - 0.0
}
pub fn set_intensity_factor_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.intensity_factor = u16::MAX;
return self;
}
self.intensity_factor = unscaled as u16;
self
}
pub fn avg_stroke_count_scaled(&self) -> f64 {
if self.avg_stroke_count == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_stroke_count as f64 / 10.0 - 0.0
}
pub fn set_avg_stroke_count_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.avg_stroke_count = u32::MAX;
return self;
}
self.avg_stroke_count = unscaled as u32;
self
}
pub fn avg_stroke_distance_scaled(&self) -> f64 {
if self.avg_stroke_distance == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_stroke_distance as f64 / 100.0 - 0.0
}
pub fn set_avg_stroke_distance_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_stroke_distance = u16::MAX;
return self;
}
self.avg_stroke_distance = unscaled as u16;
self
}
pub fn pool_length_scaled(&self) -> f64 {
if self.pool_length == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.pool_length as f64 / 100.0 - 0.0
}
pub fn set_pool_length_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.pool_length = u16::MAX;
return self;
}
self.pool_length = unscaled as u16;
self
}
pub fn avg_altitude_scaled(&self) -> f64 {
if self.avg_altitude == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_altitude as f64 / 5.0 - 500.0
}
pub fn set_avg_altitude_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 500.0) * 5.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_altitude = u16::MAX;
return self;
}
self.avg_altitude = unscaled as u16;
self
}
pub fn max_altitude_scaled(&self) -> f64 {
if self.max_altitude == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_altitude as f64 / 5.0 - 500.0
}
pub fn set_max_altitude_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 500.0) * 5.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.max_altitude = u16::MAX;
return self;
}
self.max_altitude = unscaled as u16;
self
}
pub fn avg_grade_scaled(&self) -> f64 {
if self.avg_grade == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_grade as f64 / 100.0 - 0.0
}
pub fn set_avg_grade_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.avg_grade = i16::MAX;
return self;
}
self.avg_grade = unscaled as i16;
self
}
pub fn avg_pos_grade_scaled(&self) -> f64 {
if self.avg_pos_grade == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_pos_grade as f64 / 100.0 - 0.0
}
pub fn set_avg_pos_grade_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.avg_pos_grade = i16::MAX;
return self;
}
self.avg_pos_grade = unscaled as i16;
self
}
pub fn avg_neg_grade_scaled(&self) -> f64 {
if self.avg_neg_grade == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_neg_grade as f64 / 100.0 - 0.0
}
pub fn set_avg_neg_grade_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.avg_neg_grade = i16::MAX;
return self;
}
self.avg_neg_grade = unscaled as i16;
self
}
pub fn max_pos_grade_scaled(&self) -> f64 {
if self.max_pos_grade == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_pos_grade as f64 / 100.0 - 0.0
}
pub fn set_max_pos_grade_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.max_pos_grade = i16::MAX;
return self;
}
self.max_pos_grade = unscaled as i16;
self
}
pub fn max_neg_grade_scaled(&self) -> f64 {
if self.max_neg_grade == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_neg_grade as f64 / 100.0 - 0.0
}
pub fn set_max_neg_grade_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.max_neg_grade = i16::MAX;
return self;
}
self.max_neg_grade = unscaled as i16;
self
}
pub fn total_moving_time_scaled(&self) -> f64 {
if self.total_moving_time == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.total_moving_time as f64 / 1000.0 - 0.0
}
pub fn set_total_moving_time_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.total_moving_time = u32::MAX;
return self;
}
self.total_moving_time = unscaled as u32;
self
}
pub fn avg_pos_vertical_speed_scaled(&self) -> f64 {
if self.avg_pos_vertical_speed == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_pos_vertical_speed as f64 / 1000.0 - 0.0
}
pub fn set_avg_pos_vertical_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.avg_pos_vertical_speed = i16::MAX;
return self;
}
self.avg_pos_vertical_speed = unscaled as i16;
self
}
pub fn avg_neg_vertical_speed_scaled(&self) -> f64 {
if self.avg_neg_vertical_speed == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_neg_vertical_speed as f64 / 1000.0 - 0.0
}
pub fn set_avg_neg_vertical_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.avg_neg_vertical_speed = i16::MAX;
return self;
}
self.avg_neg_vertical_speed = unscaled as i16;
self
}
pub fn max_pos_vertical_speed_scaled(&self) -> f64 {
if self.max_pos_vertical_speed == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_pos_vertical_speed as f64 / 1000.0 - 0.0
}
pub fn set_max_pos_vertical_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.max_pos_vertical_speed = i16::MAX;
return self;
}
self.max_pos_vertical_speed = unscaled as i16;
self
}
pub fn max_neg_vertical_speed_scaled(&self) -> f64 {
if self.max_neg_vertical_speed == i16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_neg_vertical_speed as f64 / 1000.0 - 0.0
}
pub fn set_max_neg_vertical_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i16::MAX as f64 {
self.max_neg_vertical_speed = i16::MAX;
return self;
}
self.max_neg_vertical_speed = unscaled as i16;
self
}
pub fn time_in_hr_zone_scaled(&self) -> Vec<f64> {
if self.time_in_hr_zone == Vec::<u32>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.time_in_hr_zone.len());
for &x in &self.time_in_hr_zone {
v.push(x as f64 / 1000.0 - 0.0)
}
v
}
pub fn set_time_in_hr_zone_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.time_in_hr_zone = Vec::new();
return self;
}
self.time_in_hr_zone = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.time_in_hr_zone.push(u32::MAX);
continue;
}
self.time_in_hr_zone.push(unscaled as u32);
}
self
}
pub fn time_in_speed_zone_scaled(&self) -> Vec<f64> {
if self.time_in_speed_zone == Vec::<u32>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.time_in_speed_zone.len());
for &x in &self.time_in_speed_zone {
v.push(x as f64 / 1000.0 - 0.0)
}
v
}
pub fn set_time_in_speed_zone_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.time_in_speed_zone = Vec::new();
return self;
}
self.time_in_speed_zone = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.time_in_speed_zone.push(u32::MAX);
continue;
}
self.time_in_speed_zone.push(unscaled as u32);
}
self
}
pub fn time_in_cadence_zone_scaled(&self) -> Vec<f64> {
if self.time_in_cadence_zone == Vec::<u32>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.time_in_cadence_zone.len());
for &x in &self.time_in_cadence_zone {
v.push(x as f64 / 1000.0 - 0.0)
}
v
}
pub fn set_time_in_cadence_zone_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.time_in_cadence_zone = Vec::new();
return self;
}
self.time_in_cadence_zone = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.time_in_cadence_zone.push(u32::MAX);
continue;
}
self.time_in_cadence_zone.push(unscaled as u32);
}
self
}
pub fn time_in_power_zone_scaled(&self) -> Vec<f64> {
if self.time_in_power_zone == Vec::<u32>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.time_in_power_zone.len());
for &x in &self.time_in_power_zone {
v.push(x as f64 / 1000.0 - 0.0)
}
v
}
pub fn set_time_in_power_zone_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.time_in_power_zone = Vec::new();
return self;
}
self.time_in_power_zone = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.time_in_power_zone.push(u32::MAX);
continue;
}
self.time_in_power_zone.push(unscaled as u32);
}
self
}
pub fn avg_lap_time_scaled(&self) -> f64 {
if self.avg_lap_time == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_lap_time as f64 / 1000.0 - 0.0
}
pub fn set_avg_lap_time_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.avg_lap_time = u32::MAX;
return self;
}
self.avg_lap_time = unscaled as u32;
self
}
pub fn min_altitude_scaled(&self) -> f64 {
if self.min_altitude == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.min_altitude as f64 / 5.0 - 500.0
}
pub fn set_min_altitude_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 500.0) * 5.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.min_altitude = u16::MAX;
return self;
}
self.min_altitude = unscaled as u16;
self
}
pub fn max_ball_speed_scaled(&self) -> f64 {
if self.max_ball_speed == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_ball_speed as f64 / 100.0 - 0.0
}
pub fn set_max_ball_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.max_ball_speed = u16::MAX;
return self;
}
self.max_ball_speed = unscaled as u16;
self
}
pub fn avg_ball_speed_scaled(&self) -> f64 {
if self.avg_ball_speed == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_ball_speed as f64 / 100.0 - 0.0
}
pub fn set_avg_ball_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_ball_speed = u16::MAX;
return self;
}
self.avg_ball_speed = unscaled as u16;
self
}
pub fn avg_vertical_oscillation_scaled(&self) -> f64 {
if self.avg_vertical_oscillation == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_vertical_oscillation as f64 / 10.0 - 0.0
}
pub fn set_avg_vertical_oscillation_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_vertical_oscillation = u16::MAX;
return self;
}
self.avg_vertical_oscillation = unscaled as u16;
self
}
pub fn avg_stance_time_percent_scaled(&self) -> f64 {
if self.avg_stance_time_percent == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_stance_time_percent as f64 / 100.0 - 0.0
}
pub fn set_avg_stance_time_percent_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_stance_time_percent = u16::MAX;
return self;
}
self.avg_stance_time_percent = unscaled as u16;
self
}
pub fn avg_stance_time_scaled(&self) -> f64 {
if self.avg_stance_time == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_stance_time as f64 / 10.0 - 0.0
}
pub fn set_avg_stance_time_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_stance_time = u16::MAX;
return self;
}
self.avg_stance_time = unscaled as u16;
self
}
pub fn avg_fractional_cadence_scaled(&self) -> f64 {
if self.avg_fractional_cadence == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_fractional_cadence as f64 / 128.0 - 0.0
}
pub fn set_avg_fractional_cadence_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 128.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_fractional_cadence = u8::MAX;
return self;
}
self.avg_fractional_cadence = unscaled as u8;
self
}
pub fn max_fractional_cadence_scaled(&self) -> f64 {
if self.max_fractional_cadence == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.max_fractional_cadence as f64 / 128.0 - 0.0
}
pub fn set_max_fractional_cadence_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 128.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.max_fractional_cadence = u8::MAX;
return self;
}
self.max_fractional_cadence = unscaled as u8;
self
}
pub fn total_fractional_cycles_scaled(&self) -> f64 {
if self.total_fractional_cycles == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.total_fractional_cycles as f64 / 128.0 - 0.0
}
pub fn set_total_fractional_cycles_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 128.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.total_fractional_cycles = u8::MAX;
return self;
}
self.total_fractional_cycles = unscaled as u8;
self
}
pub fn avg_total_hemoglobin_conc_scaled(&self) -> Vec<f64> {
if self.avg_total_hemoglobin_conc == Vec::<u16>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.avg_total_hemoglobin_conc.len());
for &x in &self.avg_total_hemoglobin_conc {
v.push(x as f64 / 100.0 - 0.0)
}
v
}
pub fn set_avg_total_hemoglobin_conc_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.avg_total_hemoglobin_conc = Vec::new();
return self;
}
self.avg_total_hemoglobin_conc = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_total_hemoglobin_conc.push(u16::MAX);
continue;
}
self.avg_total_hemoglobin_conc.push(unscaled as u16);
}
self
}
pub fn min_total_hemoglobin_conc_scaled(&self) -> Vec<f64> {
if self.min_total_hemoglobin_conc == Vec::<u16>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.min_total_hemoglobin_conc.len());
for &x in &self.min_total_hemoglobin_conc {
v.push(x as f64 / 100.0 - 0.0)
}
v
}
pub fn set_min_total_hemoglobin_conc_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.min_total_hemoglobin_conc = Vec::new();
return self;
}
self.min_total_hemoglobin_conc = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.min_total_hemoglobin_conc.push(u16::MAX);
continue;
}
self.min_total_hemoglobin_conc.push(unscaled as u16);
}
self
}
pub fn max_total_hemoglobin_conc_scaled(&self) -> Vec<f64> {
if self.max_total_hemoglobin_conc == Vec::<u16>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.max_total_hemoglobin_conc.len());
for &x in &self.max_total_hemoglobin_conc {
v.push(x as f64 / 100.0 - 0.0)
}
v
}
pub fn set_max_total_hemoglobin_conc_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.max_total_hemoglobin_conc = Vec::new();
return self;
}
self.max_total_hemoglobin_conc = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.max_total_hemoglobin_conc.push(u16::MAX);
continue;
}
self.max_total_hemoglobin_conc.push(unscaled as u16);
}
self
}
pub fn avg_saturated_hemoglobin_percent_scaled(&self) -> Vec<f64> {
if self.avg_saturated_hemoglobin_percent == Vec::<u16>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.avg_saturated_hemoglobin_percent.len());
for &x in &self.avg_saturated_hemoglobin_percent {
v.push(x as f64 / 10.0 - 0.0)
}
v
}
pub fn set_avg_saturated_hemoglobin_percent_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.avg_saturated_hemoglobin_percent = Vec::new();
return self;
}
self.avg_saturated_hemoglobin_percent = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_saturated_hemoglobin_percent.push(u16::MAX);
continue;
}
self.avg_saturated_hemoglobin_percent.push(unscaled as u16);
}
self
}
pub fn min_saturated_hemoglobin_percent_scaled(&self) -> Vec<f64> {
if self.min_saturated_hemoglobin_percent == Vec::<u16>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.min_saturated_hemoglobin_percent.len());
for &x in &self.min_saturated_hemoglobin_percent {
v.push(x as f64 / 10.0 - 0.0)
}
v
}
pub fn set_min_saturated_hemoglobin_percent_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.min_saturated_hemoglobin_percent = Vec::new();
return self;
}
self.min_saturated_hemoglobin_percent = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.min_saturated_hemoglobin_percent.push(u16::MAX);
continue;
}
self.min_saturated_hemoglobin_percent.push(unscaled as u16);
}
self
}
pub fn max_saturated_hemoglobin_percent_scaled(&self) -> Vec<f64> {
if self.max_saturated_hemoglobin_percent == Vec::<u16>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.max_saturated_hemoglobin_percent.len());
for &x in &self.max_saturated_hemoglobin_percent {
v.push(x as f64 / 10.0 - 0.0)
}
v
}
pub fn set_max_saturated_hemoglobin_percent_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.max_saturated_hemoglobin_percent = Vec::new();
return self;
}
self.max_saturated_hemoglobin_percent = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.max_saturated_hemoglobin_percent.push(u16::MAX);
continue;
}
self.max_saturated_hemoglobin_percent.push(unscaled as u16);
}
self
}
pub fn avg_left_torque_effectiveness_scaled(&self) -> f64 {
if self.avg_left_torque_effectiveness == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_left_torque_effectiveness as f64 / 2.0 - 0.0
}
pub fn set_avg_left_torque_effectiveness_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 2.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_left_torque_effectiveness = u8::MAX;
return self;
}
self.avg_left_torque_effectiveness = unscaled as u8;
self
}
pub fn avg_right_torque_effectiveness_scaled(&self) -> f64 {
if self.avg_right_torque_effectiveness == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_right_torque_effectiveness as f64 / 2.0 - 0.0
}
pub fn set_avg_right_torque_effectiveness_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 2.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_right_torque_effectiveness = u8::MAX;
return self;
}
self.avg_right_torque_effectiveness = unscaled as u8;
self
}
pub fn avg_left_pedal_smoothness_scaled(&self) -> f64 {
if self.avg_left_pedal_smoothness == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_left_pedal_smoothness as f64 / 2.0 - 0.0
}
pub fn set_avg_left_pedal_smoothness_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 2.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_left_pedal_smoothness = u8::MAX;
return self;
}
self.avg_left_pedal_smoothness = unscaled as u8;
self
}
pub fn avg_right_pedal_smoothness_scaled(&self) -> f64 {
if self.avg_right_pedal_smoothness == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_right_pedal_smoothness as f64 / 2.0 - 0.0
}
pub fn set_avg_right_pedal_smoothness_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 2.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_right_pedal_smoothness = u8::MAX;
return self;
}
self.avg_right_pedal_smoothness = unscaled as u8;
self
}
pub fn avg_combined_pedal_smoothness_scaled(&self) -> f64 {
if self.avg_combined_pedal_smoothness == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_combined_pedal_smoothness as f64 / 2.0 - 0.0
}
pub fn set_avg_combined_pedal_smoothness_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 2.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_combined_pedal_smoothness = u8::MAX;
return self;
}
self.avg_combined_pedal_smoothness = unscaled as u8;
self
}
pub fn time_standing_scaled(&self) -> f64 {
if self.time_standing == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.time_standing as f64 / 1000.0 - 0.0
}
pub fn set_time_standing_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.time_standing = u32::MAX;
return self;
}
self.time_standing = unscaled as u32;
self
}
pub fn avg_left_power_phase_scaled(&self) -> Vec<f64> {
if self.avg_left_power_phase == Vec::<u8>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.avg_left_power_phase.len());
for &x in &self.avg_left_power_phase {
v.push(x as f64 / 0.7111111 - 0.0)
}
v
}
pub fn set_avg_left_power_phase_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.avg_left_power_phase = Vec::new();
return self;
}
self.avg_left_power_phase = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 0.7111111;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_left_power_phase.push(u8::MAX);
continue;
}
self.avg_left_power_phase.push(unscaled as u8);
}
self
}
pub fn avg_left_power_phase_peak_scaled(&self) -> Vec<f64> {
if self.avg_left_power_phase_peak == Vec::<u8>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.avg_left_power_phase_peak.len());
for &x in &self.avg_left_power_phase_peak {
v.push(x as f64 / 0.7111111 - 0.0)
}
v
}
pub fn set_avg_left_power_phase_peak_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.avg_left_power_phase_peak = Vec::new();
return self;
}
self.avg_left_power_phase_peak = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 0.7111111;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_left_power_phase_peak.push(u8::MAX);
continue;
}
self.avg_left_power_phase_peak.push(unscaled as u8);
}
self
}
pub fn avg_right_power_phase_scaled(&self) -> Vec<f64> {
if self.avg_right_power_phase == Vec::<u8>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.avg_right_power_phase.len());
for &x in &self.avg_right_power_phase {
v.push(x as f64 / 0.7111111 - 0.0)
}
v
}
pub fn set_avg_right_power_phase_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.avg_right_power_phase = Vec::new();
return self;
}
self.avg_right_power_phase = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 0.7111111;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_right_power_phase.push(u8::MAX);
continue;
}
self.avg_right_power_phase.push(unscaled as u8);
}
self
}
pub fn avg_right_power_phase_peak_scaled(&self) -> Vec<f64> {
if self.avg_right_power_phase_peak == Vec::<u8>::new() {
return Vec::new();
}
let mut v = Vec::with_capacity(self.avg_right_power_phase_peak.len());
for &x in &self.avg_right_power_phase_peak {
v.push(x as f64 / 0.7111111 - 0.0)
}
v
}
pub fn set_avg_right_power_phase_peak_scaled(&mut self, v: &Vec<f64>) -> &mut Session {
if v.is_empty() {
self.avg_right_power_phase_peak = Vec::new();
return self;
}
self.avg_right_power_phase_peak = Vec::with_capacity(v.len());
for &x in v {
let unscaled = (x + 0.0) * 0.7111111;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.avg_right_power_phase_peak.push(u8::MAX);
continue;
}
self.avg_right_power_phase_peak.push(unscaled as u8);
}
self
}
pub fn enhanced_avg_speed_scaled(&self) -> f64 {
if self.enhanced_avg_speed == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_avg_speed as f64 / 1000.0 - 0.0
}
pub fn set_enhanced_avg_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.enhanced_avg_speed = u32::MAX;
return self;
}
self.enhanced_avg_speed = unscaled as u32;
self
}
pub fn enhanced_max_speed_scaled(&self) -> f64 {
if self.enhanced_max_speed == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_max_speed as f64 / 1000.0 - 0.0
}
pub fn set_enhanced_max_speed_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.enhanced_max_speed = u32::MAX;
return self;
}
self.enhanced_max_speed = unscaled as u32;
self
}
pub fn enhanced_avg_altitude_scaled(&self) -> f64 {
if self.enhanced_avg_altitude == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_avg_altitude as f64 / 5.0 - 500.0
}
pub fn set_enhanced_avg_altitude_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 500.0) * 5.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.enhanced_avg_altitude = u32::MAX;
return self;
}
self.enhanced_avg_altitude = unscaled as u32;
self
}
pub fn enhanced_min_altitude_scaled(&self) -> f64 {
if self.enhanced_min_altitude == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_min_altitude as f64 / 5.0 - 500.0
}
pub fn set_enhanced_min_altitude_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 500.0) * 5.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.enhanced_min_altitude = u32::MAX;
return self;
}
self.enhanced_min_altitude = unscaled as u32;
self
}
pub fn enhanced_max_altitude_scaled(&self) -> f64 {
if self.enhanced_max_altitude == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_max_altitude as f64 / 5.0 - 500.0
}
pub fn set_enhanced_max_altitude_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 500.0) * 5.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.enhanced_max_altitude = u32::MAX;
return self;
}
self.enhanced_max_altitude = unscaled as u32;
self
}
pub fn lev_battery_consumption_scaled(&self) -> f64 {
if self.lev_battery_consumption == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.lev_battery_consumption as f64 / 2.0 - 0.0
}
pub fn set_lev_battery_consumption_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 2.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.lev_battery_consumption = u8::MAX;
return self;
}
self.lev_battery_consumption = unscaled as u8;
self
}
pub fn avg_vertical_ratio_scaled(&self) -> f64 {
if self.avg_vertical_ratio == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_vertical_ratio as f64 / 100.0 - 0.0
}
pub fn set_avg_vertical_ratio_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_vertical_ratio = u16::MAX;
return self;
}
self.avg_vertical_ratio = unscaled as u16;
self
}
pub fn avg_stance_time_balance_scaled(&self) -> f64 {
if self.avg_stance_time_balance == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_stance_time_balance as f64 / 100.0 - 0.0
}
pub fn set_avg_stance_time_balance_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_stance_time_balance = u16::MAX;
return self;
}
self.avg_stance_time_balance = unscaled as u16;
self
}
pub fn avg_step_length_scaled(&self) -> f64 {
if self.avg_step_length == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_step_length as f64 / 10.0 - 0.0
}
pub fn set_avg_step_length_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_step_length = u16::MAX;
return self;
}
self.avg_step_length = unscaled as u16;
self
}
pub fn total_anaerobic_training_effect_scaled(&self) -> f64 {
if self.total_anaerobic_training_effect == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.total_anaerobic_training_effect as f64 / 10.0 - 0.0
}
pub fn set_total_anaerobic_training_effect_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 10.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.total_anaerobic_training_effect = u8::MAX;
return self;
}
self.total_anaerobic_training_effect = unscaled as u8;
self
}
pub fn avg_vam_scaled(&self) -> f64 {
if self.avg_vam == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_vam as f64 / 1000.0 - 0.0
}
pub fn set_avg_vam_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_vam = u16::MAX;
return self;
}
self.avg_vam = unscaled as u16;
self
}
pub fn avg_depth_scaled(&self) -> f64 {
if self.avg_depth == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_depth as f64 / 1000.0 - 0.0
}
pub fn set_avg_depth_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.avg_depth = u32::MAX;
return self;
}
self.avg_depth = unscaled as u32;
self
}
pub fn max_depth_scaled(&self) -> f64 {
if self.max_depth == u32::MAX {
return f64::from_bits(u64::MAX);
}
self.max_depth as f64 / 1000.0 - 0.0
}
pub fn set_max_depth_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 1000.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u32::MAX as f64 {
self.max_depth = u32::MAX;
return self;
}
self.max_depth = unscaled as u32;
self
}
pub fn training_load_peak_scaled(&self) -> f64 {
if self.training_load_peak == i32::MAX {
return f64::from_bits(u64::MAX);
}
self.training_load_peak as f64 / 65536.0 - 0.0
}
pub fn set_training_load_peak_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 65536.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > i32::MAX as f64 {
self.training_load_peak = i32::MAX;
return self;
}
self.training_load_peak = unscaled as i32;
self
}
pub fn enhanced_avg_respiration_rate_scaled(&self) -> f64 {
if self.enhanced_avg_respiration_rate == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_avg_respiration_rate as f64 / 100.0 - 0.0
}
pub fn set_enhanced_avg_respiration_rate_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.enhanced_avg_respiration_rate = u16::MAX;
return self;
}
self.enhanced_avg_respiration_rate = unscaled as u16;
self
}
pub fn enhanced_max_respiration_rate_scaled(&self) -> f64 {
if self.enhanced_max_respiration_rate == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_max_respiration_rate as f64 / 100.0 - 0.0
}
pub fn set_enhanced_max_respiration_rate_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.enhanced_max_respiration_rate = u16::MAX;
return self;
}
self.enhanced_max_respiration_rate = unscaled as u16;
self
}
pub fn enhanced_min_respiration_rate_scaled(&self) -> f64 {
if self.enhanced_min_respiration_rate == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.enhanced_min_respiration_rate as f64 / 100.0 - 0.0
}
pub fn set_enhanced_min_respiration_rate_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.enhanced_min_respiration_rate = u16::MAX;
return self;
}
self.enhanced_min_respiration_rate = unscaled as u16;
self
}
pub fn total_fractional_ascent_scaled(&self) -> f64 {
if self.total_fractional_ascent == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.total_fractional_ascent as f64 / 100.0 - 0.0
}
pub fn set_total_fractional_ascent_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.total_fractional_ascent = u8::MAX;
return self;
}
self.total_fractional_ascent = unscaled as u8;
self
}
pub fn total_fractional_descent_scaled(&self) -> f64 {
if self.total_fractional_descent == u8::MAX {
return f64::from_bits(u64::MAX);
}
self.total_fractional_descent as f64 / 100.0 - 0.0
}
pub fn set_total_fractional_descent_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u8::MAX as f64 {
self.total_fractional_descent = u8::MAX;
return self;
}
self.total_fractional_descent = unscaled as u8;
self
}
pub fn avg_core_temperature_scaled(&self) -> f64 {
if self.avg_core_temperature == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.avg_core_temperature as f64 / 100.0 - 0.0
}
pub fn set_avg_core_temperature_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.avg_core_temperature = u16::MAX;
return self;
}
self.avg_core_temperature = unscaled as u16;
self
}
pub fn min_core_temperature_scaled(&self) -> f64 {
if self.min_core_temperature == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.min_core_temperature as f64 / 100.0 - 0.0
}
pub fn set_min_core_temperature_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.min_core_temperature = u16::MAX;
return self;
}
self.min_core_temperature = unscaled as u16;
self
}
pub fn max_core_temperature_scaled(&self) -> f64 {
if self.max_core_temperature == u16::MAX {
return f64::from_bits(u64::MAX);
}
self.max_core_temperature as f64 / 100.0 - 0.0
}
pub fn set_max_core_temperature_scaled(&mut self, v: f64) -> &mut Session {
let unscaled = (v + 0.0) * 100.0;
if unscaled.is_nan() || unscaled.is_infinite() || unscaled > u16::MAX as f64 {
self.max_core_temperature = u16::MAX;
return self;
}
self.max_core_temperature = unscaled as u16;
self
}
pub fn mark_as_expanded(&mut self, num: u8, flag: bool) -> bool {
match num {
124 | 125 | 126 | 127 | 128 | 169 | 170 | 180 => {
if flag {
self.state[num as usize >> 3] |= 1 << (num & 7)
} else {
self.state[num as usize >> 3] &= !(1 << (num & 7))
}
true
}
_ => false,
}
}
pub fn is_expanded(&self, num: u8) -> bool {
is_expanded(&self.state, num)
}
}
impl Default for Session {
fn default() -> Self {
Self::new()
}
}
impl From<&Message> for Session {
fn from(mesg: &Message) -> Self {
let mut vals: [&Value; 255] = [const { &Value::Invalid }; 255];
let mut state = [0u8; 23];
const KNOWN_NUMS: [u64; 4] = [
18446742974197919743,
18446678103011623167,
932252819858127487,
6917529027641541119,
];
let mut n = 0u64;
for field in &mesg.fields {
n += (KNOWN_NUMS[field.num as usize >> 6] >> (field.num & 63)) & 1 ^ 1
}
let mut unknown_fields: Vec<Field> = Vec::with_capacity(n as usize);
for field in &mesg.fields {
if (KNOWN_NUMS[field.num as usize >> 6] >> (field.num & 63)) & 1 == 0 {
unknown_fields.push(field.clone());
continue;
}
if field.is_expanded && field.num < 181 {
state[field.num as usize >> 3] |= 1 << (field.num & 7)
}
vals[field.num as usize] = &field.value;
}
Self {
message_index: typedef::MessageIndex(vals[254].as_u16()),
timestamp: typedef::DateTime(vals[253].as_u32()),
event: typedef::Event(vals[0].as_u8()),
event_type: typedef::EventType(vals[1].as_u8()),
start_time: typedef::DateTime(vals[2].as_u32()),
start_position_lat: vals[3].as_i32(),
start_position_long: vals[4].as_i32(),
sport: typedef::Sport(vals[5].as_u8()),
sub_sport: typedef::SubSport(vals[6].as_u8()),
total_elapsed_time: vals[7].as_u32(),
total_timer_time: vals[8].as_u32(),
total_distance: vals[9].as_u32(),
total_cycles: vals[10].as_u32(),
total_calories: vals[11].as_u16(),
total_fat_calories: vals[13].as_u16(),
avg_speed: vals[14].as_u16(),
max_speed: vals[15].as_u16(),
avg_heart_rate: vals[16].as_u8(),
max_heart_rate: vals[17].as_u8(),
avg_cadence: vals[18].as_u8(),
max_cadence: vals[19].as_u8(),
avg_power: vals[20].as_u16(),
max_power: vals[21].as_u16(),
total_ascent: vals[22].as_u16(),
total_descent: vals[23].as_u16(),
total_training_effect: vals[24].as_u8(),
first_lap_index: vals[25].as_u16(),
num_laps: vals[26].as_u16(),
event_group: vals[27].as_u8(),
trigger: typedef::SessionTrigger(vals[28].as_u8()),
nec_lat: vals[29].as_i32(),
nec_long: vals[30].as_i32(),
swc_lat: vals[31].as_i32(),
swc_long: vals[32].as_i32(),
num_lengths: vals[33].as_u16(),
normalized_power: vals[34].as_u16(),
training_stress_score: vals[35].as_u16(),
intensity_factor: vals[36].as_u16(),
left_right_balance: typedef::LeftRightBalance100(vals[37].as_u16()),
end_position_lat: vals[38].as_i32(),
end_position_long: vals[39].as_i32(),
avg_stroke_count: vals[41].as_u32(),
avg_stroke_distance: vals[42].as_u16(),
swim_stroke: typedef::SwimStroke(vals[43].as_u8()),
pool_length: vals[44].as_u16(),
threshold_power: vals[45].as_u16(),
pool_length_unit: typedef::DisplayMeasure(vals[46].as_u8()),
num_active_lengths: vals[47].as_u16(),
total_work: vals[48].as_u32(),
avg_altitude: vals[49].as_u16(),
max_altitude: vals[50].as_u16(),
gps_accuracy: vals[51].as_u8(),
avg_grade: vals[52].as_i16(),
avg_pos_grade: vals[53].as_i16(),
avg_neg_grade: vals[54].as_i16(),
max_pos_grade: vals[55].as_i16(),
max_neg_grade: vals[56].as_i16(),
avg_temperature: vals[57].as_i8(),
max_temperature: vals[58].as_i8(),
total_moving_time: vals[59].as_u32(),
avg_pos_vertical_speed: vals[60].as_i16(),
avg_neg_vertical_speed: vals[61].as_i16(),
max_pos_vertical_speed: vals[62].as_i16(),
max_neg_vertical_speed: vals[63].as_i16(),
min_heart_rate: vals[64].as_u8(),
time_in_hr_zone: vals[65].as_vec_u32(),
time_in_speed_zone: vals[66].as_vec_u32(),
time_in_cadence_zone: vals[67].as_vec_u32(),
time_in_power_zone: vals[68].as_vec_u32(),
avg_lap_time: vals[69].as_u32(),
best_lap_index: vals[70].as_u16(),
min_altitude: vals[71].as_u16(),
player_score: vals[82].as_u16(),
opponent_score: vals[83].as_u16(),
opponent_name: vals[84].as_string(),
stroke_count: vals[85].as_vec_u16(),
zone_count: vals[86].as_vec_u16(),
max_ball_speed: vals[87].as_u16(),
avg_ball_speed: vals[88].as_u16(),
avg_vertical_oscillation: vals[89].as_u16(),
avg_stance_time_percent: vals[90].as_u16(),
avg_stance_time: vals[91].as_u16(),
avg_fractional_cadence: vals[92].as_u8(),
max_fractional_cadence: vals[93].as_u8(),
total_fractional_cycles: vals[94].as_u8(),
avg_total_hemoglobin_conc: vals[95].as_vec_u16(),
min_total_hemoglobin_conc: vals[96].as_vec_u16(),
max_total_hemoglobin_conc: vals[97].as_vec_u16(),
avg_saturated_hemoglobin_percent: vals[98].as_vec_u16(),
min_saturated_hemoglobin_percent: vals[99].as_vec_u16(),
max_saturated_hemoglobin_percent: vals[100].as_vec_u16(),
avg_left_torque_effectiveness: vals[101].as_u8(),
avg_right_torque_effectiveness: vals[102].as_u8(),
avg_left_pedal_smoothness: vals[103].as_u8(),
avg_right_pedal_smoothness: vals[104].as_u8(),
avg_combined_pedal_smoothness: vals[105].as_u8(),
sport_profile_name: vals[110].as_string(),
sport_index: vals[111].as_u8(),
time_standing: vals[112].as_u32(),
stand_count: vals[113].as_u16(),
avg_left_pco: vals[114].as_i8(),
avg_right_pco: vals[115].as_i8(),
avg_left_power_phase: vals[116].as_vec_u8(),
avg_left_power_phase_peak: vals[117].as_vec_u8(),
avg_right_power_phase: vals[118].as_vec_u8(),
avg_right_power_phase_peak: vals[119].as_vec_u8(),
avg_power_position: vals[120].as_vec_u16(),
max_power_position: vals[121].as_vec_u16(),
avg_cadence_position: vals[122].as_vec_u8(),
max_cadence_position: vals[123].as_vec_u8(),
enhanced_avg_speed: vals[124].as_u32(),
enhanced_max_speed: vals[125].as_u32(),
enhanced_avg_altitude: vals[126].as_u32(),
enhanced_min_altitude: vals[127].as_u32(),
enhanced_max_altitude: vals[128].as_u32(),
avg_lev_motor_power: vals[129].as_u16(),
max_lev_motor_power: vals[130].as_u16(),
lev_battery_consumption: vals[131].as_u8(),
avg_vertical_ratio: vals[132].as_u16(),
avg_stance_time_balance: vals[133].as_u16(),
avg_step_length: vals[134].as_u16(),
total_anaerobic_training_effect: vals[137].as_u8(),
avg_vam: vals[139].as_u16(),
avg_depth: vals[140].as_u32(),
max_depth: vals[141].as_u32(),
surface_interval: vals[142].as_u32(),
start_cns: vals[143].as_u8(),
end_cns: vals[144].as_u8(),
start_n2: vals[145].as_u16(),
end_n2: vals[146].as_u16(),
avg_respiration_rate: vals[147].as_u8(),
max_respiration_rate: vals[148].as_u8(),
min_respiration_rate: vals[149].as_u8(),
min_temperature: vals[150].as_i8(),
o2_toxicity: vals[155].as_u16(),
dive_number: vals[156].as_u32(),
training_load_peak: vals[168].as_i32(),
enhanced_avg_respiration_rate: vals[169].as_u16(),
enhanced_max_respiration_rate: vals[170].as_u16(),
enhanced_min_respiration_rate: vals[180].as_u16(),
total_grit: vals[181].as_f32(),
total_flow: vals[182].as_f32(),
jump_count: vals[183].as_u16(),
avg_grit: vals[186].as_f32(),
avg_flow: vals[187].as_f32(),
workout_feel: vals[192].as_u8(),
workout_rpe: vals[193].as_u8(),
avg_spo2: vals[194].as_u8(),
avg_stress: vals[195].as_u8(),
metabolic_calories: vals[196].as_u16(),
sdrr_hrv: vals[197].as_u8(),
rmssd_hrv: vals[198].as_u8(),
total_fractional_ascent: vals[199].as_u8(),
total_fractional_descent: vals[200].as_u8(),
avg_core_temperature: vals[208].as_u16(),
min_core_temperature: vals[209].as_u16(),
max_core_temperature: vals[210].as_u16(),
state,
unknown_fields,
developer_fields: mesg.developer_fields.clone(),
}
}
}
impl From<Session> for Message {
fn from(m: Session) -> Self {
let mut arr = [const {
Field {
num: 0,
profile_type: ProfileType(0),
value: Value::Invalid,
is_expanded: false,
}
}; 157];
let mut len = 0usize;
let state = m.state;
if m.message_index != typedef::MessageIndex(u16::MAX) {
arr[len] = Field {
num: 254,
profile_type: ProfileType::MESSAGE_INDEX,
value: Value::Uint16(m.message_index.0),
is_expanded: false,
};
len += 1;
}
if m.timestamp != typedef::DateTime(u32::MAX) {
arr[len] = Field {
num: 253,
profile_type: ProfileType::DATE_TIME,
value: Value::Uint32(m.timestamp.0),
is_expanded: false,
};
len += 1;
}
if m.event != typedef::Event(u8::MAX) {
arr[len] = Field {
num: 0,
profile_type: ProfileType::EVENT,
value: Value::Uint8(m.event.0),
is_expanded: false,
};
len += 1;
}
if m.event_type != typedef::EventType(u8::MAX) {
arr[len] = Field {
num: 1,
profile_type: ProfileType::EVENT_TYPE,
value: Value::Uint8(m.event_type.0),
is_expanded: false,
};
len += 1;
}
if m.start_time != typedef::DateTime(u32::MAX) {
arr[len] = Field {
num: 2,
profile_type: ProfileType::DATE_TIME,
value: Value::Uint32(m.start_time.0),
is_expanded: false,
};
len += 1;
}
if m.start_position_lat != i32::MAX {
arr[len] = Field {
num: 3,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.start_position_lat),
is_expanded: false,
};
len += 1;
}
if m.start_position_long != i32::MAX {
arr[len] = Field {
num: 4,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.start_position_long),
is_expanded: false,
};
len += 1;
}
if m.sport != typedef::Sport(u8::MAX) {
arr[len] = Field {
num: 5,
profile_type: ProfileType::SPORT,
value: Value::Uint8(m.sport.0),
is_expanded: false,
};
len += 1;
}
if m.sub_sport != typedef::SubSport(u8::MAX) {
arr[len] = Field {
num: 6,
profile_type: ProfileType::SUB_SPORT,
value: Value::Uint8(m.sub_sport.0),
is_expanded: false,
};
len += 1;
}
if m.total_elapsed_time != u32::MAX {
arr[len] = Field {
num: 7,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.total_elapsed_time),
is_expanded: false,
};
len += 1;
}
if m.total_timer_time != u32::MAX {
arr[len] = Field {
num: 8,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.total_timer_time),
is_expanded: false,
};
len += 1;
}
if m.total_distance != u32::MAX {
arr[len] = Field {
num: 9,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.total_distance),
is_expanded: false,
};
len += 1;
}
if m.total_cycles != u32::MAX {
arr[len] = Field {
num: 10,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.total_cycles),
is_expanded: false,
};
len += 1;
}
if m.total_calories != u16::MAX {
arr[len] = Field {
num: 11,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.total_calories),
is_expanded: false,
};
len += 1;
}
if m.total_fat_calories != u16::MAX {
arr[len] = Field {
num: 13,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.total_fat_calories),
is_expanded: false,
};
len += 1;
}
if m.avg_speed != u16::MAX {
arr[len] = Field {
num: 14,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_speed),
is_expanded: false,
};
len += 1;
}
if m.max_speed != u16::MAX {
arr[len] = Field {
num: 15,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.max_speed),
is_expanded: false,
};
len += 1;
}
if m.avg_heart_rate != u8::MAX {
arr[len] = Field {
num: 16,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_heart_rate),
is_expanded: false,
};
len += 1;
}
if m.max_heart_rate != u8::MAX {
arr[len] = Field {
num: 17,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.max_heart_rate),
is_expanded: false,
};
len += 1;
}
if m.avg_cadence != u8::MAX {
arr[len] = Field {
num: 18,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_cadence),
is_expanded: false,
};
len += 1;
}
if m.max_cadence != u8::MAX {
arr[len] = Field {
num: 19,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.max_cadence),
is_expanded: false,
};
len += 1;
}
if m.avg_power != u16::MAX {
arr[len] = Field {
num: 20,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_power),
is_expanded: false,
};
len += 1;
}
if m.max_power != u16::MAX {
arr[len] = Field {
num: 21,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.max_power),
is_expanded: false,
};
len += 1;
}
if m.total_ascent != u16::MAX {
arr[len] = Field {
num: 22,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.total_ascent),
is_expanded: false,
};
len += 1;
}
if m.total_descent != u16::MAX {
arr[len] = Field {
num: 23,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.total_descent),
is_expanded: false,
};
len += 1;
}
if m.total_training_effect != u8::MAX {
arr[len] = Field {
num: 24,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.total_training_effect),
is_expanded: false,
};
len += 1;
}
if m.first_lap_index != u16::MAX {
arr[len] = Field {
num: 25,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.first_lap_index),
is_expanded: false,
};
len += 1;
}
if m.num_laps != u16::MAX {
arr[len] = Field {
num: 26,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.num_laps),
is_expanded: false,
};
len += 1;
}
if m.event_group != u8::MAX {
arr[len] = Field {
num: 27,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.event_group),
is_expanded: false,
};
len += 1;
}
if m.trigger != typedef::SessionTrigger(u8::MAX) {
arr[len] = Field {
num: 28,
profile_type: ProfileType::SESSION_TRIGGER,
value: Value::Uint8(m.trigger.0),
is_expanded: false,
};
len += 1;
}
if m.nec_lat != i32::MAX {
arr[len] = Field {
num: 29,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.nec_lat),
is_expanded: false,
};
len += 1;
}
if m.nec_long != i32::MAX {
arr[len] = Field {
num: 30,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.nec_long),
is_expanded: false,
};
len += 1;
}
if m.swc_lat != i32::MAX {
arr[len] = Field {
num: 31,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.swc_lat),
is_expanded: false,
};
len += 1;
}
if m.swc_long != i32::MAX {
arr[len] = Field {
num: 32,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.swc_long),
is_expanded: false,
};
len += 1;
}
if m.num_lengths != u16::MAX {
arr[len] = Field {
num: 33,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.num_lengths),
is_expanded: false,
};
len += 1;
}
if m.normalized_power != u16::MAX {
arr[len] = Field {
num: 34,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.normalized_power),
is_expanded: false,
};
len += 1;
}
if m.training_stress_score != u16::MAX {
arr[len] = Field {
num: 35,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.training_stress_score),
is_expanded: false,
};
len += 1;
}
if m.intensity_factor != u16::MAX {
arr[len] = Field {
num: 36,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.intensity_factor),
is_expanded: false,
};
len += 1;
}
if m.left_right_balance != typedef::LeftRightBalance100(u16::MAX) {
arr[len] = Field {
num: 37,
profile_type: ProfileType::LEFT_RIGHT_BALANCE_100,
value: Value::Uint16(m.left_right_balance.0),
is_expanded: false,
};
len += 1;
}
if m.end_position_lat != i32::MAX {
arr[len] = Field {
num: 38,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.end_position_lat),
is_expanded: false,
};
len += 1;
}
if m.end_position_long != i32::MAX {
arr[len] = Field {
num: 39,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.end_position_long),
is_expanded: false,
};
len += 1;
}
if m.avg_stroke_count != u32::MAX {
arr[len] = Field {
num: 41,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.avg_stroke_count),
is_expanded: false,
};
len += 1;
}
if m.avg_stroke_distance != u16::MAX {
arr[len] = Field {
num: 42,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_stroke_distance),
is_expanded: false,
};
len += 1;
}
if m.swim_stroke != typedef::SwimStroke(u8::MAX) {
arr[len] = Field {
num: 43,
profile_type: ProfileType::SWIM_STROKE,
value: Value::Uint8(m.swim_stroke.0),
is_expanded: false,
};
len += 1;
}
if m.pool_length != u16::MAX {
arr[len] = Field {
num: 44,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.pool_length),
is_expanded: false,
};
len += 1;
}
if m.threshold_power != u16::MAX {
arr[len] = Field {
num: 45,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.threshold_power),
is_expanded: false,
};
len += 1;
}
if m.pool_length_unit != typedef::DisplayMeasure(u8::MAX) {
arr[len] = Field {
num: 46,
profile_type: ProfileType::DISPLAY_MEASURE,
value: Value::Uint8(m.pool_length_unit.0),
is_expanded: false,
};
len += 1;
}
if m.num_active_lengths != u16::MAX {
arr[len] = Field {
num: 47,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.num_active_lengths),
is_expanded: false,
};
len += 1;
}
if m.total_work != u32::MAX {
arr[len] = Field {
num: 48,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.total_work),
is_expanded: false,
};
len += 1;
}
if m.avg_altitude != u16::MAX {
arr[len] = Field {
num: 49,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_altitude),
is_expanded: false,
};
len += 1;
}
if m.max_altitude != u16::MAX {
arr[len] = Field {
num: 50,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.max_altitude),
is_expanded: false,
};
len += 1;
}
if m.gps_accuracy != u8::MAX {
arr[len] = Field {
num: 51,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.gps_accuracy),
is_expanded: false,
};
len += 1;
}
if m.avg_grade != i16::MAX {
arr[len] = Field {
num: 52,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.avg_grade),
is_expanded: false,
};
len += 1;
}
if m.avg_pos_grade != i16::MAX {
arr[len] = Field {
num: 53,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.avg_pos_grade),
is_expanded: false,
};
len += 1;
}
if m.avg_neg_grade != i16::MAX {
arr[len] = Field {
num: 54,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.avg_neg_grade),
is_expanded: false,
};
len += 1;
}
if m.max_pos_grade != i16::MAX {
arr[len] = Field {
num: 55,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.max_pos_grade),
is_expanded: false,
};
len += 1;
}
if m.max_neg_grade != i16::MAX {
arr[len] = Field {
num: 56,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.max_neg_grade),
is_expanded: false,
};
len += 1;
}
if m.avg_temperature != i8::MAX {
arr[len] = Field {
num: 57,
profile_type: ProfileType::SINT8,
value: Value::Int8(m.avg_temperature),
is_expanded: false,
};
len += 1;
}
if m.max_temperature != i8::MAX {
arr[len] = Field {
num: 58,
profile_type: ProfileType::SINT8,
value: Value::Int8(m.max_temperature),
is_expanded: false,
};
len += 1;
}
if m.total_moving_time != u32::MAX {
arr[len] = Field {
num: 59,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.total_moving_time),
is_expanded: false,
};
len += 1;
}
if m.avg_pos_vertical_speed != i16::MAX {
arr[len] = Field {
num: 60,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.avg_pos_vertical_speed),
is_expanded: false,
};
len += 1;
}
if m.avg_neg_vertical_speed != i16::MAX {
arr[len] = Field {
num: 61,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.avg_neg_vertical_speed),
is_expanded: false,
};
len += 1;
}
if m.max_pos_vertical_speed != i16::MAX {
arr[len] = Field {
num: 62,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.max_pos_vertical_speed),
is_expanded: false,
};
len += 1;
}
if m.max_neg_vertical_speed != i16::MAX {
arr[len] = Field {
num: 63,
profile_type: ProfileType::SINT16,
value: Value::Int16(m.max_neg_vertical_speed),
is_expanded: false,
};
len += 1;
}
if m.min_heart_rate != u8::MAX {
arr[len] = Field {
num: 64,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.min_heart_rate),
is_expanded: false,
};
len += 1;
}
if m.time_in_hr_zone != Vec::<u32>::new() {
arr[len] = Field {
num: 65,
profile_type: ProfileType::UINT32,
value: Value::VecUint32(m.time_in_hr_zone),
is_expanded: false,
};
len += 1;
}
if m.time_in_speed_zone != Vec::<u32>::new() {
arr[len] = Field {
num: 66,
profile_type: ProfileType::UINT32,
value: Value::VecUint32(m.time_in_speed_zone),
is_expanded: false,
};
len += 1;
}
if m.time_in_cadence_zone != Vec::<u32>::new() {
arr[len] = Field {
num: 67,
profile_type: ProfileType::UINT32,
value: Value::VecUint32(m.time_in_cadence_zone),
is_expanded: false,
};
len += 1;
}
if m.time_in_power_zone != Vec::<u32>::new() {
arr[len] = Field {
num: 68,
profile_type: ProfileType::UINT32,
value: Value::VecUint32(m.time_in_power_zone),
is_expanded: false,
};
len += 1;
}
if m.avg_lap_time != u32::MAX {
arr[len] = Field {
num: 69,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.avg_lap_time),
is_expanded: false,
};
len += 1;
}
if m.best_lap_index != u16::MAX {
arr[len] = Field {
num: 70,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.best_lap_index),
is_expanded: false,
};
len += 1;
}
if m.min_altitude != u16::MAX {
arr[len] = Field {
num: 71,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.min_altitude),
is_expanded: false,
};
len += 1;
}
if m.player_score != u16::MAX {
arr[len] = Field {
num: 82,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.player_score),
is_expanded: false,
};
len += 1;
}
if m.opponent_score != u16::MAX {
arr[len] = Field {
num: 83,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.opponent_score),
is_expanded: false,
};
len += 1;
}
if m.opponent_name != String::new() {
arr[len] = Field {
num: 84,
profile_type: ProfileType::STRING,
value: Value::String(m.opponent_name),
is_expanded: false,
};
len += 1;
}
if m.stroke_count != Vec::<u16>::new() {
arr[len] = Field {
num: 85,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.stroke_count),
is_expanded: false,
};
len += 1;
}
if m.zone_count != Vec::<u16>::new() {
arr[len] = Field {
num: 86,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.zone_count),
is_expanded: false,
};
len += 1;
}
if m.max_ball_speed != u16::MAX {
arr[len] = Field {
num: 87,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.max_ball_speed),
is_expanded: false,
};
len += 1;
}
if m.avg_ball_speed != u16::MAX {
arr[len] = Field {
num: 88,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_ball_speed),
is_expanded: false,
};
len += 1;
}
if m.avg_vertical_oscillation != u16::MAX {
arr[len] = Field {
num: 89,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_vertical_oscillation),
is_expanded: false,
};
len += 1;
}
if m.avg_stance_time_percent != u16::MAX {
arr[len] = Field {
num: 90,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_stance_time_percent),
is_expanded: false,
};
len += 1;
}
if m.avg_stance_time != u16::MAX {
arr[len] = Field {
num: 91,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_stance_time),
is_expanded: false,
};
len += 1;
}
if m.avg_fractional_cadence != u8::MAX {
arr[len] = Field {
num: 92,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_fractional_cadence),
is_expanded: false,
};
len += 1;
}
if m.max_fractional_cadence != u8::MAX {
arr[len] = Field {
num: 93,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.max_fractional_cadence),
is_expanded: false,
};
len += 1;
}
if m.total_fractional_cycles != u8::MAX {
arr[len] = Field {
num: 94,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.total_fractional_cycles),
is_expanded: false,
};
len += 1;
}
if m.avg_total_hemoglobin_conc != Vec::<u16>::new() {
arr[len] = Field {
num: 95,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.avg_total_hemoglobin_conc),
is_expanded: false,
};
len += 1;
}
if m.min_total_hemoglobin_conc != Vec::<u16>::new() {
arr[len] = Field {
num: 96,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.min_total_hemoglobin_conc),
is_expanded: false,
};
len += 1;
}
if m.max_total_hemoglobin_conc != Vec::<u16>::new() {
arr[len] = Field {
num: 97,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.max_total_hemoglobin_conc),
is_expanded: false,
};
len += 1;
}
if m.avg_saturated_hemoglobin_percent != Vec::<u16>::new() {
arr[len] = Field {
num: 98,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.avg_saturated_hemoglobin_percent),
is_expanded: false,
};
len += 1;
}
if m.min_saturated_hemoglobin_percent != Vec::<u16>::new() {
arr[len] = Field {
num: 99,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.min_saturated_hemoglobin_percent),
is_expanded: false,
};
len += 1;
}
if m.max_saturated_hemoglobin_percent != Vec::<u16>::new() {
arr[len] = Field {
num: 100,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.max_saturated_hemoglobin_percent),
is_expanded: false,
};
len += 1;
}
if m.avg_left_torque_effectiveness != u8::MAX {
arr[len] = Field {
num: 101,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_left_torque_effectiveness),
is_expanded: false,
};
len += 1;
}
if m.avg_right_torque_effectiveness != u8::MAX {
arr[len] = Field {
num: 102,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_right_torque_effectiveness),
is_expanded: false,
};
len += 1;
}
if m.avg_left_pedal_smoothness != u8::MAX {
arr[len] = Field {
num: 103,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_left_pedal_smoothness),
is_expanded: false,
};
len += 1;
}
if m.avg_right_pedal_smoothness != u8::MAX {
arr[len] = Field {
num: 104,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_right_pedal_smoothness),
is_expanded: false,
};
len += 1;
}
if m.avg_combined_pedal_smoothness != u8::MAX {
arr[len] = Field {
num: 105,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_combined_pedal_smoothness),
is_expanded: false,
};
len += 1;
}
if m.sport_profile_name != String::new() {
arr[len] = Field {
num: 110,
profile_type: ProfileType::STRING,
value: Value::String(m.sport_profile_name),
is_expanded: false,
};
len += 1;
}
if m.sport_index != u8::MAX {
arr[len] = Field {
num: 111,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.sport_index),
is_expanded: false,
};
len += 1;
}
if m.time_standing != u32::MAX {
arr[len] = Field {
num: 112,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.time_standing),
is_expanded: false,
};
len += 1;
}
if m.stand_count != u16::MAX {
arr[len] = Field {
num: 113,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.stand_count),
is_expanded: false,
};
len += 1;
}
if m.avg_left_pco != i8::MAX {
arr[len] = Field {
num: 114,
profile_type: ProfileType::SINT8,
value: Value::Int8(m.avg_left_pco),
is_expanded: false,
};
len += 1;
}
if m.avg_right_pco != i8::MAX {
arr[len] = Field {
num: 115,
profile_type: ProfileType::SINT8,
value: Value::Int8(m.avg_right_pco),
is_expanded: false,
};
len += 1;
}
if m.avg_left_power_phase != Vec::<u8>::new() {
arr[len] = Field {
num: 116,
profile_type: ProfileType::UINT8,
value: Value::VecUint8(m.avg_left_power_phase),
is_expanded: false,
};
len += 1;
}
if m.avg_left_power_phase_peak != Vec::<u8>::new() {
arr[len] = Field {
num: 117,
profile_type: ProfileType::UINT8,
value: Value::VecUint8(m.avg_left_power_phase_peak),
is_expanded: false,
};
len += 1;
}
if m.avg_right_power_phase != Vec::<u8>::new() {
arr[len] = Field {
num: 118,
profile_type: ProfileType::UINT8,
value: Value::VecUint8(m.avg_right_power_phase),
is_expanded: false,
};
len += 1;
}
if m.avg_right_power_phase_peak != Vec::<u8>::new() {
arr[len] = Field {
num: 119,
profile_type: ProfileType::UINT8,
value: Value::VecUint8(m.avg_right_power_phase_peak),
is_expanded: false,
};
len += 1;
}
if m.avg_power_position != Vec::<u16>::new() {
arr[len] = Field {
num: 120,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.avg_power_position),
is_expanded: false,
};
len += 1;
}
if m.max_power_position != Vec::<u16>::new() {
arr[len] = Field {
num: 121,
profile_type: ProfileType::UINT16,
value: Value::VecUint16(m.max_power_position),
is_expanded: false,
};
len += 1;
}
if m.avg_cadence_position != Vec::<u8>::new() {
arr[len] = Field {
num: 122,
profile_type: ProfileType::UINT8,
value: Value::VecUint8(m.avg_cadence_position),
is_expanded: false,
};
len += 1;
}
if m.max_cadence_position != Vec::<u8>::new() {
arr[len] = Field {
num: 123,
profile_type: ProfileType::UINT8,
value: Value::VecUint8(m.max_cadence_position),
is_expanded: false,
};
len += 1;
}
if m.enhanced_avg_speed != u32::MAX {
arr[len] = Field {
num: 124,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.enhanced_avg_speed),
is_expanded: is_expanded(&state, 124),
};
len += 1;
}
if m.enhanced_max_speed != u32::MAX {
arr[len] = Field {
num: 125,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.enhanced_max_speed),
is_expanded: is_expanded(&state, 125),
};
len += 1;
}
if m.enhanced_avg_altitude != u32::MAX {
arr[len] = Field {
num: 126,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.enhanced_avg_altitude),
is_expanded: is_expanded(&state, 126),
};
len += 1;
}
if m.enhanced_min_altitude != u32::MAX {
arr[len] = Field {
num: 127,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.enhanced_min_altitude),
is_expanded: is_expanded(&state, 127),
};
len += 1;
}
if m.enhanced_max_altitude != u32::MAX {
arr[len] = Field {
num: 128,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.enhanced_max_altitude),
is_expanded: is_expanded(&state, 128),
};
len += 1;
}
if m.avg_lev_motor_power != u16::MAX {
arr[len] = Field {
num: 129,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_lev_motor_power),
is_expanded: false,
};
len += 1;
}
if m.max_lev_motor_power != u16::MAX {
arr[len] = Field {
num: 130,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.max_lev_motor_power),
is_expanded: false,
};
len += 1;
}
if m.lev_battery_consumption != u8::MAX {
arr[len] = Field {
num: 131,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.lev_battery_consumption),
is_expanded: false,
};
len += 1;
}
if m.avg_vertical_ratio != u16::MAX {
arr[len] = Field {
num: 132,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_vertical_ratio),
is_expanded: false,
};
len += 1;
}
if m.avg_stance_time_balance != u16::MAX {
arr[len] = Field {
num: 133,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_stance_time_balance),
is_expanded: false,
};
len += 1;
}
if m.avg_step_length != u16::MAX {
arr[len] = Field {
num: 134,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_step_length),
is_expanded: false,
};
len += 1;
}
if m.total_anaerobic_training_effect != u8::MAX {
arr[len] = Field {
num: 137,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.total_anaerobic_training_effect),
is_expanded: false,
};
len += 1;
}
if m.avg_vam != u16::MAX {
arr[len] = Field {
num: 139,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_vam),
is_expanded: false,
};
len += 1;
}
if m.avg_depth != u32::MAX {
arr[len] = Field {
num: 140,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.avg_depth),
is_expanded: false,
};
len += 1;
}
if m.max_depth != u32::MAX {
arr[len] = Field {
num: 141,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.max_depth),
is_expanded: false,
};
len += 1;
}
if m.surface_interval != u32::MAX {
arr[len] = Field {
num: 142,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.surface_interval),
is_expanded: false,
};
len += 1;
}
if m.start_cns != u8::MAX {
arr[len] = Field {
num: 143,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.start_cns),
is_expanded: false,
};
len += 1;
}
if m.end_cns != u8::MAX {
arr[len] = Field {
num: 144,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.end_cns),
is_expanded: false,
};
len += 1;
}
if m.start_n2 != u16::MAX {
arr[len] = Field {
num: 145,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.start_n2),
is_expanded: false,
};
len += 1;
}
if m.end_n2 != u16::MAX {
arr[len] = Field {
num: 146,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.end_n2),
is_expanded: false,
};
len += 1;
}
if m.avg_respiration_rate != u8::MAX {
arr[len] = Field {
num: 147,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_respiration_rate),
is_expanded: false,
};
len += 1;
}
if m.max_respiration_rate != u8::MAX {
arr[len] = Field {
num: 148,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.max_respiration_rate),
is_expanded: false,
};
len += 1;
}
if m.min_respiration_rate != u8::MAX {
arr[len] = Field {
num: 149,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.min_respiration_rate),
is_expanded: false,
};
len += 1;
}
if m.min_temperature != i8::MAX {
arr[len] = Field {
num: 150,
profile_type: ProfileType::SINT8,
value: Value::Int8(m.min_temperature),
is_expanded: false,
};
len += 1;
}
if m.o2_toxicity != u16::MAX {
arr[len] = Field {
num: 155,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.o2_toxicity),
is_expanded: false,
};
len += 1;
}
if m.dive_number != u32::MAX {
arr[len] = Field {
num: 156,
profile_type: ProfileType::UINT32,
value: Value::Uint32(m.dive_number),
is_expanded: false,
};
len += 1;
}
if m.training_load_peak != i32::MAX {
arr[len] = Field {
num: 168,
profile_type: ProfileType::SINT32,
value: Value::Int32(m.training_load_peak),
is_expanded: false,
};
len += 1;
}
if m.enhanced_avg_respiration_rate != u16::MAX {
arr[len] = Field {
num: 169,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.enhanced_avg_respiration_rate),
is_expanded: is_expanded(&state, 169),
};
len += 1;
}
if m.enhanced_max_respiration_rate != u16::MAX {
arr[len] = Field {
num: 170,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.enhanced_max_respiration_rate),
is_expanded: is_expanded(&state, 170),
};
len += 1;
}
if m.enhanced_min_respiration_rate != u16::MAX {
arr[len] = Field {
num: 180,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.enhanced_min_respiration_rate),
is_expanded: is_expanded(&state, 180),
};
len += 1;
}
if m.total_grit != f32::MAX {
arr[len] = Field {
num: 181,
profile_type: ProfileType::FLOAT32,
value: Value::Float32(m.total_grit),
is_expanded: false,
};
len += 1;
}
if m.total_flow != f32::MAX {
arr[len] = Field {
num: 182,
profile_type: ProfileType::FLOAT32,
value: Value::Float32(m.total_flow),
is_expanded: false,
};
len += 1;
}
if m.jump_count != u16::MAX {
arr[len] = Field {
num: 183,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.jump_count),
is_expanded: false,
};
len += 1;
}
if m.avg_grit != f32::MAX {
arr[len] = Field {
num: 186,
profile_type: ProfileType::FLOAT32,
value: Value::Float32(m.avg_grit),
is_expanded: false,
};
len += 1;
}
if m.avg_flow != f32::MAX {
arr[len] = Field {
num: 187,
profile_type: ProfileType::FLOAT32,
value: Value::Float32(m.avg_flow),
is_expanded: false,
};
len += 1;
}
if m.workout_feel != u8::MAX {
arr[len] = Field {
num: 192,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.workout_feel),
is_expanded: false,
};
len += 1;
}
if m.workout_rpe != u8::MAX {
arr[len] = Field {
num: 193,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.workout_rpe),
is_expanded: false,
};
len += 1;
}
if m.avg_spo2 != u8::MAX {
arr[len] = Field {
num: 194,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_spo2),
is_expanded: false,
};
len += 1;
}
if m.avg_stress != u8::MAX {
arr[len] = Field {
num: 195,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.avg_stress),
is_expanded: false,
};
len += 1;
}
if m.metabolic_calories != u16::MAX {
arr[len] = Field {
num: 196,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.metabolic_calories),
is_expanded: false,
};
len += 1;
}
if m.sdrr_hrv != u8::MAX {
arr[len] = Field {
num: 197,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.sdrr_hrv),
is_expanded: false,
};
len += 1;
}
if m.rmssd_hrv != u8::MAX {
arr[len] = Field {
num: 198,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.rmssd_hrv),
is_expanded: false,
};
len += 1;
}
if m.total_fractional_ascent != u8::MAX {
arr[len] = Field {
num: 199,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.total_fractional_ascent),
is_expanded: false,
};
len += 1;
}
if m.total_fractional_descent != u8::MAX {
arr[len] = Field {
num: 200,
profile_type: ProfileType::UINT8,
value: Value::Uint8(m.total_fractional_descent),
is_expanded: false,
};
len += 1;
}
if m.avg_core_temperature != u16::MAX {
arr[len] = Field {
num: 208,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.avg_core_temperature),
is_expanded: false,
};
len += 1;
}
if m.min_core_temperature != u16::MAX {
arr[len] = Field {
num: 209,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.min_core_temperature),
is_expanded: false,
};
len += 1;
}
if m.max_core_temperature != u16::MAX {
arr[len] = Field {
num: 210,
profile_type: ProfileType::UINT16,
value: Value::Uint16(m.max_core_temperature),
is_expanded: false,
};
len += 1;
}
Message {
header: 0,
num: typedef::MesgNum::SESSION,
fields: {
let mut fields: Vec<Field> = Vec::with_capacity(len + m.unknown_fields.len());
fields.extend_from_slice(&arr[..len]);
fields.extend_from_slice(&m.unknown_fields);
fields
},
developer_fields: m.developer_fields,
}
}
}