From 3e4fb93a594f11a80904653396698d6c70e07cb0 Mon Sep 17 00:00:00 2001 From: Niklas Halle Date: Sat, 31 Oct 2020 20:44:44 +0100 Subject: Initial public release --- src/metric/absorbed_dose.rs | 10 +++++ src/metric/acceleration.rs | 10 +++++ src/metric/amount_of_substance.rs | 10 +++++ src/metric/area.rs | 28 ++++++++++++ src/metric/capacitance.rs | 10 +++++ src/metric/catalytic_activity.rs | 10 +++++ src/metric/conductance.rs | 39 ++++++++++++++++ src/metric/dose_equivalent.rs | 30 +++++++++++++ src/metric/electric_charge.rs | 10 +++++ src/metric/electric_current.rs | 10 +++++ src/metric/electric_potential.rs | 10 +++++ src/metric/electric_resistance.rs | 10 +++++ src/metric/energy.rs | 32 +++++++++++++ src/metric/force.rs | 10 +++++ src/metric/frequency.rs | 59 ++++++++++++++++++++++++ src/metric/illuminance.rs | 10 +++++ src/metric/inductance.rs | 10 +++++ src/metric/length.rs | 44 ++++++++++++++++++ src/metric/luminous_flux.rs | 10 +++++ src/metric/luminous_intensity.rs | 10 +++++ src/metric/magnetic_flux.rs | 10 +++++ src/metric/magnetic_flux_density.rs | 10 +++++ src/metric/mass.rs | 36 +++++++++++++++ src/metric/plane_angle.rs | 28 ++++++++++++ src/metric/power.rs | 10 +++++ src/metric/pressure.rs | 28 ++++++++++++ src/metric/solid_angle.rs | 10 +++++ src/metric/temperature.rs | 89 +++++++++++++++++++++++++++++++++++++ src/metric/time.rs | 36 +++++++++++++++ src/metric/velocity.rs | 10 +++++ src/metric/volume.rs | 32 +++++++++++++ 31 files changed, 671 insertions(+) create mode 100644 src/metric/absorbed_dose.rs create mode 100644 src/metric/acceleration.rs create mode 100644 src/metric/amount_of_substance.rs create mode 100644 src/metric/area.rs create mode 100644 src/metric/capacitance.rs create mode 100644 src/metric/catalytic_activity.rs create mode 100644 src/metric/conductance.rs create mode 100644 src/metric/dose_equivalent.rs create mode 100644 src/metric/electric_charge.rs create mode 100644 src/metric/electric_current.rs create mode 100644 src/metric/electric_potential.rs create mode 100644 src/metric/electric_resistance.rs create mode 100644 src/metric/energy.rs create mode 100644 src/metric/force.rs create mode 100644 src/metric/frequency.rs create mode 100644 src/metric/illuminance.rs create mode 100644 src/metric/inductance.rs create mode 100644 src/metric/length.rs create mode 100644 src/metric/luminous_flux.rs create mode 100644 src/metric/luminous_intensity.rs create mode 100644 src/metric/magnetic_flux.rs create mode 100644 src/metric/magnetic_flux_density.rs create mode 100644 src/metric/mass.rs create mode 100644 src/metric/plane_angle.rs create mode 100644 src/metric/power.rs create mode 100644 src/metric/pressure.rs create mode 100644 src/metric/solid_angle.rs create mode 100644 src/metric/temperature.rs create mode 100644 src/metric/time.rs create mode 100644 src/metric/velocity.rs create mode 100644 src/metric/volume.rs (limited to 'src/metric') diff --git a/src/metric/absorbed_dose.rs b/src/metric/absorbed_dose.rs new file mode 100644 index 0000000..41ef508 --- /dev/null +++ b/src/metric/absorbed_dose.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(AbsorbedDose, Gray, "Gy"); \ No newline at end of file diff --git a/src/metric/acceleration.rs b/src/metric/acceleration.rs new file mode 100644 index 0000000..3b3d50a --- /dev/null +++ b/src/metric/acceleration.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(Acceleration, Accel, "m/s²"); \ No newline at end of file diff --git a/src/metric/amount_of_substance.rs b/src/metric/amount_of_substance.rs new file mode 100644 index 0000000..34058c7 --- /dev/null +++ b/src/metric/amount_of_substance.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(AmountOfSubstance, Mole, "mol"); \ No newline at end of file diff --git a/src/metric/area.rs b/src/metric/area.rs new file mode 100644 index 0000000..eb2b0c3 --- /dev/null +++ b/src/metric/area.rs @@ -0,0 +1,28 @@ +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 Area { + Base(f64, fn(f64) -> f64, &'static str), + Canonical(f64), + SquareMeter(f64), + SquareMetre(f64), +} + +impl Unit for Area { + fn to_si_unit(&self) -> Area { + match self { + Area::Base(_, _, _) => self.clone(), + Area::Canonical(value) => Area::Base(value.clone(), |x| x, "m²"), + Area::SquareMeter(value) => Area::Base(value.clone(), |x| x, "m²"), + Area::SquareMetre(value) => Area::Base(value.clone(), |x| x, "m²"), + } + } +} + +declare_unit_basics!(Area); \ No newline at end of file diff --git a/src/metric/capacitance.rs b/src/metric/capacitance.rs new file mode 100644 index 0000000..a98c203 --- /dev/null +++ b/src/metric/capacitance.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(Capacitance, Farad, "F"); \ No newline at end of file diff --git a/src/metric/catalytic_activity.rs b/src/metric/catalytic_activity.rs new file mode 100644 index 0000000..710a87a --- /dev/null +++ b/src/metric/catalytic_activity.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(CatalyticActivity, Katal, "kat"); \ No newline at end of file diff --git a/src/metric/conductance.rs b/src/metric/conductance.rs new file mode 100644 index 0000000..29712e0 --- /dev/null +++ b/src/metric/conductance.rs @@ -0,0 +1,39 @@ +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; +use crate::declare_simple_unit; + +use crate::metric::electric_resistance::ElectricResistance; + +declare_simple_unit!(Conductance, Siemens, "S"); + +// 1/s = Hz +impl Div for f64 { + type Output = Conductance; + + fn div(self, rhs: ElectricResistance) -> Self::Output { + Conductance::Canonical(self * rhs.to_si_primitive()) + } +} + +// Hz * s = 1 +impl Mul for Conductance { + type Output = f64; + + fn mul(self, rhs: ElectricResistance) -> Self::Output { + self.to_si_primitive() * rhs.to_si_primitive() + } +} + +// s * Hz = 1 +impl Mul for ElectricResistance { + type Output = f64; + + fn mul(self, rhs: Conductance) -> Self::Output { + self.to_si_primitive() * rhs.to_si_primitive() + } +} \ No newline at end of file diff --git a/src/metric/dose_equivalent.rs b/src/metric/dose_equivalent.rs new file mode 100644 index 0000000..408c7de --- /dev/null +++ b/src/metric/dose_equivalent.rs @@ -0,0 +1,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 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; \ No newline at end of file diff --git a/src/metric/electric_charge.rs b/src/metric/electric_charge.rs new file mode 100644 index 0000000..9e6e970 --- /dev/null +++ b/src/metric/electric_charge.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(ElectricCharge, Coulomb, "C"); \ No newline at end of file diff --git a/src/metric/electric_current.rs b/src/metric/electric_current.rs new file mode 100644 index 0000000..376e426 --- /dev/null +++ b/src/metric/electric_current.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(ElectricCurrent, Ampere, "A"); \ No newline at end of file diff --git a/src/metric/electric_potential.rs b/src/metric/electric_potential.rs new file mode 100644 index 0000000..9fdbde8 --- /dev/null +++ b/src/metric/electric_potential.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(ElectricPotential, Volt, "V"); \ No newline at end of file diff --git a/src/metric/electric_resistance.rs b/src/metric/electric_resistance.rs new file mode 100644 index 0000000..3d3d9f8 --- /dev/null +++ b/src/metric/electric_resistance.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(ElectricResistance, Ohm, "Ω"); \ No newline at end of file diff --git a/src/metric/energy.rs b/src/metric/energy.rs new file mode 100644 index 0000000..5884a2f --- /dev/null +++ b/src/metric/energy.rs @@ -0,0 +1,32 @@ +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 Energy { + Base(f64, fn(f64) -> f64, &'static str), + Canonical(f64), + Joule(f64), + KiloJoule(f64), + Calorie(f64), + Kilocalorie(f64), +} + +impl Unit for Energy { + fn to_si_unit(&self) -> Energy { + match self { + Energy::Base(_, _, _) => self.clone(), + Energy::Canonical(value) => Energy::Base(value.clone(), |x| x, "J"), + Energy::Joule(value) => Energy::Base(value.clone(), |x| x, "J"), + Energy::KiloJoule(value) => Energy::Base(value * 1000.0, |x| x / 1000.0, "kJ"), + Energy::Calorie(value) => Energy::Base(value * 4.184, |x| x / 4.184, "cal"), + Energy::Kilocalorie(value) => Energy::Base(value * 4184.0, |x| x / 4184.0, "kcal"), + } + } +} + +declare_unit_basics!(Energy); \ No newline at end of file diff --git a/src/metric/force.rs b/src/metric/force.rs new file mode 100644 index 0000000..5011ce6 --- /dev/null +++ b/src/metric/force.rs @@ -0,0 +1,10 @@ +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; +use crate::declare_simple_unit; + +declare_simple_unit!(Force, Newton, "N"); \ No newline at end of file diff --git a/src/metric/frequency.rs b/src/metric/frequency.rs new file mode 100644 index 0000000..c35f874 --- /dev/null +++ b/src/metric/frequency.rs @@ -0,0 +1,59 @@ +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; + +use crate::metric::time::Time; + +#[derive(Copy, Clone, Debug, PartialOrd, PartialEq)] +pub enum Frequency { + Base(f64, fn(f64) -> f64, &'static str), + Canonical(f64), + Hertz(f64), + Becquerel(f64), +} + +impl Unit for Frequency { + fn to_si_unit(&self) -> Frequency { + match self { + Frequency::Base(_, _, _) => self.clone(), + Frequency::Canonical(value) => Frequency::Base(value.clone(), |x| x, "Hz"), + Frequency::Hertz(value) => Frequency::Base(value.clone(), |x| x, "Hz"), + Frequency::Becquerel(value) => Frequency::Base(value.clone(), |x| x, "Bq"), + } + } +} + +declare_unit_basics!(Frequency); + +// 1/s = Hz +impl Div