unitforge 0.2.26

A library for unit and quantity consistent computations in Rust
Documentation
use crate::impl_macros::macros::*;
use crate::prelude::*;
use crate::quantities::*;
use ndarray::{Array1, Array2, ArrayView1, ArrayView2};
use num_traits::identities::Zero;
use num_traits::FromPrimitive;
#[cfg(feature = "pyo3")]
use pyo3::pyclass;
#[cfg(feature = "serde")]
use serde::{Deserialize, Serialize};
use std::cmp::Ordering;
use std::fmt;
use std::ops::{Add, AddAssign, Div, DivAssign, Mul, MulAssign, Neg, Sub, SubAssign};

#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
#[derive(Copy, Clone, PartialEq, Debug)]
#[cfg_attr(feature = "pyo3", pyclass(eq, eq_int))]
pub enum ForceUnit {
    GN,
    MN,
    kN,
    N,
    dN,
    cN,
    mN,
    muN,
    nN,
    lbf,
    kgf,
}

impl PhysicsUnit for ForceUnit {
    fn name(&self) -> &str {
        match &self {
            ForceUnit::GN => "GN",
            ForceUnit::MN => "MN",
            ForceUnit::kN => "kN",
            ForceUnit::N => "N",
            ForceUnit::dN => "dN",
            ForceUnit::cN => "cN",
            ForceUnit::mN => "mN",
            ForceUnit::muN => "μm",
            ForceUnit::nN => "nN",
            ForceUnit::lbf => "lbf",
            ForceUnit::kgf => "kgf",
        }
    }

    fn base_per_x(&self) -> (f64, i32) {
        match self {
            ForceUnit::GN => (1., 9),
            ForceUnit::MN => (1., 6),
            ForceUnit::kN => (1., 3),
            ForceUnit::N => (1., 0),
            ForceUnit::dN => (1., -1),
            ForceUnit::cN => (1., -2),
            ForceUnit::mN => (1., -3),
            ForceUnit::muN => (1., -6),
            ForceUnit::nN => (1., -9),
            ForceUnit::lbf => (4.44822, 0),
            ForceUnit::kgf => (9.80665, 0),
        }
    }
}

impl_quantity!(Force, ForceUnit, ForceUnit::N);
impl_div_with_self_to_f64!(Force);

impl_mul!(Force, Distance, ForceDistance);
impl_div!(Force, Stress, Area);
impl_div!(Force, Area, Stress);
impl_div!(Force, Distance, Stiffness);
impl_div!(Force, Stiffness, Distance);
impl_mul!(Force, Area, ForceArea);
impl_div!(Force, Acceleration, Mass);
impl_div!(Force, Mass, Acceleration);
impl_div!(Force, ForceArea, InverseArea);
impl_div!(Force, InverseArea, ForceArea);