pub struct Temperature(/* private fields */);Expand description
Represents a temperature value in degrees Celsius, as read from or written to the R4DCB08.
Valid addresses are in the range -3276.8 to 3276.7 (inclusive).
Use Temperature::try_from to create an instance from a f32.
Implementations§
Source§impl Temperature
impl Temperature
Sourcepub const NAN: Temperature
pub const NAN: Temperature
Represents a Not-a-Number temperature, often indicating a sensor error or disconnection.
Sourcepub const MIN: f32 = -3276.69995f32
pub const MIN: f32 = -3276.69995f32
Minimum measurable/representable temperature value (-3276.7 °C).
Sourcepub const MAX: f32 = 3276.69995f32
pub const MAX: f32 = 3276.69995f32
Maximum measurable/representable temperature value (+3276.7 °C).
Sourcepub fn decode_from_holding_registers(word: Word) -> Self
pub fn decode_from_holding_registers(word: Word) -> Self
Sourcepub fn encode_for_write_register(&self) -> Result<Word, Error>
pub fn encode_for_write_register(&self) -> Result<Word, Error>
Encodes the Temperature into a Word value for writing to a Modbus register.
§Returns
The Word representation of the temperature, ready for writing, or an Error if encoding fails.
§Errors
Error::EncodeError: if the temperature value isNAN.
Methods from Deref<Target = f32>§
pub const RADIX: u32 = 2u32
pub const MANTISSA_DIGITS: u32 = 24u32
pub const DIGITS: u32 = 6u32
pub const EPSILON: f32 = 1.1920929E-7f32
pub const MIN: f32 = -3.40282347E+38f32
pub const MIN_POSITIVE: f32 = 1.17549435E-38f32
pub const MAX: f32 = 3.40282347E+38f32
pub const MIN_EXP: i32 = -125i32
pub const MAX_EXP: i32 = 128i32
pub const MIN_10_EXP: i32 = -37i32
pub const MAX_10_EXP: i32 = 38i32
pub const NAN: f32 = NaN_f32
pub const INFINITY: f32 = +Inf_f32
pub const NEG_INFINITY: f32 = -Inf_f32
1.62.0 · Sourcepub fn total_cmp(&self, other: &f32) -> Ordering
pub fn total_cmp(&self, other: &f32) -> Ordering
Returns the ordering between self and other.
Unlike the standard partial comparison between floating point numbers,
this comparison always produces an ordering in accordance to
the totalOrder predicate as defined in the IEEE 754 (2008 revision)
floating point standard. The values are ordered in the following sequence:
- negative quiet NaN
- negative signaling NaN
- negative infinity
- negative numbers
- negative subnormal numbers
- negative zero
- positive zero
- positive subnormal numbers
- positive numbers
- positive infinity
- positive signaling NaN
- positive quiet NaN.
The ordering established by this function does not always agree with the
PartialOrd and PartialEq implementations of f32. For example,
they consider negative and positive zero equal, while total_cmp
doesn’t.
The interpretation of the signaling NaN bit follows the definition in the IEEE 754 standard, which may not match the interpretation by some of the older, non-conformant (e.g. MIPS) hardware implementations.
§Example
struct GoodBoy {
name: String,
weight: f32,
}
let mut bois = vec![
GoodBoy { name: "Pucci".to_owned(), weight: 0.1 },
GoodBoy { name: "Woofer".to_owned(), weight: 99.0 },
GoodBoy { name: "Yapper".to_owned(), weight: 10.0 },
GoodBoy { name: "Chonk".to_owned(), weight: f32::INFINITY },
GoodBoy { name: "Abs. Unit".to_owned(), weight: f32::NAN },
GoodBoy { name: "Floaty".to_owned(), weight: -5.0 },
];
bois.sort_by(|a, b| a.weight.total_cmp(&b.weight));
// `f32::NAN` could be positive or negative, which will affect the sort order.
if f32::NAN.is_sign_negative() {
assert!(bois.into_iter().map(|b| b.weight)
.zip([f32::NAN, -5.0, 0.1, 10.0, 99.0, f32::INFINITY].iter())
.all(|(a, b)| a.to_bits() == b.to_bits()))
} else {
assert!(bois.into_iter().map(|b| b.weight)
.zip([-5.0, 0.1, 10.0, 99.0, f32::INFINITY, f32::NAN].iter())
.all(|(a, b)| a.to_bits() == b.to_bits()))
}Trait Implementations§
Source§impl Clone for Temperature
impl Clone for Temperature
Source§fn clone(&self) -> Temperature
fn clone(&self) -> Temperature
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for Temperature
impl Debug for Temperature
Source§impl Deref for Temperature
Allows direct access to the underlying f32 temperature value.
impl Deref for Temperature
Allows direct access to the underlying f32 temperature value.
Source§impl<'de> Deserialize<'de> for Temperature
Available on crate feature serde only.
impl<'de> Deserialize<'de> for Temperature
serde only.Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
Source§impl Display for Temperature
impl Display for Temperature
Source§impl PartialEq for Temperature
impl PartialEq for Temperature
Source§impl PartialOrd for Temperature
impl PartialOrd for Temperature
Source§impl Serialize for Temperature
impl Serialize for Temperature
Source§impl TryFrom<f32> for Temperature
impl TryFrom<f32> for Temperature
Source§fn try_from(value: f32) -> Result<Self, Self::Error>
fn try_from(value: f32) -> Result<Self, Self::Error>
Attempts to create a Temperature from an f32 value.
Returns an error if the value is outside the representable range [MIN, MAX].
Note: This does not allow creating Temperature::NAN via try_from.
Use Temperature::NAN constant directly.