1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
use std::fmt::{Display, Formatter, Result};
use std::ops::{Add, Sub, AddAssign, SubAssign, Div, Mul, DivAssign, MulAssign};
use crate::metric::Unit;
use crate::metric::Primitive;
use crate::declare_unit_basics;
#[derive(Copy, Clone, Debug, PartialOrd, PartialEq)]
pub enum DoseEquivalent {
Base(f64, fn(f64) -> f64, &'static str),
Canonical(f64),
Sievert(f64),
Gray(f64),
}
impl Unit<DoseEquivalent> for DoseEquivalent {
fn to_si_unit(&self) -> DoseEquivalent {
match self {
DoseEquivalent::Base(_, _, _) => self.clone(),
DoseEquivalent::Canonical(value) => DoseEquivalent::Base(value.clone(), |x| x, "Sv"),
DoseEquivalent::Sievert(value) => DoseEquivalent::Base(value.clone(), |x| x, "Sv"),
DoseEquivalent::Gray(value) => DoseEquivalent::Base(value.clone(), |x| x, "Gy"),
}
}
}
declare_unit_basics!(DoseEquivalent);
pub type AbsorbedDose = DoseEquivalent;
|