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

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

3天内不再提示

OpenCV4中联通组件分析的一个缺点

OpenCV学堂 来源:OpenCV学堂 2024-01-04 15:51 次阅读

数据集

最近别人给了我一个生物数据分割的标注数据集,让我训练一下,发现这个数据集比较诡异,图像格式是tif的16位的浮点数,OpenCV读取过来要显示得先转换,然后它的Mask是PNG的带透明通道,最坑人的是Mask标记都是1、只有相互连接的对象标记才相互不同。官方给出的原始图像解析以后是这样:

0c28d444-aad6-11ee-8b88-92fbcf53809c.png

OpenCV读取显示图像样本

OpenCV读取tif格式16位的图像在于imread的第二个参数,默认情况下会转换为BGR彩色八位字节的图像,如果这样就是一片漆黑;这里选择为-1表示不改变原图像的通道数据信息,这样就可以读取原始图像数据了,然后转换为32f的,再归一化到0~1之间,直接显示即可。代码如下:

importnumpyasnp
img=cv.imread("D:/11111.tif",-1)#uint16
img_16=img.astype(np.float32)
cv.normalize(img_16,img_16,0,1,cv.NORM_MINMAX)
img_16.astype(np.float32)
result=np.uint8(img_16*255)
cv.imwrite('D:/tensor_cv2.jpg',result)

0c32a4a6-aad6-11ee-8b88-92fbcf53809c.jpg

OpenCV读取显示Mask图像

Mask图像是带透明通道的RGBA的图像,但是实际上所有的标注信息只存在于red通道中,所以读取以后,直接拆分通道,然后把red通道数据作为灰度图像处理,因为灰度值太低了,显示的时候我给扩大了点倍数,直接把灰度图像扔到联通组件扫描的函数中,然后就可以看到结果了。相关代码如下:

importnumpyasnp
img=cv.imread("D:/11111.png")#uint16
bb,gg,rr=cv.split(img)
h,w,c=img.shape
print(img.shape,img.dtype)
numOfcons,labels=cv.connectedComponents(rr)

colors=[]
foriinrange(numOfcons):
b=np.random.randint(0,256)
g=np.random.randint(0,256)
r=np.random.randint(0,256)
colors.append((b,g,r))

colors[0]=(0,0,0)
image=np.zeros((h,w,3),dtype=np.uint8)
forrowinrange(h):
forcolinrange(w):
image[row,col]=colors[labels[row,col]]

cv.imshow("coloredlabels",image)
cv.imwrite("D:/opencv_labels.png",image)
cv.imshow("bgr",rr*100)
cv.waitKey(0)
cv.destroyAllWindows()

标记的Mask信息原图

0c3b9584-aad6-11ee-8b88-92fbcf53809c.jpg

基于联通组件查找以后的彩色显示(注意白色粘连)

0c49233e-aad6-11ee-8b88-92fbcf53809c.png

对比与解决

对比之后发现,OpenCV中联通组件扫描以后把不同标签的样本粘连在一起了,这个是因为OpenCV寻找联通组件只分为两种值0为背景,非0就作为前景,不做灰度级别区分的联通域识别,所以导致了粘连。这个时候,只要用skimage库的函数来替换OpenCV的联通组件扫描就可以避免粘连了,因为skimage库的联通组件扫描支持独立标签分级。代码演示如下:

importskimage.io
importskimage.morphology

#Loadoneimageafteruncompressingmasks.zip
gt=skimage.io.imread("D:/11111.png")

#Keepfirstchannelonly
gt=gt[:,:,0]

#Labelindependentconnectedcomponents
gt=skimage.morphology.label(gt)
colors=[]
foriinrange(150):
b=np.random.randint(0,256)
g=np.random.randint(0,256)
r=np.random.randint(0,256)
colors.append((b,g,r))
colors[0]=(0,0,0)
h,w=gt.shape
image=np.zeros((h,w,3),dtype=np.uint8)
forrowinrange(h):
forcolinrange(w):
image[row,col]=colors[gt[row,col]]

#Displayimageoruseasneeded
cv.imshow("coloredlabels",image)
cv.imwrite("D:/labels.png",image)
cv.waitKey(0)
cv.destroyAllWindows()
运行结果对比 - 可以发现白色区域没有粘连,成功分割!

0c4f4af2-aad6-11ee-8b88-92fbcf53809c.png

希望OpenCV迟早有一天可以支持这种分级的区域联通组件扫描算法







审核编辑:刘清

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

    关注

    26

    文章

    1225

    浏览量

    55824
  • OpenCV
    +关注

    关注

    29

    文章

    611

    浏览量

    40784

原文标题:新知 | OpenCV4中联通组件分析的一个缺点

