nonzero doesn't actually hint the compiler and is therefore useless

This commit is contained in:
Quaternions 2023-10-14 11:38:54 -07:00
parent 8fba543684
commit 762f10fb01

View File

@ -87,28 +87,27 @@ const fn gcd(mut a:u64,mut b:u64)->u64{
#[derive(Clone,Copy,Hash)] #[derive(Clone,Copy,Hash)]
pub struct Ratio64{ pub struct Ratio64{
num:i64, num:i64,
den:std::num::NonZeroU64, den:u64,
} }
impl Ratio64{ impl Ratio64{
pub const ZERO:Self=Ratio64{num:0,den:unsafe{std::num::NonZeroU64::new_unchecked(1)}}; pub const ZERO:Self=Ratio64{num:0,den:1};
pub const ONE:Self=Ratio64{num:1,den:unsafe{std::num::NonZeroU64::new_unchecked(1)}}; pub const ONE:Self=Ratio64{num:1,den:1};
#[inline] #[inline]
pub const fn new(num:i64,den:u64)->Option<Ratio64>{ pub const fn new(num:i64,den:u64)->Option<Ratio64>{
match std::num::NonZeroU64::new(den){ if den==0{
Some(_)=>{ None
}else{
let d=gcd(num.unsigned_abs(),den); let d=gcd(num.unsigned_abs(),den);
Some(Self{num:num/d as i64,den:unsafe{std::num::NonZeroU64::new_unchecked(den/d)}}) Some(Self{num:num/d as i64,den:den/d})
},
None=>None,
} }
} }
#[inline] #[inline]
pub fn mul_int(self,rhs:i64)->i64{ pub fn mul_int(self,rhs:i64)->i64{
rhs*self.num/self.den.get() as i64 rhs*self.num/self.den as i64
} }
#[inline] #[inline]
pub fn rhs_div_int(self,rhs:i64)->i64{ pub fn rhs_div_int(self,rhs:i64)->i64{
rhs*self.den.get() as i64/self.num rhs*self.den as i64/self.num
} }
} }
//from num_traits crate //from num_traits crate
@ -216,11 +215,11 @@ impl std::ops::Mul<Ratio64> for Ratio64{
type Output=Ratio64; type Output=Ratio64;
#[inline] #[inline]
fn mul(self,rhs:Ratio64)->Self::Output{ fn mul(self,rhs:Ratio64)->Self::Output{
let (num,den)=(self.num*rhs.num,self.den.get()*rhs.den.get()); let (num,den)=(self.num*rhs.num,self.den*rhs.den);
let d=gcd(num.unsigned_abs(),den); let d=gcd(num.unsigned_abs(),den);
Self{ Self{
num:num/d as i64, num:num/d as i64,
den:unsafe{std::num::NonZeroU64::new_unchecked(den/d)}, den:den/d,
} }
} }
} }
@ -240,7 +239,7 @@ impl std::ops::Div<u64> for Ratio64{
fn div(self,rhs:u64)->Self::Output { fn div(self,rhs:u64)->Self::Output {
Self{ Self{
num:self.num, num:self.num,
den:std::num::NonZeroU64::new(self.den.get()*rhs).unwrap(), den:self.den*rhs,
} }
} }
} }
@ -426,7 +425,7 @@ impl Into<f32> for Planar64{
impl From<Ratio64> for Planar64{ impl From<Ratio64> for Planar64{
#[inline] #[inline]
fn from(ratio:Ratio64)->Self{ fn from(ratio:Ratio64)->Self{
Self(Self::ONE.0*ratio.num/ratio.den.get() as i64) Self((((ratio.num as i128)<<32)/ratio.den as i128) as i64)
} }
} }
#[derive(Debug)] #[derive(Debug)]