forked from StrafesNET/strafe-project
matrix multiplication
This commit is contained in:
parent
1a6ece1312
commit
34450d6a13
@ -32,6 +32,29 @@ macro_rules! impl_matrix {
|
||||
)
|
||||
}
|
||||
}
|
||||
#[inline]
|
||||
// MatX<VecY>.MatY<VecZ> = MatX<VecZ>
|
||||
pub fn dot<const Z:usize,U,V>(self,rhs:Matrix<Y,Z,U>)->Matrix<X,Z,V>
|
||||
where
|
||||
T:core::ops::Mul<U,Output=V>+Copy,
|
||||
V:core::iter::Sum,
|
||||
{
|
||||
let mut array_of_iterators=rhs.array.map(|axis|axis.into_iter());
|
||||
Matrix{
|
||||
array:self.array.map(|axis|
|
||||
core::array::from_fn(|_|
|
||||
// axis dot product with transposed rhs array
|
||||
axis.into_iter().zip(
|
||||
array_of_iterators.each_mut().map(|iter|
|
||||
iter.next().unwrap()
|
||||
)
|
||||
).map(|(a,b)|
|
||||
a*b
|
||||
).sum()
|
||||
)
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
impl<const X:usize,const Y:usize,T> Matrix<X,Y,T>
|
||||
where
|
||||
|
Loading…
Reference in New Issue
Block a user