#[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())) ) } } impl core::ops::Mul> for Matrix where T:core::ops::Mul+Copy, V:core::iter::Sum, U:Copy, { type Output=Matrix; #[inline] fn mul(self,rhs:Matrix)->Self::Output{ self.dot(rhs) } } #[cfg(feature="fixed_wide")] $crate::impl_matrix_wide_dot_8x8!(); } } #[doc(hidden)] #[macro_export(local_inner_macros)] macro_rules! impl_matrix_extend { ( $x: expr, $y: expr ) => { impl Matrix<$x,$y,T>{ #[inline] pub fn extend_row(self,value:Vector<$x,T>)->Matrix<$x,{$y+1},T>{ let mut iter=self.array.into_iter().chain(core::iter::once(value.array)); Matrix::new( core::array::from_fn(|_|iter.next().unwrap()), ) } #[inline] pub fn extend_column(self,value:Vector<$y,T>)->Matrix<{$x+1},$y,T>{ let mut iter_rows=value.array.into_iter(); Matrix::new( self.array.map(|axis|{ let mut elements_iter=axis.into_iter().chain(core::iter::once(iter_rows.next().unwrap())); core::array::from_fn(|_|elements_iter.next().unwrap()) }) ) } } } } #[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!(); } }