#[doc(hidden)] #[macro_export(local_inner_macros)] macro_rules! impl_matrix { () => { impl Matrix{ #[inline(always)] pub const fn new(array:[[T;X];Y])->Self{ Self{array} } #[inline(always)] pub fn to_array(self)->[[T;X];Y]{ self.array } #[inline] pub fn map(self,f:F)->Matrix where F:Fn(T)->U { Matrix::new( self.array.map(|inner|inner.map(&f)), ) } #[inline] pub fn transpose(self)->Matrix{ //how did I think of this let mut array_of_iterators=self.array.map(|axis|axis.into_iter()); Matrix::new( core::array::from_fn(|_| array_of_iterators.each_mut().map(|iter| iter.next().unwrap() ) ) ) } #[inline] // MatY.MatX = MatY pub fn dot(self,rhs:Matrix)->Matrix where T:core::ops::Mul+Copy, V:core::iter::Sum, U:Copy, { let mut array_of_iterators=rhs.array.map(|axis|axis.into_iter().cycle()); Matrix::new( self.array.map(|axis| core::array::from_fn(|_| // axis dot product with transposed rhs array axis.iter().zip( array_of_iterators.iter_mut() ).map(|(&lhs_value,rhs_iter)| lhs_value*rhs_iter.next().unwrap() ).sum() ) ) ) } } impl Matrix where T:Copy { pub const fn from_value(value:T)->Self{ Self::new([[value;X];Y]) } } impl Default for Matrix{ fn default()->Self{ Self::new( core::array::from_fn(|_|core::array::from_fn(|_|Default::default())) ) } } #[cfg(feature="fixed_wide")] $crate::impl_matrix_wide_dot_8x8!(); } } #[doc(hidden)] #[macro_export(local_inner_macros)] macro_rules! impl_matrix_named_fields_shape { ( ($struct_outer:ident, $size_outer: expr), ($size_inner: expr) ) => { impl core::ops::Deref for Matrix<$size_outer,$size_inner,T>{ type Target=$struct_outer>; fn deref(&self)->&Self::Target{ unsafe{core::mem::transmute(&self.array)} } } impl core::ops::DerefMut for Matrix<$size_outer,$size_inner,T>{ fn deref_mut(&mut self)->&mut Self::Target{ unsafe{core::mem::transmute(&mut self.array)} } } } } #[doc(hidden)] #[macro_export(local_inner_macros)] macro_rules! impl_matrix_named_fields_shape_shim { ( ($($vector_info:tt),+), $matrix_info:tt ) => { $crate::macro_repeated!(impl_matrix_named_fields_shape,$matrix_info,$($vector_info),+); } } #[doc(hidden)] #[macro_export(local_inner_macros)] macro_rules! impl_matrix_named_fields { ( ($($matrix_info:tt),+), $vector_infos:tt ) => { $crate::macro_repeated!(impl_matrix_named_fields_shape_shim,$vector_infos,$($matrix_info),+); } } #[doc(hidden)] #[macro_export(local_inner_macros)] macro_rules! impl_matrix_3x3 { ()=>{ #[cfg(feature="fixed_wide")] $crate::impl_matrix_wide_3x3!(); } }