eigen 作为函数参数错误

error: invalid initialization of non-const reference of type 'Eigen::Matrix<double, 4, 4>&' from an rvalue of type 'Eigen::Matrix<double, 4, 4>

error: static assertion failed: YOU_MIXED_DIFFERENT_NUMERIC_TYPES__YOU_NEED_TO_USE_THE_CAST_METHOD_OF_MATRIXBASE_TO_CAST_NUMERIC_TYPES_EXPLICITLY
   EIGEN_CHECK_BINARY_COMPATIBILIY(Func,typename ActualDstTypeCleaned::Scalar,typename Src::Scalar);
   ^

function(a, b)

a Eigen::Matrix<double, 4, 4>

b Eigen::Matrix<float, 4, 4>

两个矩阵的类型不一致,一个是Eigen::Matrix<double, 4, 4>,一个是Eigen::Matrix<float, 4, 4>, 改成一样的就可以了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
非常抱歉,可能是我在之前的回答中出现了错误。下面是一个更正的代码示例,定义了一个名为`UF_MTX_eigen_decomp`的函数,它接受一个矩阵和一个向量,并计算出矩阵的特征值和特征向量。 ```c #include <stdio.h> #include <stdlib.h> #include <math.h> void UF_MTX_eigen_decomp(double *A, int n, double *eigval, double *eigvec) { // 矩阵A的特征值和特征向量将存储在eigval和eigvec中 // eigvec是一个n*n的矩阵,每一列是一个特征向量 // 请在此处编写计算特征值和特征向量的代码 } int main() { int n = 3; double A[] = {1.0, 2.0, 3.0, 2.0, 4.0, 5.0, 3.0, 5.0, 6.0}; double eigval[n]; double eigvec[n*n]; UF_MTX_eigen_decomp(A, n, eigval, eigvec); printf("Eigenvalues:\n"); for (int i = 0; i < n; i++) { printf("%f\n", eigval[i]); } printf("Eigenvectors:\n"); for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { printf("%f ", eigvec[j*n+i]); } printf("\n"); } return 0; } ``` 在这个示例中,`UF_MTX_eigen_decomp`函数接受一个指向矩阵`A`的指针,矩阵的大小为`n` x `n`。它还接受两个指向数组`eigval`和`eigvec`的指针,用于存储特征值和特征向量。`eigvec`是一个`n` x `n`矩阵,每一列都是一个特征向量。 在`main`函数中,我们定义了一个3 x 3的矩阵`A`,并定义了两个数组`eigval`和`eigvec`来存储特征值和特征向量。然后我们调用`UF_MTX_eigen_decomp`函数来计算矩阵`A`的特征值和特征向量,并将它们存储在`eigval`和`eigvec`数组中。最后,我们打印出特征值和特征向量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值