0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

一个关于寻找图像中最亮点的教程的后续

新机器视觉 来源:AI算法与图像处理 作者:AI算法与图像处理 2021-06-18 11:41 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

今天的博客文章是我几年前做的一个关于寻找图像中最亮点的教程的后续。

我之前的教程假设在图像中只有一个亮点你想要检测。。.

但如果有多个亮点呢?

如果您想在图像中检测多个亮点,代码会稍微复杂一点,但不会太复杂。不过不用担心:我将详细解释每一个步骤。

看看下面的图片:

2fa98c60-cf69-11eb-9e57-12bb97331649.jpg

在这幅图中,我们有五个灯泡。

我们的目标是检测图像中的这五个灯泡,并对它们进行唯一的标记。

首先,打开一个新文件并将其命名为detect_bright_spot .py。然后,插入以下代码:

# import the necessary packagesfrom imutils import contoursfrom skimage import measureimport numpy as npimport argparseimport imutilsimport cv2# construct the argument parse and parse the argumentsap = argparse.ArgumentParser()ap.add_argument(“-i”, “--image”, required=True, help=“path to the image file”)args = vars(ap.parse_args())

导入一些必要的包和命令行参数。

要开始检测图像中最亮的区域,我们首先需要从磁盘加载我们的图像,然后将其转换为灰度图并进行平滑滤波,以减少高频噪声:

# load the image, convert it to grayscale, and blur itimage = cv2.imread(args[“image”])gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)blurred = cv2.GaussianBlur(gray, (11, 11), 0)

这些操作的输出如下:

2fcf2f1a-cf69-11eb-9e57-12bb97331649.png

为了显示模糊图像中最亮的区域,我们需要应用阈值化:

# threshold the image to reveal light regions in the# blurred imagethresh = cv2.threshold(blurred, 200, 255, cv2.THRESH_BINARY)[1]

操作取任意像素值p 》= 200,并将其设置为255(白色)。像素值《 200被设置为0(黑色)。

阈值化后,我们得到如下图像:

2fe920c8-cf69-11eb-9e57-12bb97331649.png

注意图像的明亮区域现在都是白色的,而其余的图像被设置为黑色。

然而,在这幅图像中有一点噪声(即,小斑点),所以让我们通过执行一系列的腐蚀和膨胀操作来清除它:

# perform a series of erosions and dilations to remove# any small blobs of noise from the thresholded imagethresh = cv2.erode(thresh, None, iterations=2)thresh = cv2.dilate(thresh, None, iterations=4)

在应用这些操作之后,你可以看到我们的thresh图像变得更加“干净”,但是仍然有一些我们想要移除的斑点。

303a4fde-cf69-11eb-9e57-12bb97331649.png

本项目的关键步骤是对上图中的每个区域进行标记,然而,即使在应用了腐蚀和膨胀后,我们仍然想要过滤掉剩余的小块儿区域。

一个很好的方法是执行连接组件分析:

# perform a connected component analysis on the thresholded# image, then initialize a mask to store only the “large”# componentslabels = measure.label(thresh, neighbors=8, background=0)mask = np.zeros(thresh.shape, dtype=“uint8”)# loop over the unique componentsfor label in np.unique(labels): # if this is the background label, ignore it if label == 0: continue # otherwise, construct the label mask and count the # number of pixels labelMask = np.zeros(thresh.shape, dtype=“uint8”) labelMask[labels == label] = 255 numPixels = cv2.countNonZero(labelMask) # if the number of pixels in the component is sufficiently # large, then add it to our mask of “large blobs” if numPixels 》 300: mask = cv2.add(mask, labelMask)

第4行使用scikit-image库执行实际的连接组件分析。measure.lable返回的label和我们的阈值图像有相同的大小,唯一的区别就是label存储的为阈值图像每一斑点对应的正整数。

然后我们在第5行初始化一个掩膜来存储大的斑点。

第7行我们开始循环遍历每个label中的正整数标签,如果标签为零,则表示我们正在检测背景并可以安全的忽略它(9,10行)。

