forked from StrafesNET/strafe-project
lol idk #1
@ -3,7 +3,11 @@ name = "fixed_wide"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
|
[features]
|
||||||
|
default=["wide_traits"]
|
||||||
|
wide_traits=["dep:wide_traits"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
bnum = "0.11.0"
|
bnum = "0.11.0"
|
||||||
typenum = "1.17.0"
|
typenum = "1.17.0"
|
||||||
wide_traits = { version = "0.1.0", path = "../wide_traits" }
|
wide_traits = { version = "0.1.0", path = "../wide_traits", optional = true }
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
use bnum::cast::As;
|
|
||||||
use bnum::BInt;
|
use bnum::BInt;
|
||||||
use wide_traits::wide::WideMul;
|
use typenum::Unsigned;
|
||||||
use typenum::{Sum,Unsigned};
|
|
||||||
use std::marker::PhantomData;
|
use std::marker::PhantomData;
|
||||||
|
|
||||||
#[derive(Clone,Copy,Debug,Hash)]
|
#[derive(Clone,Copy,Debug,Hash)]
|
||||||
pub struct Fixed<const CHUNKS:usize,Frac>{
|
pub struct Fixed<const CHUNKS:usize,Frac>{
|
||||||
bits:BInt<{CHUNKS}>,
|
pub(crate)bits:BInt<{CHUNKS}>,
|
||||||
frac:PhantomData<Frac>,
|
pub(crate)frac:PhantomData<Frac>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<const CHUNKS:usize,FracDst:Unsigned,T> From<T> for Fixed<CHUNKS,FracDst>
|
impl<const CHUNKS:usize,FracDst:Unsigned,T> From<T> for Fixed<CHUNKS,FracDst>
|
||||||
@ -82,31 +80,3 @@ impl_assign_operator!( Fixed, BitOrAssign, bitor_assign );
|
|||||||
impl_operator!( Fixed, BitOr, bitor, Self );
|
impl_operator!( Fixed, BitOr, bitor, Self );
|
||||||
impl_assign_operator!( Fixed, BitXorAssign, bitxor_assign );
|
impl_assign_operator!( Fixed, BitXorAssign, bitxor_assign );
|
||||||
impl_operator!( Fixed, BitXor, bitxor, Self );
|
impl_operator!( Fixed, BitXor, bitxor, Self );
|
||||||
|
|
||||||
//going wider native
|
|
||||||
macro_rules! impl_wide_mul {
|
|
||||||
($lhs: expr,$rhs: expr) => {
|
|
||||||
impl<A,B> WideMul<Fixed<$rhs,B>> for Fixed<$lhs,A>
|
|
||||||
where
|
|
||||||
A:std::ops::Add<B>,
|
|
||||||
B:Unsigned,
|
|
||||||
{
|
|
||||||
type Output=Fixed<{$lhs+$rhs},Sum<A,B>>;
|
|
||||||
fn wide_mul(self,rhs:Fixed<$rhs,B>)->Self::Output{
|
|
||||||
Fixed{
|
|
||||||
bits:self.bits.as_::<BInt<{$lhs+$rhs}>>()*rhs.bits.as_::<BInt<{$lhs+$rhs}>>(),
|
|
||||||
frac:PhantomData,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
//const generics sidestepped wahoo
|
|
||||||
impl_wide_mul!(1,1);impl_wide_mul!(2,1);impl_wide_mul!(3,1);impl_wide_mul!(4,1);impl_wide_mul!(5,1);impl_wide_mul!(6,1);impl_wide_mul!(7,1);impl_wide_mul!(8,1);
|
|
||||||
impl_wide_mul!(1,2);impl_wide_mul!(2,2);impl_wide_mul!(3,2);impl_wide_mul!(4,2);impl_wide_mul!(5,2);impl_wide_mul!(6,2);impl_wide_mul!(7,2);impl_wide_mul!(8,2);
|
|
||||||
impl_wide_mul!(1,3);impl_wide_mul!(2,3);impl_wide_mul!(3,3);impl_wide_mul!(4,3);impl_wide_mul!(5,3);impl_wide_mul!(6,3);impl_wide_mul!(7,3);impl_wide_mul!(8,3);
|
|
||||||
impl_wide_mul!(1,4);impl_wide_mul!(2,4);impl_wide_mul!(3,4);impl_wide_mul!(4,4);impl_wide_mul!(5,4);impl_wide_mul!(6,4);impl_wide_mul!(7,4);impl_wide_mul!(8,4);
|
|
||||||
impl_wide_mul!(1,5);impl_wide_mul!(2,5);impl_wide_mul!(3,5);impl_wide_mul!(4,5);impl_wide_mul!(5,5);impl_wide_mul!(6,5);impl_wide_mul!(7,5);impl_wide_mul!(8,5);
|
|
||||||
impl_wide_mul!(1,6);impl_wide_mul!(2,6);impl_wide_mul!(3,6);impl_wide_mul!(4,6);impl_wide_mul!(5,6);impl_wide_mul!(6,6);impl_wide_mul!(7,6);impl_wide_mul!(8,6);
|
|
||||||
impl_wide_mul!(1,7);impl_wide_mul!(2,7);impl_wide_mul!(3,7);impl_wide_mul!(4,7);impl_wide_mul!(5,7);impl_wide_mul!(6,7);impl_wide_mul!(7,7);impl_wide_mul!(8,7);
|
|
||||||
impl_wide_mul!(1,8);impl_wide_mul!(2,8);impl_wide_mul!(3,8);impl_wide_mul!(4,8);impl_wide_mul!(5,8);impl_wide_mul!(6,8);impl_wide_mul!(7,8);impl_wide_mul!(8,8);
|
|
||||||
|
@ -1,2 +1,5 @@
|
|||||||
pub mod fixed;
|
pub mod fixed;
|
||||||
pub mod types;
|
pub mod types;
|
||||||
|
|
||||||
|
#[cfg(feature="wide_traits")]
|
||||||
|
mod wide_traits;
|
||||||
|
44
fixed_wide/src/wide_traits.rs
Normal file
44
fixed_wide/src/wide_traits.rs
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
use bnum::BInt;
|
||||||
|
use bnum::cast::As;
|
||||||
|
use typenum::{Sum,Unsigned};
|
||||||
|
use crate::fixed::Fixed;
|
||||||
|
use wide_traits::wide::WideMul;
|
||||||
|
use std::marker::PhantomData;
|
||||||
|
|
||||||
|
macro_rules! impl_wide_mul {
|
||||||
|
($lhs: expr,$rhs: expr) => {
|
||||||
|
impl<A,B> WideMul<Fixed<$rhs,B>> for Fixed<$lhs,A>
|
||||||
|
where
|
||||||
|
A:std::ops::Add<B>,
|
||||||
|
B:Unsigned,
|
||||||
|
{
|
||||||
|
type Output=Fixed<{$lhs+$rhs},Sum<A,B>>;
|
||||||
|
fn wide_mul(self,rhs:Fixed<$rhs,B>)->Self::Output{
|
||||||
|
Fixed{
|
||||||
|
bits:self.bits.as_::<BInt<{$lhs+$rhs}>>()*rhs.bits.as_::<BInt<{$lhs+$rhs}>>(),
|
||||||
|
frac:PhantomData,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
macro_rules! impl_wide_mul_all {
|
||||||
|
($(($x:expr, $y:expr)),*) => {
|
||||||
|
$(
|
||||||
|
impl_wide_mul!($x, $y);
|
||||||
|
)*
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
//const generics sidestepped wahoo
|
||||||
|
impl_wide_mul_all!(
|
||||||
|
(1,1),(2,1),(3,1),(4,1),(5,1),(6,1),(7,1),(8,1),
|
||||||
|
(1,2),(2,2),(3,2),(4,2),(5,2),(6,2),(7,2),(8,2),
|
||||||
|
(1,3),(2,3),(3,3),(4,3),(5,3),(6,3),(7,3),(8,3),
|
||||||
|
(1,4),(2,4),(3,4),(4,4),(5,4),(6,4),(7,4),(8,4),
|
||||||
|
(1,5),(2,5),(3,5),(4,5),(5,5),(6,5),(7,5),(8,5),
|
||||||
|
(1,6),(2,6),(3,6),(4,6),(5,6),(6,6),(7,6),(8,6),
|
||||||
|
(1,7),(2,7),(3,7),(4,7),(5,7),(6,7),(7,7),(8,7),
|
||||||
|
(1,8),(2,8),(3,8),(4,8),(5,8),(6,8),(7,8),(8,8)
|
||||||
|
);
|
@ -3,6 +3,10 @@ name = "fixed_wide_vectors"
|
|||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
|
[features]
|
||||||
|
default=["wide_traits"]
|
||||||
|
wide_traits=["dep:wide_traits"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
fixed_wide = { version = "0.1.0", path = "../fixed_wide" }
|
fixed_wide = { version = "0.1.0", path = "../fixed_wide" }
|
||||||
wide_traits = { version = "0.1.0", path = "../wide_traits" }
|
wide_traits = { version = "0.1.0", path = "../wide_traits", optional = true }
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
// Stolen from https://github.com/c1m50c/fixed-vectors (MIT license)
|
#[cfg(feature="wide_traits")]
|
||||||
pub mod wide;
|
pub mod wide;
|
||||||
|
|
||||||
|
// Stolen from https://github.com/c1m50c/fixed-vectors (MIT license)
|
||||||
#[doc(hidden)]
|
#[doc(hidden)]
|
||||||
#[macro_export(local_inner_macros)]
|
#[macro_export(local_inner_macros)]
|
||||||
macro_rules! impl_vector {
|
macro_rules! impl_vector {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user