视差图(Disparity)三维重投影得到特征点的三维空间坐标的2种方法

前提

1、使用BM或者SGBM算法计算得到了双目图像的合适左右视差图;
2、使用立体校正函数stereoRectify()计算得到了4*4重投影矩阵Q;

方法1-perspectiveTransform()

1、透视变换这里可以用于计算一系列特征点的三维重投影坐标值,原理如图:
在这里插入图片描述

2、perspectiveTransform()函数原型:
在这里插入图片描述
在这里插入图片描述

其中注意:mat这里应该等效重投影矩阵Q;
在这里插入图片描述

3、使用方法:

  • 首先计算左相机图像中的特征点位置(像素坐标),找到对应视差图中点的位置,得到(x,y,d)值;
  • 调用函数perspectiveTransform()计算三维重投影的空间坐标;

方法2-reprojectimageto3d()

1、函数原型:
在这里插入图片描述
在这里插入图片描述

2、原理与透视变换相同,不过操作的对象是整个视差图所有点;
3、使用:

  • 首先得到视差图与4*4重投影矩阵Q;
  • 然后调用reprojectimageto3d()得到整幅图像的三维坐标信息;
  • 最后根据左相机图像中特征点的坐标信息,只提取对应的三维坐标信息;

PS

以上内容是我猜想的,可不可行还没验证,只可信一半~~(有问题麻烦帮忙指正一下呀)

参考

1、《Learning OpenCV3》P657

  • 4
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值