k-means算法的matlab代码实现_基于MATLAB的腐蚀膨胀算法实现

80984af33e1cffd3b837e6e15a26c0de.png

本篇文章要分享的是基于MATLAB的腐蚀膨胀算法实现,腐蚀膨胀是形态学图像处理的基础,腐蚀在二值图像的基础上做“收缩”或“细化”操作,膨胀在二值图像的基础上做“加长”或“变粗”的操作。

  什么是二值图像呢?把一幅图片看做成一个二维的数组,那么二值图像是一个只有0和1的逻辑数组,我们前面Sobel边缘检测后的图像输出边缘效果,设置个阈值,大于阈值输出为1,小于阈值输出为0,最后输出就是一幅二维图像了。

腐蚀

  腐蚀是一种消除边界点,使边界向内部收缩的过程。可以用来消除小且无意义的物体。用3X3的结构元素,扫描图像的每一个像素,用结构元素与其覆盖的二值图像做“与”操作,如果都为1,结果图像的该像素为1。否则为0。结果会使二值图像小一圈。

  有一个形象的比喻来可以说明该运算,用0表示蛀虫,1表示大米。蛀虫腐蚀大米的过程便是腐蚀运算,

4f41c29e16236194ca1afcd34c5d2cb9.png

腐蚀

如图所示,对于一个像素矩阵而言,只要有蛀虫(0)的存在,大米(1)就会被腐蚀掉了,即使只存在一个蛀虫(0),但是还是会被蛀虫腐蚀完毕,最后一幅图上面由于没有蛀虫(0)所以大米完好无损。

关于算法的实现,可以用下式子来表示,即3x3像素的运算:

P = P11 & P12 & P13 & P21 & P22 & P23 & P31 & P32 & P33

在FPGA中,为了通过面积去换速度,我们将上式改变如下:                       

P1 = P11 & P12 & P13

P2 = P21 & P22 & P23

P3 = P31 & P32 & P33

P = P1 & P2 & P3

MATLAB中可以直接写一个按位或运算。

膨胀

  膨胀是将与物体接触的所有背景点合并到该物体中,使边界向外部扩张的过程。可以用来填补物体中的空洞。用3X3的结构元素,扫描图像的每一个像素,用结构元素与其覆盖的二值图像做“与”操作,如果都为0,结果图像的该像素为0,。否则为1。结果使二值图像扩大一圈。

  先腐蚀后膨胀的过程称为开运算。用来消除小物体、在纤细点处分离物体、平滑较大物体的边界的同时并不明显的改变其面积。先膨胀后腐蚀的过程称为比运算,用来填充物体内细小空间、连接邻近物体、平滑其边界的同时并不明显改变其面积。

  膨胀算法用最简单的比喻来描述:0表示害虫,1表示青蛙,青蛙吃了害虫表示膨胀运算,我们用3*3像素阵列来解释:

fef4641964352a1532c2d9599649acb5.png

膨胀

如图所示,图左只有害虫(0),所以害虫都活着,中间那个图,虽然只有一个害虫,但是还是会被青蛙全部吃掉,最右边的那幅图,都是青蛙,所以青蛙始终是青蛙。

关于算法的实现,可以用下式子来表示,即3x3像素的运算:

P = P11 | P12 | P13 | P21 | P22 | P23 | P31 | P32 | P33

在HDL中,为了通过面积去换速度,我们将上式改变如下:                             

P1 = P11 | P12 | P13

P2 = P21 | P22 | P23

P3 = P31 | P32 | P33

P = P1 | P2 | P3

MATLAB中可以直接写一个按位与运算。

开运算闭运算

  先腐蚀后膨胀叫开运算,开运算的作用是清除图像边缘周围非边缘的细小的点。先膨胀后腐蚀为闭运算,闭运算的作用是清除图像内部的空洞,

  如果我们的目标物体外面有很多无关的小区域,就用开运算去除掉;如果物体内部有很多小黑洞,就用闭运算填充掉。

MATLAB逻辑运算函数

bitand(), 对十进制数进行逐位逻辑与运算:先将十进制数转换成二进制数,然后逐位与运算,其运算结果转换为十进制。

bitor(), 对十进制数进行逐位逻辑或运算:先将十进制数转换成二进制数,然后逐位与运算,其运算结果转换为十进制。

MATLAB代码实现

需要了解代码的私聊我,发你。(这就不再复制了)

处理后结果对比

为了可以清晰的看到图像边缘的变化,我们把黑色作为背景,白色作为边缘。

94f75d1ea1d297b04a62be1de5362f48.png

Sobel边缘检测后的lena

f7ec60aa27f74e8303c26d61fb2166f2.png

腐蚀后的lena

0b08e8672559115f1cd7bf8a599d5327.png

膨胀后的lena

fceb7032132fe4dbf264d58e1e65408f.png

先腐蚀后膨胀开运算lena

9c3076c0d078d728314382e2b817d925.png

先膨胀后腐蚀闭运算lena

  从上面两幅图可以看出,腐蚀后的图像边缘明显变细,消除了更多假边缘,在腐蚀基础上使用膨胀算法的lena将腐蚀后的边缘扩大、加粗,这样看起来更清楚。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
k-means聚类算法是一种常用的无监督学习算法,用于将数据集划分为k个不同的类别。这个算法的目标是最小化每个数据点与其所属类别的质心之间的距离的平方和。下面是k-means算法Matlab实现的简要介绍[^1][^2]: 1. 首先,选择k个初始质心。可以随机选择k个数据点作为初始质心,或者使用更高级的初始化方法,如k-means++算法。 2. 对于每个数据点,计算其与每个质心之间的距离,并将其分配给距离最近的质心所代表的类别。 3. 更新每个类别的质心,将其设置为该类别中所有数据点的平均值。 4. 重复步骤2和步骤3,直到质心不再发生变化或达到预定的迭代次数。 下面是一个使用Matlab实现k-means算法的示例代码: ```matlab % 设置参数 k = 3; % 类别数 max_iters = 10; % 最大迭代次数 % 加载数据集 load('data.mat'); % 假设数据集保存在data.mat文件中 % 初始化质心 centroids = initCentroids(X, k); % 使用自定义的初始化函数initCentroids % 迭代更新质心和类别 for iter = 1:max_iters % 分配数据点到最近的质心 idx = findClosestCentroids(X, centroids); % 使用自定义的函数findClosestCentroids % 更新质心 centroids = computeCentroids(X, idx, k); % 使用自定义的函数computeCentroids end % 自定义的初始化函数 function centroids = initCentroids(X, k) % 随机选择k个数据点作为初始质心 randidx = randperm(size(X, 1)); centroids = X(randidx(1:k), :); end % 自定义的函数,用于计算每个数据点与质心之间的距离并分配类别 function idx = findClosestCentroids(X, centroids) K = size(centroids, 1); idx = zeros(size(X,1), 1); for i = 1:size(X, 1) min_dist = inf; for j = 1:K dist = sum((X(i,:) - centroids(j,:)).^2); if dist < min_dist min_dist = dist; idx(i) = j; end end end end % 自定义的函数,用于更新质心 function centroids = computeCentroids(X, idx, K) [m n] = size(X); centroids = zeros(K, n); for i = 1:K centroids(i,:) = mean(X(idx == i,:)); end end ``` 这是一个简单的k-means算法Matlab实现,你可以根据自己的数据集和需求进行相应的修改和调整。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值