matlab中的thresh怎样计算的,matlab – 选择正确的基本矩阵

本文探讨了在Matlab中使用五点算法实现基本矩阵求解,与OpenCV的findEssentialMat函数进行比较。作者发现尽管两者都使用五点算法,但解的选取和三角测量结果不同,并分析了可能的原因和解决方案的选择策略。
摘要由CSDN通过智能技术生成

我想使用Matlab编写自己的sfm管道代码,因为我需要一些opencv函数不提供的输出.但是,我使用opencv进行比较.

Opencv函数[E,mask] = cv.findEssentialMat(points1,points2,’CameraMatrix’,K,’Method’,’Ransac’);使用Nister的五点算法和RANSAC提供基本矩阵解决方案.

使用以下内容找到inlier指数:InliersIndices = find(mask> 0);

我使用了Nister算法的Matlab实现:

对函数的调用如下:

[E_all, R_all, t_all, Eo_all] = five_point_algorithm( pts1, pts2, K, K);

该算法输出多达10个基本矩阵的解.但是,我遇到了以下问题:

>上面提到的impelmentation仅用于完美对应(没有Ransac),并且我使用InliersIndices为算法5提供对应,输出的基本矩阵(最多10个)都不同于Opencv返回的矩阵.

>所有返回的基本矩阵应该是解决方案,那么为什么当我使用以下函数对每个矩阵进行三角测量时,我不会获得相同的3D点?

>如何选择合适的基本marix解决方案?

我使用matlab工具箱的功能进行三角测量

投影矩阵:

P1=K*[eye(3) [0;0;0]];

P2=K*[R_all{i} t_all{i}];

[pts3D,rep_error] = triangulate(pts1', pts2', P1',P2');

编辑

从[E,mask]返回的E = cv.findEssentialMa

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值