summaryrefslogtreecommitdiffstats
path: root/src/metric/dose_equivalent.rs
blob: 408c7deb080a9f38fe20a0248b712731eef99693 (plain) (blame)
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;