python opencv双目测距_OpenCV实现双目测距

原理图示

原理很简单,利用了相似三角形计算距离,所以双目测距的主要任务在于前期摄像头的定标、双目图像点的特征匹配上。

常用做法具体步骤

1.双目定标和校正,获得摄像头的参数矩阵

摄像头定标一般都需要一个放在摄像头前的特制的标定参照物(棋盘纸),摄像头获取该物体的图像,并由此计算摄像头的内外参数。标定参照物上的每一个特征点相对于世界坐标系的位置在制作时应精确测定,世界坐标系可选为参照物的物体坐标系。在得到这些已知点在图像上的投影位置后,可计算出摄像头的内外参数。

如上公式所示,摄像头由于光学透镜的特性使得成像存在着径向畸变,可由三个参数k1,k2,k3确定;由于装配方面的误差,传感器与光学镜头之间并非完全平行,因此成像存在切向畸变,可由两个参数p1,p2确定。

具体操作:

cvStereoRectify 执行双目校正

initUndistortRectifyMap 分别生成两个图像校正所需的像素映射矩阵

cvremap 分别对两个图像进行校正

2.立体匹配,获得视差图:

具体操作:

预处理: 图像归一化,减少亮度差别,增强纹理

stereoBM生成视差图

匹配过程: 滑动sad窗口,沿着水平线进行匹配搜索,由于校正后左右图片平行,左图的特征可以在右图对应行找到最佳匹配

再过滤: 去除坏的匹配点 通过uniquenessratio

输出视差图disparity:如果左右匹配点比较稠密,匹配点多,得到的图像与原图相似度比较大, 如果匹配点比较稀疏,得到的点与原图 相似度比较小

3.得出测距:

根据提取的特征点上用上述双目测距的相似三角算法得出距离。

小车中的实际应用

SIFT特征提取算法对左右图像点提取特征

knnMatch取k=2找到左右图片最佳匹配

再过滤去除坏的匹配点

对于剩下的点使用相似三角形计算公式得到图片各点景深标在图上

最终小车避障可根据其中少数点进行判断,或者取均值。

双目测距是一种利用两个摄像头或者相机来测量物体距离的方法。在Python中,实现双目测距可以使用一些已有的库和代码。 首先,你需要进行双目标定,这是为了获取相机的内外参数。内参数包括相机的焦距、主点坐标等,而外参数则是相机的旋转矩阵和平移向量。这些参数可以通过拍摄棋盘格图像并使用标定算法获得。 接下来是立体校正,也就是校正左右相机的图像,使得它们的像素点在同一平面上。这一步还包括消除畸变,以保证图像的几何形状是正确的。 然后是立体匹配,通过对左右相机的图像进行匹配,找出对应的像素点对。这一步可以使用一些算法,如均值迁移、视差图像等。 接着是视差计算,根据左右相机图像的像素点对的视差值,可以计算出物体到相机的距离。 最后是深度计算,通过将视差值转化为三维坐标,可以得到物体的三维坐标和深度信息。 在Python中,可以使用一些库和代码实现双目测距,比如OpenCV和StereoBM算法。你可以查找相应的资料和示例代码,根据具体需求进行使用和修改。参考中的博客文章提供了一种Python实现双目测距的方法,其中包含了主函数和相机参数的代码,以及双目测距的步骤和流程。 总结起来,实现双目测距的步骤包括双目标定、立体校正、立体匹配、视差计算和深度计算。在Python中,可以使用一些库和代码来实现这些步骤,并最终得到物体的距离信息。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [双目测距理论及其python实现](https://blog.csdn.net/javastart/article/details/127477851)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [双目测距 BM算法 Python版](https://blog.csdn.net/qq_41204464/article/details/120344636)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值