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