首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

分水岭算法及案例

分水岭算法 Watershed Algorithm(分水岭算法),顾名思义,就是根据分水岭的构成来考虑图像的分割。现实中我们可以或者说可以想象有山有湖的景象,那么那一定是水绕 山,山围水的情形。...当然在需要的时候,要人工构筑分水岭,以防集水盆之间的互相穿透。而区分高山(plateaus)与水的界线,以及湖与湖之间的间隔或 都是连通的关系,就是我们可爱的分水岭(watershed)。...分水岭分割算法把图像看成一幅“地形图”, 其中亮度比较强的区域像素值较大,而比较暗的区域像素值较小,通过寻找“汇水盆地”和“分水岭界限”,对图像进行分割。...(7) 最终如何用前景标记和背景标记实现标记分水岭分割?...这个可以通过计算bw的距离变换的分水岭变换来实现, % 然后寻找结果的分水岭脊线(DL==0)。D = bwdist(BW)计算二值图像BW的欧几里得矩阵。

65110

分水岭变换图像分割接触对象

分水岭变换 % 使用分水岭变换分割来分离接触对象 % 分水岭变换分割将图像中的“分水岭流域”和“分水岭脊线” % 视为一个亮像素高、暗像素低的曲面 % 如果可以识别或“标记”前景对象和背景位置、效果更好...% 分水岭变换分割遵循以下基本程序: %% 步骤1: 读取图片、转为灰度图 rgb = imread('pears.png'); I = rgb2gray(rgb); imshow(I) ?...% 不能用分水岭变换直接在梯度幅度上分割图像 L = watershed(gmag); Lrgb = label2rgb(L); imshow(Lrgb) title('直接在梯度幅度上分割图像')...% 理想情况下,我们不希望背景标记太靠近我们要分割的对象的边缘 % 通过计算前景的“阴影骨架”来“细化”背景(欧氏距离变换bwdist) % 可以通过计算距离变换的分水岭变换、然后寻找结果的分水岭线来实现...D = bwdist(bw); DL = watershed(D); bgm = DL == 0; imshow(bgm) title('分水岭线') ?

98820

图像分割之分水岭算法

使用C++、opencv进行分水岭分割图像 分水岭概念是以对图像进行三维可视化处理为基础的:其中两个是坐标,另一个是灰度级。...这些大坝的边界对应于分水岭的分割线。所以,它们是由分水岭算法提取出来的(连续的)边界线。...动图演示了整个分水岭算法的过程: 算法实现: 算法应用: 分水岭算法对噪声等影响非常敏感。...为了解决过度分割的问题,可以使用基于标记(mark)图像的分水岭算法,就是通过先验知识,来指导分水岭算法,以便获得更好的图像分段效果。...】- 退出程序\n\n\n"); } 源图像: 进行标记的图像: 分水岭算法得到的图像: 分割后图像: 代码的第108-122行是对opencv分水岭算法生成的结果图进行分析,目前对watershed

1.6K30

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

分水岭算法原理 2. 距离变换 3. opencv有关函数的用法 二、基于距离的分水岭分割流程 三、python代码实现 一、 原理 1....分水岭算法原理 任何一副灰度图像都可以被看成拓扑平面,灰度值高的区域可以被看成是山峰,灰度值低的区域可以被看成是山谷。我们向每一个山谷中灌不同颜色的水。...我们构建好的堤坝就是对图像的分割,这就是分水岭算法的背后原理。 OpenCV采用了基于掩模的分水岭算法,在这种算法中我们要设置那些山谷点会汇合,那些不会。...然后实施分水岭算法。每一次灌水,我们的标签就会被更新,当两个不同颜色的标签相遇时就构建堤坝,直到将所有山峰淹没,最后我们得到的边界对象(堤坝)的值为 -1。 2....转成灰度图像 二值化处理、形态学操作 距离变换 寻找种子、生成marker 实施分水岭算法、输出分割后的图像 三、python代码实现 # -*- coding: UTF-8 -*- """ @公众号

1.9K20

Android OpenCV(四十二):图像分割(分水岭法)

分水岭分水岭算法介绍,下面这位知乎博主已经讲得非常详细了,详情请自行查阅。...https://zhuanlan.zhihu.com/p/67741538 分水岭算法的整个过程: 把梯度图像中的所有像素按照灰度值进行分类,并设定一个测地距离阈值。...随着水平面越来越高,会设置更多更高的大坝,直到灰度值的最大值,所有区域都在分水岭线上相遇,这些大坝就对整个图像像素的进行了分区。 ?...不从最小值开始增长,可以将相对较高的灰度值像素作为起始点(需要用户手动标记),从标记处开始进行淹没,则很多小区域都会被合并为一个区域,这被称为基于图像标记(mark)的分水岭算法 API public...标记是分水岭过程中的“种子”。标记图像中所有没有被标记的像素值为0。在输出图像中,两个区域之间的分割线用-1表示。

88120

OpenCV基于标记控制的分水岭分割算法演示

常见图像分割算法之一 分水岭分割 图像分水岭分割是基于图像形态学的语义分割算法,常见的算法实现主要基于标记的分水岭分割方法,图示如下: ?...算法就是要找到分水岭线,对图像完成分水岭分割,这个在生物与医学图像处理中特别有用。...主要原因是常见的分水岭算法是基于灰度基本与距离变换结果寻找分割线,很容易导致过度分割,过度分割的合并有比较复杂,而基于标记(marker)的分水岭分割算法就比较稳定,一般情况下不会产生过度分割问题。...图像分水岭分割流程 正常对于输入图像首先需要转换为灰度图像、然后二值图像,通过距离变换生成标记,然后使用分水岭变换算法得到输出结果,可视化输出即可。...分水岭分割结果 ?

2.3K20

C++ OpenCV图像分割之分水岭分割

前言 前面我们说了两种分割方法,这一章我们说图像的分水岭分割。...分水岭算法是一种图像区域分割法,在分割的过程中,它会把跟临近像素间的相似性作为重要的参考依据,从而将在空间位置上相近并且灰度值相近的像素点互相连接起来构成一个封闭的轮廓,封闭性是分水岭算法的一个重要特征...算法会根据markers传入的轮廓作为种子(也就是所谓的注水点),对图像上其他的像素点根据分水岭算法规则进行判断,并对每个像素点的区域归属进行划定,直到处理完图像上所有像素点。...---- 上面的API函数非常简单,但是参数里面第二个说了在需要进行轮廓的提取,所以说在做分水岭操作之前,我们要结合以前学过的知识对图像进行先一步的处理如 均值滤波----变成灰度图---二值化--...7.将生成的markers进行分水岭转换 ? 8.生成随机颜色,并填充颜色,在新的图像中画出来后看一下分割的效果 ? ? 9.显示最后填充的图片并打印出一共多少个 ?

2.3K10
领券