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);