2024-08-23 22:57:12 +00:00
|
|
|
#[doc(hidden)]
|
|
|
|
#[macro_export(local_inner_macros)]
|
2024-08-23 23:26:19 +00:00
|
|
|
macro_rules! impl_wide_operations {
|
2024-08-23 22:57:12 +00:00
|
|
|
( $struct: ident { $($field: ident), + }, $size: expr ) => {
|
2024-08-27 19:07:19 +00:00
|
|
|
impl<U,T:Copy+fixed_wide_traits::wide::WideMul<Output=U>> fixed_wide_traits::wide::WideMul for $struct<T> {
|
2024-08-23 23:26:19 +00:00
|
|
|
type Output=$struct<U>;
|
2024-08-23 22:57:12 +00:00
|
|
|
#[inline]
|
2024-08-23 23:26:19 +00:00
|
|
|
fn wide_mul(self, rhs: Self) -> Self::Output {
|
|
|
|
$struct{
|
|
|
|
$( $field: self.$field.wide_mul(rhs.$field) ), +
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-08-27 19:07:19 +00:00
|
|
|
impl<U:std::ops::Add<Output=U>,T:Copy+fixed_wide_traits::wide::WideMul<Output=U>> $struct<T> {
|
2024-08-23 23:26:19 +00:00
|
|
|
#[inline]
|
2024-08-23 23:49:05 +00:00
|
|
|
pub fn wide_dot(self, other: Self) -> U {
|
2024-08-23 22:57:12 +00:00
|
|
|
$crate::sum_repeating!(
|
2024-08-23 23:26:19 +00:00
|
|
|
$( + (self.$field.wide_mul(other.$field)) ) +
|
2024-08-23 22:57:12 +00:00
|
|
|
)
|
|
|
|
}
|
2024-08-23 23:49:05 +00:00
|
|
|
pub fn wide_length_squared(&self) -> U {
|
|
|
|
let squared = $struct {
|
2024-08-23 23:26:19 +00:00
|
|
|
$( $field: self.$field.wide_mul(self.$field) ), +
|
2024-08-23 22:57:12 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
$crate::sum_repeating!(
|
|
|
|
$( + squared.$field ) +
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// HACK: Allows us to sum repeating tokens in macros.
|
|
|
|
// See: https://stackoverflow.com/a/60187870/17452730
|
|
|
|
#[doc(hidden)]
|
|
|
|
#[macro_export(local_inner_macros)]
|
|
|
|
macro_rules! sum_repeating {
|
|
|
|
( + $($item: tt) * ) => {
|
|
|
|
$($item) *
|
|
|
|
};
|
|
|
|
}
|