Python opencv图像处理基础总结(七) 基于分水岭算法的图像分割

简介: 任何一副灰度图像都可以被看成拓扑平面,灰度值高的区域可以被看成是山峰,灰度值低的区域可以被看成是山谷。我们向每一个山谷中灌不同颜色的水。随着水的位的升高,不同山谷的水就会相遇汇合,为了防止不同山谷的水汇合,我们需要在水汇合的地方构建起堤坝。不停地灌水,不停地构建堤坝知道所有的山峰都被水淹没。我们构建好的堤坝就是对图像的分割

一、 原理


1. 分水岭算法原理


  • 任何一副灰度图像都可以被看成拓扑平面,灰度值高的区域可以被看成是山峰,灰度值低的区域可以被看成是山谷。我们向每一个山谷中灌不同颜色的水。随着水的位的升高,不同山谷的水就会相遇汇合,为了防止不同山谷的水汇合,我们需要在水汇合的地方构建起堤坝。不停地灌水,不停地构建堤坝知道所有的山峰都被水淹没。我们构建好的堤坝就是对图像的分割,这就是分水岭算法的背后原理。
  • OpenCV采用了基于掩模的分水岭算法,在这种算法中我们要设置那些山谷点会汇合,那些不会。这是一种交互式的图像分割,我们要做的就是给我们已知的对象打上不同的标签。如果某个区域肯定是前景或对象,就使用某个颜色(或灰度值)标签标记它。如果某个区域肯定不是对象而是背景就使用另外一个颜色标签标记。而剩下的不能确定是前景还是背景的区域就用 0 标记,这就是我们的标签。然后实施分水岭算法。每一次灌水,我们的标签就会被更新,当两个不同颜色的标签相遇时就构建堤坝,直到将所有山峰淹没,最后我们得到的边界对象(堤坝)的值为 -1。


2. 距离变换


  • 距离变换的基本含义是计算一个图像中非零像素点到最近的零像素点的距离,也就是到零像素点的最短距离。
  • 最常见的距离变换算法就是通过连续的腐蚀操作来实现,腐蚀操作的停止条件是所有前景像素都被完全。
  • 腐蚀。这样根据腐蚀的先后顺序,我们就得到各个前景像素点到前景中心骨架像素点的距离。
  • 根据各个像素点的距离值,设置为不同的灰度值。这样就完成了二值图像的距离变换。


3. opencv有关函数的用法


cv2.distanceTransform(src, distanceType, maskSize, dst=None, dstType=None)


  • src:输入二值图像
  • distanceType:计算距离的方式
  • maskSize:蒙板尺寸


cv2.connectedComponents(image, labels=None, connectivity=None, ltype=None)


  • image:输入8位单通道图像
  • labels:输出标签地图
  • connectivity:连通性,默认8,还可以取4。
  • Itype:输出标签类型 ,默认 CV_32S, 还可以取CV_16U。


cv2.watershed(image, markers)


  • image:输入图像
  • markers:标记


二、基于距离的分水岭分割流程



  • 输入图像,有噪声的话,先进行去噪。
  • 转成灰度图像
  • 二值化处理、形态学操作
  • 距离变换
  • 寻找种子、生成marker
  • 实施分水岭算法、输出分割后的图像


三、python代码实现


# -*- coding: UTF-8 -*-"""@公众号      : AI庭云君@Author     : 叶庭云@CSDN       : https://yetingyun.blog.csdn.net/"""importcv2ascvimportnumpyasnpdefwatershed_algorithm(image):
# 边缘保留滤波EPF  去噪blur=cv.pyrMeanShiftFiltering(image,sp=10,sr=100)
# 转成灰度图像gray=cv.cvtColor(blur, cv.COLOR_BGR2GRAY)
# 得到二值图像   自适应阈值ret, binary=cv.threshold(gray, 0, 255, cv.THRESH_BINARY|cv.THRESH_OTSU)
cv.imshow('binary image', binary)
# 形态学操作   获取结构元素  开操作kernel=cv.getStructuringElement(cv.MORPH_RECT, (3, 3))
opening=cv.morphologyEx(binary, cv.MORPH_OPEN, kernel=kernel, iterations=2)
# 确定区域sure_bg=cv.dilate(opening, kernel, iterations=3)
# cv.imshow('mor-opt', sure_bg)# 距离变换dist=cv.distanceTransform(opening, cv.DIST_L2, 3)
dist_out=cv.normalize(dist, 0, 1.0, cv.NORM_MINMAX)
# cv.imshow('distance-', dist_out * 50)ret, surface=cv.threshold(dist_out, dist_out.max() *0.6, 255, cv.THRESH_BINARY)
# cv.imshow('surface-markers', surface)surface_fg=np.uint8(surface)    # 转成8位整型unkonown=cv.subtract(sure_bg, surface_fg)        # 找到位置区域# Marker labellingret, markers=cv.connectedComponents(surface_fg)  # 连通区域print(ret)
# 分水岭变换# Add one to all labels so that sure background is not 0, but 1markers=markers+1# Now, mark the region of unknown with zeromarkers[unkonown==255] =0# 实施分水岭算法了。标签图像将会被修改,边界区域的标记将变为 -1markers=cv.watershed(image, markers=markers)
image[markers==-1] = [0, 0, 255]      # 被标记的区域   设为红色cv.imshow('result', image)
src=cv.imread(r'./test/042.png')
src=cv.resize(src, None, fx=0.5, fy=0.5)
cv.imshow('input image', src)
watershed_algorithm(src)
cv.waitKey(0)
cv.destroyAllWindows()


