unitforge/quantities/
force_distance.rs

1use crate::impl_macros::macros::*;
2use crate::prelude::*;
3use crate::quantities::*;
4use ndarray::{Array1, Array2, ArrayView1, ArrayView2};
5use num_traits::identities::Zero;
6use num_traits::FromPrimitive;
7#[cfg(feature = "pyo3")]
8use pyo3::pyclass;
9#[cfg(feature = "serde")]
10use serde::{Deserialize, Serialize};
11use std::cmp::Ordering;
12use std::fmt;
13use std::ops::{Add, AddAssign, Div, DivAssign, Mul, MulAssign, Neg, Sub, SubAssign};
14#[cfg(feature = "strum")]
15use strum_macros::EnumIter;
16
17#[cfg_attr(feature = "strum", derive(EnumIter))]
18#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
19#[derive(Copy, Clone, PartialEq, Debug)]
20#[cfg_attr(feature = "pyo3", pyclass(eq, eq_int))]
21pub enum ForceDistanceUnit {
22    Nm,
23    Ndm,
24    Ncm,
25    Nmm,
26    kNm,
27    kNdm,
28    kNcm,
29    kNmm,
30    LbFt,
31    LbIn,
32    J,
33    eV,
34    keV,
35    MeV,
36    GeV,
37    TeV,
38}
39
40make_alias!(ForceDistance, ForceDistanceUnit, Moment, MomentUnit);
41make_alias!(ForceDistance, ForceDistanceUnit, Energy, EnergyUnit);
42
43impl PhysicsUnit for ForceDistanceUnit {
44    fn name(&self) -> &str {
45        match self {
46            ForceDistanceUnit::Nm => "Nm",
47            ForceDistanceUnit::Ndm => "Ndm",
48            ForceDistanceUnit::Ncm => "Ncm",
49            ForceDistanceUnit::Nmm => "Nmm",
50            ForceDistanceUnit::kNm => "kNm",
51            ForceDistanceUnit::kNdm => "kNdm",
52            ForceDistanceUnit::kNcm => "kNcm",
53            ForceDistanceUnit::kNmm => "kNmm",
54            ForceDistanceUnit::LbFt => "lb-ft",
55            ForceDistanceUnit::LbIn => "lb-in",
56            ForceDistanceUnit::J => "J",
57            ForceDistanceUnit::eV => "eV",
58            ForceDistanceUnit::keV => "keV",
59            ForceDistanceUnit::MeV => "MeV",
60            ForceDistanceUnit::GeV => "GeV",
61            ForceDistanceUnit::TeV => "TeV",
62        }
63    }
64
65    fn base_per_x(&self) -> (f64, i32) {
66        match self {
67            ForceDistanceUnit::Nmm => (1., -3),
68            ForceDistanceUnit::Ncm => (1., -2),
69            ForceDistanceUnit::Ndm => (1., -1),
70            ForceDistanceUnit::Nm => (1., 0),
71            ForceDistanceUnit::kNm => (1., 3),
72            ForceDistanceUnit::kNdm => (1., 2),
73            ForceDistanceUnit::kNcm => (1., 1),
74            ForceDistanceUnit::kNmm => (1., 0),
75            ForceDistanceUnit::LbFt => (1.35582, 0),
76            ForceDistanceUnit::LbIn => (1.12985, -1),
77            ForceDistanceUnit::J => (1.0, 0),
78            ForceDistanceUnit::eV => (Charge::e() * Voltage::new(1., VoltageUnit::V)).get_tuple(),
79            ForceDistanceUnit::keV => (Charge::e() * Voltage::new(1., VoltageUnit::kV)).get_tuple(),
80            ForceDistanceUnit::MeV => (Charge::e() * Voltage::new(1., VoltageUnit::MV)).get_tuple(),
81            ForceDistanceUnit::GeV => (Charge::e() * Voltage::new(1., VoltageUnit::GV)).get_tuple(),
82            ForceDistanceUnit::TeV => (Charge::e() * Voltage::new(1., VoltageUnit::TV)).get_tuple(),
83        }
84    }
85}
86
87impl_quantity!(
88    ForceDistance,
89    ForceDistanceUnit,
90    [ForceDistanceUnit::Nm, ForceDistanceUnit::J]
91);
92impl_div_with_self_to_f64!(ForceDistance);