否则,我们为当前区域构建一个掩码。

下面我提供了一个GIF动画,它可视化地构建了每个标签的labelMask。使用这个动画来帮助你了解如何访问和显示每个单独的组件:

305158fa-cf69-11eb-9e57-12bb97331649.gif

然后第15行对labelMask中的非零像素进行计数。如果numPixels超过了一个预先定义的阈值(在本例中,总数为300像素),那么我们认为这个斑点“足够大”,并将其添加到掩膜中。

输出掩模如下图:

注意,所有小的斑点都被过滤掉了,只有大的斑点被保留了下来。

最后一步是在我们的图像上绘制标记的斑点:

# find the contours in the mask, then sort them from left to# rightcnts = cv2.findContours(mask.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)cnts = imutils.grab_contours(cnts)cnts = contours.sort_contours(cnts)[0]# loop over the contoursfor (i, c) in enumerate(cnts): # draw the bright spot on the image (x, y, w, h) = cv2.boundingRect(c) ((cX, cY), radius) = cv2.minEnclosingCircle(c) cv2.circle(image, (int(cX), int(cY)), int(radius), (0, 0, 255), 3) cv2.putText(image, “#{}”.format(i + 1), (x, y - 15), cv2.FONT_HERSHEY_SIMPLEX, 0.45, (0, 0, 255), 2)# show the output imagecv2.imshow(“Image”, image)cv2.waitKey(0)

首先,我们需要检测掩模图像中的轮廓,然后按从左到右排序(3-7行)。

一旦我们的轮廓已经排序,我们可以对它们进行单独的循环处理(第8行)。

对于这些轮廓线,我们将计算出代表明亮区域的最小包围圆(第12行)。

然后,我们唯一地标记该区域并在图像上绘制它(第12-15行)。

最后,第17行和第18行显示了输出结果。

运行程序,你应该会看到以下输出图像:

请注意,每个灯泡都被独特地标上了圆圈,圆圈围绕着每个单独的明亮区域。

责任编辑:lq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OpenCV
    +关注

    关注

    33

    文章

    652

    浏览量

    45086
  • 检测图像
    +关注

    关注

    0

    文章

    3

    浏览量

    5618
  • python
    +关注

    关注

    58

    文章

    4885

    浏览量

    90307

