前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用OpenCV检测坑洼

使用OpenCV检测坑洼

作者头像
OpenCV学堂
发布2020-06-19 16:10:28
8060
发布2020-06-19 16:10:28
举报

来源:公众号 小白学视觉 授权

本文将向大家介绍如何使用OpenCV库进行坑洼检测。

为什么要检测坑洼?

坑洼是道路的结构性指标,事先发现坑洼地可以延长高速公路的使用寿命,防止事故的发生,同时降低死亡率。

一种可行的解决方案是构建自动坑洞检测系统,该系统可通过云服务发送实时信息以提醒管理结构,来杜绝每天人工检查所产生的不必要花费。

OpenCV是一个帮助研究人员处理图像问题的库,该库提供了大量处理图像的方法。OpenCV的使用将有助于坑洼检测。

图像的基础知识

在了解代码之前,必须先了解图像的工作原理。

图像一般被划分为很多像素,每个像素的值范围介于 0 和 255 之间。转换为灰度时,范围从 0 到 1。

大小为28x28的灰度图像

可以操作图像的每个像素。例如,如果希望随机像素具有另一个值,则有两种方法。第一种是通过直接更改矩阵中的点来更改这一点。第二种是使用内核东西来实现。

内核是具有一定值的小矩阵,通常为 3x3,叠加在图像上充当滤波器。

(40*0) + (42*1) + (46*0) + (46*0) + (50*0) + (55*0) + (52*0) + (56*0) + (58*0) = 42

上图显示了图像与内核卷积的结果。卷积是通过数值的相乘相加得到输出结果的过程。卷积可以实现图像的模糊,例如下图所示。

所选内核对输入图像进行了模糊

阈值

阈值的概念很简单,给定一个图像,绘制其直方图并选择一个值。比该值大的每个像素都将变为黑色,比该值小的每个像素将变为白色,具体如下所示。

根据照明选择不同阈值的自适应阈值方法(这一方法可用于检测坑洞)。更多算法可以在OpenCV阈值文档中找到。

边缘检测

边缘检测算法将在图像中找到边缘。Canny是一种边缘检测算法,它将检测图像的边缘,并输出仅具有轮廓的图像。进一步的解释可以在这里找到。

使用不同参数应用的 Canny 图像

坑洼检测

我们可以将前面介绍的内核+阈值+边缘检测结合起来,并在道路上找到坑洼。

图1显示了从道路上拍摄的图像,该道路的坑洼直接位于汽车前

图2显示了应用了阈值处理的图像,坑洼和清洁街道区域被突出显示。

Canny应用于图片3,其中可以找到轮廓。在这里,可以创建一个算法,以便查看轮廓是否为坑洞。

图4显示了选中坑洞的图像。

最终图像,带有绿色标记的区域为坑洞的位置。

更多坑洼检测的结果如下图所示。

使用OpenCV进行坑洞检测并不难。此外,我们可以构建检测系统并将其与云和地图服务结合,以便提供有关选定区域坑洞的实时信息。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-06-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 OpenCV学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档