use core::{
cmp::PartialOrd,
ops::{Add, AddAssign, Div, DivAssign, Mul, MulAssign, Neg, Sub, SubAssign},
};
use num_traits::{Zero, real::Real};
pub trait VectorSpace: Zero + PartialEq
where
Self: Add<Output = Self>
+ Sub<Output = Self>
+ Mul<<Self as VectorSpace>::Scalar, Output = Self>
+ Div<<Self as VectorSpace>::Scalar, Output = Self>
+ Neg<Output = Self>,
{
type Scalar: Real + PartialOrd;
}
impl VectorSpace for f32 {
type Scalar = Self;
}
impl VectorSpace for f64 {
type Scalar = Self;
}
pub trait VectorSpaceAssign:
VectorSpace + AddAssign + SubAssign + MulAssign<Self::Scalar> + DivAssign<Self::Scalar>
{
}
impl<T> VectorSpaceAssign for T where
T: VectorSpace + AddAssign + SubAssign + MulAssign<Self::Scalar> + DivAssign<Self::Scalar>
{
}