运行效果如下:








目录
相关文章
|
1天前
|
数据采集 算法 数据可视化
python实现时序平滑算法SG滤波器
python实现时序平滑算法SG滤波器
|
1天前
|
计算机视觉 Python
【Python实战】——Python+Opencv是实现车牌自动识别
【Python实战】——Python+Opencv是实现车牌自动识别
|
6天前
|
机器学习/深度学习 自然语言处理 算法
Python遗传算法GA对长短期记忆LSTM深度学习模型超参数调优分析司机数据|附数据代码
Python遗传算法GA对长短期记忆LSTM深度学习模型超参数调优分析司机数据|附数据代码
|
6天前
|
算法 机器人 Python
Python实现教程:平面最短路径算法
Python实现教程:平面最短路径算法
13 1
|
6天前
|
算法 Serverless 计算机视觉
使用OpenCV和Python进行极线校正
使用OpenCV和Python进行极线校正
12 1
|
12天前
|
机器学习/深度学习 运维 算法
【Python机器学习专栏】异常检测算法在Python中的实践
【4月更文挑战第30天】本文介绍了异常检测的重要性和在不同领域的应用,如欺诈检测和网络安全。文章概述了四种常见异常检测算法:基于统计、距离、密度和模型的方法。在Python实践中,使用scikit-learn库展示了如何实现这些算法,包括正态分布拟合、K-means聚类、局部异常因子(LOF)和孤立森林(Isolation Forest)。通过计算概率密度、距离、LOF值和数据点的平均路径长度来识别异常值。
|
12天前
|
机器学习/深度学习 数据可视化 算法
【Python机器学习专栏】t-SNE算法在数据可视化中的应用
【4月更文挑战第30天】t-SNE算法是用于高维数据可视化的非线性降维技术,通过最小化Kullback-Leibler散度在低维空间保持数据点间关系。其特点包括:高维到二维/三维映射、保留局部结构、无需预定义簇数量,但计算成本高。Python中可使用`scikit-learn`的`TSNE`类实现,结合`matplotlib`进行可视化。尽管计算昂贵,t-SNE在揭示复杂数据集结构上极具价值。
|
12天前
|
机器学习/深度学习 算法 数据挖掘
【Python机器学习专栏】关联规则学习:Apriori算法详解
【4月更文挑战第30天】Apriori算法是一种用于关联规则学习的经典算法,尤其适用于购物篮分析,以发现商品间的购买关联。该算法基于支持度和置信度指标,通过迭代生成频繁项集并提取满足阈值的规则。Python中可借助mlxtend库实现Apriori,例如处理购物篮数据,设置支持度和置信度阈值,找出相关规则。
|
12天前
|
机器学习/深度学习 算法 数据挖掘
【Python机器学习专栏】层次聚类算法的原理与应用
【4月更文挑战第30天】层次聚类是数据挖掘中的聚类技术,无需预设簇数量,能生成数据的层次结构。分为凝聚(自下而上)和分裂(自上而下)两类,常用凝聚层次聚类有最短/最长距离、群集平均和Ward方法。优点是自动确定簇数、提供层次结构,适合小到中型数据集;缺点是计算成本高、过程不可逆且对异常值敏感。在Python中可使用`scipy.cluster.hierarchy`进行实现。尽管有局限,层次聚类仍是各领域强大的分析工具。
|
12天前
|
机器学习/深度学习 算法 数据挖掘
【Python 机器学习专栏】K-means 聚类算法在 Python 中的实现
【4月更文挑战第30天】K-means 是一种常见的聚类算法,用于将数据集划分为 K 个簇。其基本流程包括初始化簇中心、分配数据点、更新簇中心并重复此过程直到收敛。在 Python 中实现 K-means 包括数据准备、定义距离函数、初始化、迭代和输出结果。虽然算法简单高效,但它需要预先设定 K 值,且对初始点选择敏感,可能陷入局部最优。广泛应用在市场分析、图像分割等场景。理解原理与实现对应用聚类分析至关重要。

热门文章

最新文章