文章出处:【微信号:CVSCHOOL,微信公众号:OpenCV学堂】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    OpenCV4.8 CUDA编程代码教程

    OpenCV4支持通过GPU实现CUDA加速执行,实现对OpenCV图像处理程序的加速运行,当前支持加速的模块包括如下。
    的头像 发表于 12-05 09:56 452次阅读
    <b class='flag-5'>OpenCV</b>4.8 CUDA编程代码教程

    Nanopc-t4 + tengine = mobilenet_ssd帧仅需200ms

    相关配置(由于距离写帖子的时间有些久,加之自己动手搞过些其他配置,所以不太清楚哪些配置是原本带有的,第四项应该是原本镜像系统没有配置的,不过最好看看吧。5、去掉cmake下面的opencv4配置mv
    发表于 09-14 14:20

    OpenCV自带组件HighGUI怎么使用?

    将介绍OpenCV自带组件HighGUI的简单使用。当我们在测试算法,查看算法效果的时候,需要用到可视化,动态调参的界面,也可能需要监听鼠标,键盘等的动作,这时,HighGUI就发挥大作用了,HighGUI作为
    发表于 11-05 06:54

    Vivado HLS实现OpenCV图像处理的设计流程与分析

    opencv2.0之前,opencv是完全用C实现的,但是,IplImage类型与CvMat类型的关系类似于面向对象的继承关系。实际上,CvMat之上还有
    发表于 07-08 08:30

    实现PC和单片机通信的方法步骤

    效果视频 基于opencv4和yolo,实现PC和单片机通信,控制步进电机捕获目标PC端代码//#include "opencv2/core.hpp"#include "
    发表于 12-03 07:21

    如何使用PythonOpenCV模块检测颜色

    在这篇文章,我们将看到如何使用 Python OpenCV 模块检测颜色,进入这个领域的第步就是安装下面提到的模块。pip install
    发表于 02-09 16:31

    鲁班猫0 -安装opencv

    ON要等那么会儿,结事之后就可以make了:sudo make -j4这里就是漫长的等待,我这里大约两小时结束结束后执行sudo make install配置#opencv4.pc
    发表于 04-09 13:29

    【飞凌RK3588开发板试用】安装OPENCV

    下载源码:Releases - OpenCV我这里是下载最新版本4.7.0编译源码1、把下载的源码包上传到开发板,解压后在opencv下面新建build文件压,并进行入build文
    发表于 04-09 20:23

    Yuzuki Lizard 全志V851S开发板 –编译 OPENCV 4.5.4

    ,设定) 到此编译成功 6、编译出来的文件 动态库文件 /usr/local/lib/ 文件库 /usr/local/include/opencv4/ 注意下面步骤成功编译出来的固件,是不含动态库
    发表于 05-08 09:22

    CMake在Linux 6.1.1-1.0.0搜索包opencv损坏了吗?

    我有 cmake 项目,使用以下 CMake 语句从 Yocto Linux SDK 导入 OpenCV 库: find_package (需要OpenCV ) 在
    发表于 05-09 11:32

    中联通公开招募3G电子渠道合作企业

    中联通公开招募3G电子渠道合作企业      12月11日消息,中国联通12月10日发布公告,开始面向社会公开招募社会电子渠
    发表于 12-11 09:42 508次阅读

    基于opencv4和Yolo-Fastest,实现PC和单片机通信,控制步进电机捕获目标

    效果视频 基于opencv4和yolo,实现PC和单片机通信,控制步进电机捕获目标
    发表于 11-23 17:36 15次下载
    基于<b class='flag-5'>opencv4</b>和Yolo-Fastest,实现PC和单片机通信,控制步进电机捕获目标

    如何在Raspberry Pi 3上安装OpenCV4

    今天我们将学习如何在 Raspberry Pi 3 上安装 OpenCV4 库,以便我们可以将其用于计算机视觉应用程序。这将允许 OpenCV 在像 Pi 这样的便携式设备上运行,从而打开许多可能性的大门。所以让我们开始吧
    的头像 发表于 09-08 16:09 1369次阅读
    如何在Raspberry Pi 3上安装<b class='flag-5'>OpenCV4</b>库

    学习OpenCV4的系统化路线图

    OpenCV4发布测试版本开始,作者就一直关注!根据自己近十年图像处理OpenCV开发相关工作经验,花了七个月的时间,针对OpenCV4、精心选择OpenCV中常用模块与知识点,构建
    的头像 发表于 07-05 11:30 369次阅读
    学习<b class='flag-5'>OpenCV4</b>的系统化路线图

    OpenCV4图像分析之BLOB特征分析

    BLOB是图像中灰度块的一种专业称呼,更加变通一点的可以说它跟我们前面二值图像分析联通组件类似,通过特征提取实现常见的各种灰度BLOB对象组件检测与分离。使用该检测器的时候,可以根据
    的头像 发表于 12-28 12:28 387次阅读
    <b class='flag-5'>OpenCV4</b>图像<b class='flag-5'>分析</b>之BLOB特征<b class='flag-5'>分析</b>