unitforge/quantities/
velocity_squared.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 VelocitySquaredUnit {
19    msq_ssq,
20}
21
22impl PhysicsUnit for VelocitySquaredUnit {
23    fn name(&self) -> &str {
24        match &self {
25            VelocitySquaredUnit::msq_ssq => "m²/s²",
26        }
27    }
28
29    fn base_per_x(&self) -> (f64, i32) {
30        match self {
31            VelocitySquaredUnit::msq_ssq => (1., 0),
32        }
33    }
34}
35
36impl_quantity!(
37    VelocitySquared,
38    VelocitySquaredUnit,
39    VelocitySquaredUnit::msq_ssq
40);
41impl_div_with_self_to_f64!(VelocitySquared);
42
43impl_mul_with_self!(Velocity, VelocitySquared);
44impl_mul!(VelocitySquared, Mass, ForceDistance);