当前位置:   article > 正文

Eigen 利用SVD矩阵分解 求伪逆代码_eigen svd

eigen svd

 

MatrixXd 是double类型,如果是float类型请改为 MatrixXf

计算结果 可与matlab的 pinv() 函数 对比,计算结果是一致的。

  1. Eigen::MatrixXd MainWindow::pinv(Eigen::MatrixXd A)
  2. {
  3. Eigen::JacobiSVD<Eigen::MatrixXd> svd(A, Eigen::ComputeFullU | Eigen::ComputeFullV);//M=USV*
  4. double pinvtoler = 1.e-8; //tolerance
  5. int row = A.rows();
  6. int col = A.cols();
  7. int k = min(row,col);
  8. Eigen::MatrixXd X = Eigen::MatrixXd::Zero(col,row);
  9. Eigen::MatrixXd singularValues_inv = svd.singularValues();//奇异值
  10. Eigen::MatrixXd singularValues_inv_mat = Eigen::MatrixXd::Zero(col, row);
  11. for (long i = 0; i<k; ++i) {
  12. if (singularValues_inv(i) > pinvtoler)
  13. singularValues_inv(i) = 1.0 / singularValues_inv(i);
  14. else singularValues_inv(i) = 0;
  15. }
  16. for (long i = 0; i < k; ++i)
  17. {
  18. singularValues_inv_mat(i, i) = singularValues_inv(i);
  19. }
  20. X=(svd.matrixV())*(singularValues_inv_mat)*(svd.matrixU().transpose());//X=VS+U*
  21. return X;
  22. }
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/78167
推荐阅读
相关标签
  

闽ICP备14008679号