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
15#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
16#[derive(Copy, Clone, PartialEq, Debug)]
17#[cfg_attr(feature = "pyo3", pyclass(eq, eq_int))]
18pub enum ForceDistanceUnit {
19    Nm,
20    Ndm,
21    Ncm,
22    Nmm,
23    kNm,
24    kNdm,
25    kNcm,
26    kNmm,
27    LbFt,
28    LbIn,
29    J,
30    eV,
31    keV,
32    MeV,
33    GeV,
34    TeV,
35}
36
37impl PhysicsUnit for ForceDistanceUnit {
38    fn name(&self) -> &str {
39        match self {
40            ForceDistanceUnit::Nm => "Nm",
41            ForceDistanceUnit::Ndm => "Ndm",
42            ForceDistanceUnit::Ncm => "Ncm",
43            ForceDistanceUnit::Nmm => "Nmm",
44            ForceDistanceUnit::kNm => "kNm",
45            ForceDistanceUnit::kNdm => "kNdm",
46            ForceDistanceUnit::kNcm => "kNcm",
47            ForceDistanceUnit::kNmm => "kNmm",
48            ForceDistanceUnit::LbFt => "lb-ft",
49            ForceDistanceUnit::LbIn => "lb-in",
50            ForceDistanceUnit::J => "J",
51            ForceDistanceUnit::eV => "eV",
52            ForceDistanceUnit::keV => "keV",
53            ForceDistanceUnit::MeV => "MeV",
54            ForceDistanceUnit::GeV => "GeV",
55            ForceDistanceUnit::TeV => "TeV",
56        }
57    }
58
59    fn base_per_x(&self) -> (f64, i32) {
60        match self {
61            ForceDistanceUnit::Nmm => (1., -3),
62            ForceDistanceUnit::Ncm => (1., -2),
63            ForceDistanceUnit::Ndm => (1., -1),
64            ForceDistanceUnit::Nm => (1., 0),
65            ForceDistanceUnit::kNm => (1., 3),
66            ForceDistanceUnit::kNdm => (1., 2),
67            ForceDistanceUnit::kNcm => (1., 1),
68            ForceDistanceUnit::kNmm => (1., 0),
69            ForceDistanceUnit::LbFt => (1.35582, 0),
70            ForceDistanceUnit::LbIn => (1.12985, -1),
71            ForceDistanceUnit::J => (1.0, 0),
72            ForceDistanceUnit::eV => (Charge::e() * Voltage::new(1., VoltageUnit::V)).get_tuple(),
73            ForceDistanceUnit::keV => (Charge::e() * Voltage::new(1., VoltageUnit::kV)).get_tuple(),
74            ForceDistanceUnit::MeV => (Charge::e() * Voltage::new(1., VoltageUnit::MV)).get_tuple(),
75            ForceDistanceUnit::GeV => (Charge::e() * Voltage::new(1., VoltageUnit::GV)).get_tuple(),
76            ForceDistanceUnit::TeV => (Charge::e() * Voltage::new(1., VoltageUnit::TV)).get_tuple(),
77        }
78    }
79}
80
81impl_quantity!(ForceDistance, ForceDistanceUnit, ForceDistanceUnit::Nm);
82impl_div_with_self_to_f64!(ForceDistance);
83impl_div!(ForceDistance, Distance, Force);
84impl_div!(ForceDistance, Force, Distance);
85impl_mul!(ForceDistance, Distance, ForceArea);
86impl_div!(ForceDistance, VelocitySquared, Mass);
87impl_div!(ForceDistance, Mass, VelocitySquared);
88impl_div!(ForceDistance, Charge, Voltage);
89impl_div!(ForceDistance, Voltage, Charge);
90impl_div!(ForceDistance, Volume, Stress);
91impl_div!(ForceDistance, Stress, Volume);