原文标题:使用Python和OpenCV检测图像中的多个亮点

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    求助,关于imx95的图像问题求解

    我在完整模式下为 imx95 创建了图像。 获得映像后,为了将映像刷新到 SD卡,我运行了: sudo dd
    发表于 04-22 11:05

    多通道兼容图像采集卡:机搞定多路图像信号处理

    在工业自动化、安防监控、智能检测、医疗影像等领域,随着应用场景的不断升级,单路图像采集已无法满足多路信号同步接入、实时处理的重要需求。多通道兼容图像采集卡应运而生,以“机集成、多路协同”为重要优势
    的头像 发表于 03-19 14:17 213次阅读
    多通道兼容<b class='flag-5'>图像</b>采集卡:<b class='flag-5'>一</b>机搞定多路<b class='flag-5'>图像</b>信号处理

    如何修复液晶面板制程中的亮点缺陷?

    、引言 液晶面板(TFT-LCD)制程涵盖Array、Cell、Module等多道精密工序,受异物污染、工艺偏差、静电损伤等因素影响,极易产生亮点、暗点、线路缺陷等问题,其中亮点缺陷是制约产品良率
    的头像 发表于 01-22 16:45 276次阅读
    如何修复液晶面板制程中的<b class='flag-5'>亮点</b>缺陷?

    高速工业图像采集卡:PCIe/网口双接口选型与特性解析

    ​随着机器视觉技术的日益成熟,工业自动化水平的不断提高,高速工业图像采集卡作为机器视觉系统的关键组成部分,扮演着越来越重要的角色。它负责将工业相机捕捉到的图像数据以极快的速度传输到计算机,为后续
    的头像 发表于 12-30 17:01 766次阅读
    高速工业<b class='flag-5'>图像</b>采集卡:PCIe/网口双接口选型与特性解析

    请问CW32微控制器有哪些特色功能或技术亮点

    CW32微控制器有哪些特色功能或技术亮点
    发表于 12-16 08:08

    onsemi AR0235CS图像传感器:工业视觉领域的新选择

    在电子工程领域,图像传感器是许多应用的核心组件,特别是在工业检测、扫描等需要捕捉清晰图像的场景中。今天我们要介绍的是安森美(onsemi)的款高性能图像传感器——AR0235CS,它
    的头像 发表于 11-26 15:36 723次阅读
    onsemi AR0235CS<b class='flag-5'>图像</b>传感器:工业视觉领域的新选择

    工业图像采集卡:机器视觉的“信号中枢”

    、定位:连接物理视界与数字大脑的重要枢纽在工业自动化生产线的精密检测工位上,当高速相机捕捉到PCB板的微米级纹路时,常被忽视却至关重要的硬件正在完成关键转换——工业图像采集卡如同
    的头像 发表于 11-06 15:09 412次阅读
    工业<b class='flag-5'>图像</b>采集卡:机器视觉的“信号中枢”

    FPGA的图像采集过程

    次性读取所有128寄存器的值并存入RAM,RAM的存入地址即为寄存器的地址。读写模式选择通过开关控制,在写操作完成后会产生同步信号
    发表于 10-29 06:23

    使用Otsu阈值算法将灰度图像二值化

    Otsu 算法是由日本学者OTSU于1979年提出的种对图像进行二值化的高效算法,又称“最大类间方差法”。当我们对图象进行二值化操作的时候,需要根据
    发表于 10-28 06:49

    关于电压保持电路的分析

    各位大佬好,我遇到这样电路,作用是给板卡提供电压保持,板卡断电后,维持板卡定时间的运行,这个电路中选用的超级电容是2.7V/10F 关于这个电路我有些问题没搞懂,请教各位大佬。
    发表于 09-15 17:39

    寻找设计多功能控温仪的工程师,期待合作共赢​

    各位论坛的朋友,大家好!​ 我目前有关于多功能控温仪设计的项目,急需专业的工程师或者设计团队来完成设计开发,在此真诚地发帖寻找合适的合作伙伴。​ 这款多功能控温仪的应用场景主要为低
    发表于 07-25 11:24

    工业相机图像采集卡:技术剖析、应用场景与未来发展

    CameraLink、CoaXPress、GigEVision等,高效、稳定地将数据传输到计算机进行后续图像处理、分析和应用。本文将深入剖析工业相机图像采集卡的技术细
    的头像 发表于 05-28 13:49 916次阅读
    工业相机<b class='flag-5'>图像</b>采集卡:技术剖析、应用场景与未来发展

    基于LockAI视觉识别模块:C++多模板匹配

    多模板匹配是种在图像中同时寻找多个模板的技术。通过对每个模板逐进行匹配,找到与输入图像最相似的区域,并标记出匹配度最高的结果。本实验提供
    的头像 发表于 05-14 14:37 1752次阅读
    基于LockAI视觉识别模块:C++多模板匹配

    图像采集卡和显卡是样的吗?从核心差异、工作原理与应用全解析

    不少朋友在做系统集成或设备选型时,经常会问看似简单但又容易混淆的问题:图像采集卡和显卡样吗?一个是“采图”的,
    的头像 发表于 05-14 09:52 1785次阅读
    <b class='flag-5'>图像</b>采集卡和显卡是<b class='flag-5'>一</b>样的吗?从核心差异、工作原理与应用全解析

    基于LockAI视觉识别模块:C++模板匹配

    模板匹配是种在图像寻找特定模式的技术。它通过滑动模板图像(较小的
    的头像 发表于 05-13 14:14 906次阅读
    基于LockAI视觉识别模块:C++模板匹配