2020-12-01

写代码时碰到一个问题,想问问各位大佬为什么,下面的步骤是U的行列式是-1,V是-1, 2U*2V却等于3?

	Eigen::JacobiSVD<Eigen::Matrix3d> svd_slover(covge,Eigen::ComputeFullU | Eigen::ComputeFullV);
	MatXX U = svd_slover.matrixU();
	MatXX V = svd_slover.matrixV();
	MatXX D = svd_slover.singularValues();

	//std::cout<<"DEBUG: |U|*|V|="<<(U.determinant()*V.determinant())<<'\n';
    int Udet,Vdet,determinant_uv;
    
	determinant_uv = (2*U.determinant())*(2*V.determinant());
    //f=( U.determinant()*V.determinant());
    cout<<"determinant_uv = "<<determinant_uv<<endl;
    //cout<<"U = "<<Udet<<endl;
    //cout<<"V = "<<Vdet<<endl;
    cout<<"U.determinant() = "<<U.determinant()<<endl;
    cout<<"V.determinant() = "<<V.determinant()<<endl;
    cout<<"U.determinant()*V.determinant() = "<<(2*U.determinant())*(2*V.determinant())<<endl;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值