【OpenCV】障碍物提取

由于后续要做移动机器人的视觉导航,所以提取机器人行进路径上的障碍物是很重要的一步。目前已基本实现障碍物的提取,但精度不高,后续仍要进行改进。本文主要参考了基于深度摄像头的障碍物检测(realsense+opencv) http://www.cnblogs.com/daihengchen/p/5686272.html以及一些期刊论文和学位论文。
在前文得到视差图和三维坐标的基础上,首先对地面干扰区域和行进路径以外区域进行去除。以下是地面干扰区域的去除方法,行进路径以外区域我采用的是机器人行进过程中设定一定的视角,去除视角之外的区域,通过行进路径以外物体距相机中心在x轴和z轴上的距离来就算角度。
这里写图片描述
然后对处理后的视差图进行二值化分割,大致提取到障碍物。由于立体匹配过程中一些物体文理较弱的区域未匹配,导致一个物体可能被分割成几部分,所以对图像再进行闭运算,然后再求出所有障碍物的凸包,这个时候要计算面积,当面积小于一定的阈值的时候不予考虑,最终输出障碍物的凸包坐标。
以下是实现过程:
这里写图片描述

视差图→三维测距
这里写图片描述

去除行进路径以外区域→去除地面干扰区域→二值化分割
这里写图片描述

闭运算→求凸包
这里写图片描述

得到障碍物坐标和大小
这里写图片描述

  • 14
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 39
    评论
OpenCV是一个开源的计算机视觉库,可以用于图像处理和分析。在使用OpenCV进行障碍物轮廓识别时,可以借助一些函数和方法来实现。 首先,使用深度图像获取函数(find_obstacle)来获取深度图的障碍物信息。这个函数会返回每个障碍物凸包的坐标,其中凸包是包围障碍物的最小凸多边形。在这个函数中,可以通过对深度图进行阈值化和开运算来减少噪点,并使用findContours函数得到轮廓图。接下来,可以使用convexHull函数获取每个障碍物的凸包坐标。最后,将得到的障碍物坐标返回。 基本思路是通过realsense SDK2.0获取摄像头的数据和参数,并将其转化为Mat对象。然后对图像进行模糊、灰度化和二值化处理,接着提取并绘制轮廓。在计算轮廓的中心点坐标之后,可以通过计算坐标与摄像头的距离来判断障碍物的位置。最后,可以绘制一定距离内的矩形,并将距离参数转化为字符串进行显示。 总结起来,使用OpenCV进行障碍物轮廓识别的基本步骤包括:获取深度图障碍物的函数,阈值化和开运算处理,提取轮廓和凸包,计算距离并绘制矩形,最后将结果显示出来。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Python Opencv实现图像轮廓识别功能](https://download.csdn.net/download/weixin_38685876/12863292)[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: 33.333333333333336%"] - *2* [基于深度摄像头的障碍物检测(realsense+opencv)](https://blog.csdn.net/qq_31918961/article/details/90106434)[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: 33.333333333333336%"] - *3* [基于OpenCV+RealSense的障碍物检测](https://blog.csdn.net/m0_61897853/article/details/123338139)[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: 33.333333333333336%"] [ .reference_list ]
评论 39
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值