我正在rust中实现一个简单的矩阵库,目前正在编写用于标量乘法的运算符。右乘法的工作原理:
impl<T: Num + Zero + Clone + Float> Mul<T, Mat<T>> for Mat<T> {
fn mul(&self, rhs: &T) -> Mat<T> {
self.componentwise(|v| v.clone() * *rhs)
}
}
但是我似乎无法进行左乘法运算,我假设下面的代码可以实现我想要的功能:
impl<T: Num + Zero + Clone + Float> Mul<Mat<T>, Mat<T>> for T {
fn mul(&self, rhs: &Mat<T>) -> Mat<T> {
rhs.componentwise(|v| *self * v.clone())
}
}
但是以下方法不起作用:
let A = mat![[1f64, 2., 3.], [4., 5., 6.]];
let P = A * 4f64; // works!
let Q = 4f64 * A; // error...
错误是
error: mismatched types: expected `f64`, found `linalg::Mat<f64>` (expected f64, found struct linalg::Mat)
。我只能使用f64 * f64乘法,还是我接近第二种情况是错误的?我尝试专门使用impl Mul<Mat<f64>, Mat<f64>> for f64
为f64实现它,但这仍然行不通。我发现我可以使用
4f64.mul(&A)
使其工作,但这并不理想。 最佳答案
可能与声明有关:您的第二次隐式减量用于Mult<Mat<T>, Mat<T>>
,因此我的猜测是它允许将两个矩阵相乘,这不是您想要的。
(我想发表评论,但我还不能这样做:()
关于operator-overloading - Rust没有看到我的重载f64乘法运算符,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27043750/