我正在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/

10-11 01:52