use crate::*;
#[derive(Clone, Copy, Default, Debug, PartialEq, PartialOrd)]
pub struct Radian<T: Scalar> {
value: T,
}
impl<T: Scalar> Radian<T> {
pub fn new(value: T) -> Self {
Self { value }
}
}
impl<T: Scalar> From<T> for Radian<T> {
fn from(value: T) -> Self {
Self { value }
}
}
impl<T: Scalar> HasValue for Radian<T> {
type Output = T;
fn value(self) -> Self::Output {
self.value
}
}
impl<T: Scalar> Scalar for Radian<T> {}
impl<T: Scalar> Number for Radian<T> {
const ZERO: Self = Self { value: T::ZERO };
const ONE: Self = Self { value: T::ONE };
const EPSILON: Self = Self { value: T::EPSILON };
fn abs(self) -> Self {
Self {
value: self.value.abs(),
}
}
fn min(self, other: Self) -> Self {
Self {
value: self.value.min(other.value),
}
}
fn max(self, other: Self) -> Self {
Self {
value: self.value.max(other.value),
}
}
fn floor(self) -> Self {
Self {
value: self.value.floor(),
}
}
fn round(self) -> Self {
Self {
value: self.value.round(),
}
}
fn ceil(self) -> Self {
Self {
value: self.value.ceil(),
}
}
fn trunc(self) -> Self {
Self {
value: self.value.trunc(),
}
}
}
impl<T: Scalar> std::fmt::Display for Radian<T> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{}rad", self.value)
}
}
impl<T> Angle<T> for Radian<T>
where
T: Scalar + AngleOps,
{
fn sin(&self) -> T {
self.value.sin()
}
fn cos(&self) -> T {
self.value.cos()
}
fn tan(&self) -> T {
self.value.tan()
}
fn to_radians(&self) -> Self {
*self
}
fn to_degrees(&self) -> Degree<T> {
Degree::new(self.value.to_degrees())
}
}
impl<T: Scalar + std::ops::Neg<Output = T>> std::ops::Neg for Radian<T> {
type Output = Self;
fn neg(self) -> Self::Output {
Self { value: -self.value }
}
}
impl<T: Scalar> std::ops::Add<Self> for Radian<T> {
type Output = Self;
fn add(self, rhs: Self) -> Self::Output {
Self {
value: self.value + rhs.value,
}
}
}
impl<T: Scalar> std::ops::AddAssign<Self> for Radian<T> {
fn add_assign(&mut self, rhs: Self) {
self.value += rhs.value
}
}
impl<T: Scalar> std::ops::Sub<Self> for Radian<T> {
type Output = Self;
fn sub(self, rhs: Self) -> Self::Output {
Self {
value: self.value - rhs.value,
}
}
}
impl<T: Scalar> std::ops::SubAssign<Self> for Radian<T> {
fn sub_assign(&mut self, rhs: Self) {
self.value -= rhs.value
}
}
impl<T: Scalar> std::ops::Mul<Self> for Radian<T> {
type Output = Self;
fn mul(self, rhs: Self) -> Self::Output {
Self {
value: self.value * rhs.value,
}
}
}
impl<T: Scalar> std::ops::MulAssign<Self> for Radian<T> {
fn mul_assign(&mut self, rhs: Self) {
self.value *= rhs.value
}
}
impl<T: Scalar> std::ops::Div<Self> for Radian<T> {
type Output = Self;
fn div(self, rhs: Self) -> Self::Output {
Self {
value: self.value / rhs.value,
}
}
}
impl<T: Scalar> std::ops::DivAssign<Self> for Radian<T> {
fn div_assign(&mut self, rhs: Self) {
self.value /= rhs.value
}
}