部分图像分割的方法(matlab)

合集下载

浅析基于MATLAB的图像分割方法

浅析基于MATLAB的图像分割方法

像 中要提取 的 目标 物 与其背 景在灰 度特 性上 的差异 ,通过
设 置 合 适 的 灰 度 门 限 ( 值 ) 将 图 像 的 灰 度 划 分 为 两 个 或 阈 , 多个 灰 度 区 间 , 以确 定 有 意 义 的 区 域 或 分 割 物 体 的边 界 。 阈 值 分 割 常 用 于 图像 的 二 值 化 处 理 , 选 择 一 个 合 适 的 阈值 , 即 通 过 判 断 图像 中 的 每 一 个 像 素 点 的 特 征 属 性 是 否 满 足 阂 值
绍, 重点对 边缘检 测技 术的几 种常用 算 子进行 比较分 析 , 并 通 过 MAT AB 数 字 图 像 处 理 工 具 编 程 实 现 基 于 各 算 子 的 L
边缘 检测 。
2 .基 于 阈 值 的 图像 分 割 阈 值 分 割 『 一 种 常 用 的 图 像 分 割 方 法 , 主 要 利 用 图 2 1 是 它
阈值 分 割 。
对 于 图像 函数 r ,)它 在像 素 点( ,) 的梯 度 是一 ( y, x xy处
个矢量 , 义为: 定
Gx) [ ] E’=票 fy (]
梯度有 两个重要特性 : () 度 的方 向 为 函 数 f ,) 大 变 化 率 的 方 向 ; 1梯 ( Y最 x
划分成若 干个这样 的有意义 区域 的过程 , 各区域是具有 相近
特 性 的像 素 的连 通 集 合 。
始 区域 , 根据给定 的均 匀性检测准 则进行分裂 和合并这些 区
域 , 步 改 善 区 域 划 分 的 性 能 , 至 最 后 将 图 像 分 成 数 量 最 逐 直 少 的均匀区域 为止。 4 .基 于 边 缘 检 测 的 图 像 分 割 及 算 子 分 析 边 缘 是 指 图 像 中像 素 灰 度 值 或 色 彩 等 属 性 有 突 变 的 像 素 的集 合 , 存 在 于 目标 与 背 景 、 它 目标 与 目标 之 间 , 含 了丰 包 富 的 图 像 信 息 。基 于 边 缘 检 测 [ 图 像 分 割 正 是利 用 边 缘 的 2 ] 的 灰 度 变 化 特 性 , 过 考 察 图 像 中各 像 素 在 某 个 邻 域 内 灰 度 的 通

Matlab中的图像分割与边缘检测方法

Matlab中的图像分割与边缘检测方法

Matlab中的图像分割与边缘检测方法引言图像处理是一门研究如何对数字图像进行处理、分析、改进和理解的学科。

图像分割与边缘检测在图像处理中占据着重要的地位。

图像分割是将图像划分为多个具有语义意义的区域或对象的过程,而边缘检测则是找到图像中不连续的区域边界。

Matlab作为一种强大的软件工具,提供了丰富的图像处理函数和工具箱,本文将探讨在Matlab中应用的图像分割与边缘检测方法。

一、图像分割方法1. 基于阈值的分割基于阈值的分割是一种简单但有效的方法。

该方法将图像像素的灰度值与预设的阈值进行比较,根据比较结果将像素分配到不同的区域。

在Matlab中,可以使用imbinarize和graythresh函数来实现基于阈值的分割。

2. 区域增长法区域增长法基于像素之间的相似性来进行分割。

该方法从种子像素开始,通过判断邻域像素与种子像素的相似度来不断扩展区域。

在Matlab中,可以使用imsegf和regiongrowing函数来实现区域增长法。

3. 聚类方法聚类方法将图像像素分为多个类别,每个类别代表一个区域。

该方法通常使用聚类算法,比如k-means算法或者模糊c-均值算法。

在Matlab中,可以使用kmeans和fcm函数来实现聚类方法。

4. 模型驱动法模型驱动法基于数学模型来描述图像中的区域。

该方法通过定义一个能够衡量图像中区域特征的能量函数,并通过优化算法来最小化能量函数,从而得到分割结果。

在Matlab中,可以使用activecontour和chanvese函数来实现模型驱动法。

二、边缘检测方法1. Sobel算子Sobel算子是一种经典的边缘检测算子。

其基本思想是通过计算像素与其周围像素之间的差异来检测边缘。

在Matlab中,可以使用imgradient和imgradientxy函数来实现Sobel算子。

2. Canny算子Canny算子是一种广泛使用的边缘检测算子。

它利用高斯平滑、梯度计算、非极大值抑制和双阈值法来检测边缘。

(完整版)matlab图像分割毕业设计

(完整版)matlab图像分割毕业设计

数字图像的多分辨率分析处理方法研究—基于小波变换的医学图像分割的研究电信学院电子信息工程专业摘要图像分割是一种重要的图像分析技术.对图像分割的研究一直是图像技术研究中的热点和焦点。

医学图像分割是图像分割的一个重要应用领域,也是一个经典难题,至今已有上千种分割方法,既有经典的方法也有结合新兴理论的方法.本论文首先介绍了双峰法以及最大类方差自动阈值法,然后重点介绍一种基于小波变换的图像分割方法,该方法先对图像的灰度直方图进行小波多尺度变换,然后从较大的尺度系数到较小的尺度系数逐步定位出灰度阈值.最后,对这几种算法的分割效果进行了比较。

实验结果表明,本设计能够实时稳定的对目标分割提取,分割效果良好。

医学图像分割是医学图像处理中的一个经典难题.图像分割能够自动或半自动描绘出医学图像中的解剖结构和其它感兴趣的区域,从而有助于医学诊断。

关键词:小波变换;图像分割;阈值The image segmentation is an important technology of image processing. It is still a hot point and focus of image processing。

Medical image segmentation is an important application in the field of image segmentation, and it is also a classical difficult problem for researchers。

Thousands of methods have been put forward to medical image segmentation. Some use classical methods and others use new methods.In this paper , first introduced the petronas method and maximum between class variance 。

matlab阈值分割

matlab阈值分割

matlab阈值分割Matlab阈值分割是一种图像处理技术,它可以将一幅图像分为几个不同的部分。

它使用一个阈值来区分不同的图像像素,并将像素分组到相应的部分中。

Matlab阈值分割的原理是:从图像中计算一个阈值T,如果像素值大于T,则将其分配到第一部分,如果像素值小于等于T,则将其分配到第二部分。

Matlab阈值分割通常使用两种方法:绝对值分割和相对值分割。

绝对值分割是一种普遍使用的阈值分割技术,它将像素的灰度值作为T的参考,并以此来划分像素。

在这种情况下,阈值T必须手动设置,因此,如果要进行阈值分割,需要让用户输入一个阈值,然后根据用户输入的阈值进行分割。

另一种常用的Matlab阈值分割是相对值分割。

它使用图像中像素灰度值的相对大小作为阈值T,并以此来划分像素。

相对值分割可以很好地处理复杂的图像,因为它可以根据图像的特征自动计算一个合适的阈值。

Matlab阈值分割可以用来识别图像中的特定对象,例如,可以使用Matlab阈值分割来识别图像中的人脸、地面、植被等。

此外,它还可以用来检测图像中的异常像素,例如,可以使用Matlab阈值分割来检测图像中的噪声、瑕疵或其他异常像素。

Matlab阈值分割也可以用来实现图像分割,即将一幅图像分割成不同的部分,例如,可以使用Matlab阈值分割将图像分割成天空、海洋、山脉和沙漠等不同的部分。

此外,Matlab阈值分割还可以用来实现图像去噪,即将图像中的噪声去除,以获得更清晰的图像。

另外,Matlab阈值分割也可以用来实现图像压缩,即将图像中的像素压缩到更小的大小,以节省存储空间。

总之,Matlab阈值分割是一种有用的图像处理技术,可以用来实现图像分割、去噪和压缩等多种功能。

它可以使用绝对值分割和相对值分割来实现不同的功能,因此,它可以满足不同用途的需求。

如何使用MATLAB进行图像分割与识别

如何使用MATLAB进行图像分割与识别

如何使用MATLAB进行图像分割与识别图像分割与图像识别是计算机视觉领域中的重要研究方向,其中MATLAB作为一种常用的编程工具,在图像处理和机器学习方面有着广泛的应用。

本文将介绍如何使用MATLAB进行图像分割与识别,并分析其中的关键技术和算法。

一、图像分割图像分割是将一副图像分割成多个具有独立语义的区域的过程。

图像分割可以帮助我们理解图像中的目标和背景,并为图像后续处理提供基础。

在MATLAB中,有许多图像分割算法可供选择,其中比较常用的是基于聚类的方法和基于边缘检测的方法。

聚类方法是将像素点根据它们在颜色、纹理或其他特征空间中的相似度进行分组。

在MATLAB中,可以使用k-means聚类算法进行图像分割。

通过设置合适的聚类中心数量,可以将图像分成不同的区域。

边缘检测方法是通过检测图像中的边缘来进行分割。

MATLAB提供了多种边缘检测算法,如Sobel算子和Canny算子。

这些算法可以帮助我们找到图像中的边缘,并将图像分割成不同的区域。

二、图像识别图像识别是通过计算机算法对图像中的目标进行自动识别和分类的过程。

MATLAB中有多种图像识别算法可供选择,其中比较常用的是基于特征提取和机器学习的方法。

特征提取是图像识别的关键步骤之一。

在MATLAB中,可以使用SIFT、SURF和HOG等算法提取图像的特征。

通过提取图像的关键点和描述子,可以将图像转换成一组可用于识别的特征向量。

机器学习是图像识别的核心技术之一。

在MATLAB中,可以使用支持向量机(SVM)、卷积神经网络(CNN)和深度学习等算法进行图像识别。

这些算法可以对提取的特征进行训练和分类,并实现目标的自动识别和分类。

三、MATLAB图像处理工具箱MATLAB提供了丰富的图像处理工具箱,包含了大量处理图像的函数和工具。

使用MATLAB图像处理工具箱,可以很方便地进行图像处理和分析。

例如,可以使用MATLAB图像处理工具箱中的imread函数读取图像,并使用imresize函数修改图像的尺寸。

matlab目标与背景的分割与提取

matlab目标与背景的分割与提取

matlab目标与背景的分割与提取"Matlab目标与背景的分割与提取"目标与背景的分割与提取是计算机视觉和图像处理中的重要课题,它涉及到将图像中的目标与背景进行有效的分离与提取。

Matlab 作为一种强大的编程工具,为我们提供了丰富多样的图像处理函数和工具箱,可以帮助我们实现目标与背景的分割与提取任务。

本文将一步一步地介绍如何使用Matlab来进行目标与背景的分割与提取。

首先,我们需要加载并显示图像。

在Matlab中,可以使用imread 函数来读取图像数据,并使用imshow函数来显示图像。

例如,下面的代码将加载并显示一张名为"image.jpg"的图像:matlabimage = imread('image.jpg');imshow(image);接下来,我们可以使用Matlab的图像处理函数来对图像进行预处理,以便更好地进行目标与背景的分割与提取。

常见的预处理操作包括图像灰度化、图像平滑和图像增强等。

首先,我们可以使用rgb2gray函数将彩色图像转换为灰度图像。

灰度图像只包含一个亮度通道,而彩色图像包含红、绿、蓝三个通道,因此灰度图像更便于对比度和亮度的调整。

例如,下面的代码将将图像转换为灰度图像:matlabgrayImage = rgb2gray(image);然后,我们可以使用图像平滑操作来减少图像中的噪声,以便更准确地进行目标与背景的分割与提取。

常见的图像平滑算法有高斯滤波和中值滤波。

例如,下面的代码将使用高斯滤波对灰度图像进行平滑处理:matlabsmoothImage = imgaussfilt(grayImage);imshow(smoothImage);最后,我们可以使用图像增强操作来增强图像的对比度和清晰度,以便更好地进行目标与背景的分割与提取。

常见的图像增强算法有直方图均衡化和自适应直方图均衡化等。

例如,下面的代码将使用直方图均衡化对平滑后的图像进行增强处理:matlabenhancedImage = histeq(smoothImage);imshow(enhancedImage);在图像预处理完成后,我们可以使用Matlab的图像分割算法来实现目标与背景的分割与提取。

图像分割Matlab代码

图像分割Matlab代码

图像分割Matlab代码图像分割Matlab代码 (一)图像边缘检测不同方法比较将Roberts、Sobel、Prewitt、LOG、Canny算子等经典图像分割算法对灰度图像分割的结果进行比较。

Matlab 代码如下:%% 图像边缘检测不同方法比较% Roberts、Sobel、Prewitt、LOG、Canny算子对灰度图像分割的结果比较clc;clear all;close all;f=imread('8_256_lena.bmp','bmp'); subplot(2,3,1);subimage(f);title('原始图像');[g, t]=edge(f,'roberts',[],'both'); subplot(2,3,2);subimage(g);title('Roberts算子对图像分割的结果');[g, t]=edge(f,'sobel',[],'both'); subplot(2,3,3);subimage(g);title('Sobel算子对图像分割的结果');[g, t]=edge(f,'prewitt',[],'both'); subplot(2,3,4);subimage(g);title('Prewitt算子对图像分割的结果');[g, t]=edge(f,'log'); subplot(2,3,5);subimage(g);title('LOG算子对图像分割的结果'); [g, t]=edge(f,'canny'); subplot(2,3,6);subimage(g);title('Canny算子对图像分割的结果');(二)区域生长法分割图像区域生长法分割图像,matlab代码如下: %% 区域生长法分割图像clc;clear all;close all;f=imread('rice_1.bmp','bmp'); % f=imread('rice.png','png'); %f=imread('8_256_lena.bmp','bmp'); subplot(1,2,1);subimage(f);%选择三个种子点seedx=[63, 10, 85];%rice图的生长点seedy=[30, 56, 60];% seedx=[100, 150, 227];%lena图的生长点% seedy=[56, 130, 189];hold onplot(seedx,seedy,'gs','linewidth',1); title('原始图像及种子点位置');f=double(f);markerim=f==f(seedy(1),seedx(1)); for i=2:length(seedx)markerim=markerim|(f==f(seedy(i),seedx(i)));end%3个种子点区域的阈值thresh=[12,6,12];maskim= zeros(size(f));for i=1:length(seedx)g=abs(f-f(seedy(i),seedx(i)))<=thresh(i);maskim=maskim|g;end[g,nr]=bwlabel(imreconstruct(markerim,maskim),8); % g=mat2gray(g);%以灰度级显示,注释掉此行以二值图像显示subplot(1,2,2);subimage(g);title('三个种子点区域生长分割结果');(三)迭代阈值选择法二值化图像与Otsu阈值选择法二值化图像比较迭代阈值选择法二值化图像与Otsu阈值选择法二值化图像比较的matlab代码如下:%% 迭代阈值选择法二值化图像与Otsu阈值选择法二值化图像比较 clc;clear all;close all;f=imread('8_256_lena.bmp','bmp'); subplot(2,2,1);subimage(f);title('原始图像');f=double(f);T=(min(f(:))+max(f(:)))/2; done=false;i=0;while ~doner1=find(f<=T);r2=find(f>T);Tnew=(mean(f(r1))+mean(f(r2)))/2;done=abs(Tnew-T)<1;T=Tnew;i=i+1;endf(r1)=0;f(r2)=1;subplot(2,2,2);subimage(f);title('迭代阈值二值化图像图像');f=imread('8_256_lena.bmp','bmp');subplot(2,2,3);subimage(f);title('原始图像');T=graythresh(f);g=im2bw(f,T);subplot(2,2,4);subimage(g);title('Otsu方法二值化图像');。

在Matlab中实现医学图像分割和医学图像配准的方法

在Matlab中实现医学图像分割和医学图像配准的方法

在Matlab中实现医学图像分割和医学图像配准的方法医学图像处理在现代医学中起着重要的作用,它可以帮助医生更好地了解人体的结构和病变情况。

其中,医学图像分割和医学图像配准是两个常用的图像处理任务。

本文将介绍如何使用Matlab实现这两个任务的方法。

一、医学图像分割医学图像分割是将医学图像中感兴趣的区域从背景中分离出来的过程。

这对于病灶的检测和定位非常重要。

在Matlab中,有多种方法可以实现医学图像分割,如基于阈值的分割、基于区域的分割和基于边缘的分割等。

1. 基于阈值的分割基于阈值的分割是医学图像分割中最简单的方法之一。

它将图像中的像素根据亮度和颜色等特征进行分类。

在Matlab中,可以使用imbinarize函数实现阈值分割。

通过调整阈值的大小,可以得到不同的分割结果。

然而,这种方法对于复杂的图像可能效果不佳。

2. 基于区域的分割基于区域的分割是将图像中的像素分成若干区域,并根据相似性准则将它们合并或进一步细分的方法。

在Matlab中,可以使用regionprops函数计算各个区域的特征,并根据这些特征对区域进行分类和合并。

这种方法通常适用于异质性较小的图像。

3. 基于边缘的分割基于边缘的分割是通过检测图像中的边缘信息来实现分割的方法。

在Matlab中,可以使用边缘检测算法(如Canny算子)来提取图像中的边缘信息,并通过边缘连接或边缘跟踪来实现分割。

这种方法对于图像中有明显边缘的情况效果较好。

二、医学图像配准医学图像配准是将多个医学图像的位置和方向相对一致的过程。

它在医学影像的比较、融合和后续处理等方面具有重要的应用。

在Matlab中,有多种方法可以实现医学图像配准,如基于特征的配准、基于互信息的配准和基于形变场的配准等。

1. 基于特征的配准基于特征的配准是通过提取图像中的一些特征点或特征区域,并通过计算它们之间的相似性来实现配准的方法。

在Matlab中,可以使用SURF算法或SIFT算法来提取图像的特征,并通过RANSAC算法等方法来计算配准的变换矩阵。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

大津法:function y1=OTSU(image,th_set)image=imread('color1.bmp');gray=rgb2gray(image);%原图像的灰度图low_high=stretchlim(gray);%增强图像,似乎也不是一定需要gray=imadjust(gray,low_high,[]);% subplot(224);imshow(gray);title('after adjust');count=imhist(gray);[r,t]=size(gray);n=r*t;l=256;count=count/n;%各级灰度出现的概率for i=2:lif count(i)~=0st=i-1;breakendend%以上循环语句实现寻找出现概率不为0的最小灰度值for i=l:-1:1if count(i)~=0;nd=i-1;breakendend%实现找出出现概率不为0的最大灰度值f=count(st+1:nd+1);p=st;q=nd-st;%p和分别是灰度的起始和结束值u=0;for i=1:q;u=u+f(i)*(p+i-1);ua(i)=u;end%计算图像的平均灰度值for i=1:q;w(i)=sum(f(1:i));end%计算出选择不同k的时候,A区域的概率d=(u*w-ua).^2./(w.*(1-w));%求出不同k值时类间方差[y,tp]=max(d);%求出最大方差对应的灰度级th=tp+p;if th<th_setth=tp+p;elseth=th_set; %根据具体情况适当修正门限endy1=zeros(r,t);for i=1:rfor j=1:tx1(i,j)=double(gray(i,j));endendfor i=1:rfor j=1:tif (x1(i,j)>th)y1(i,j)=x1(i,j);elsey1(i,j)=0;endendend%上面一段代码实现分割% figure,imshow(y1);% title('灰度门限分割的图像');程序二:clc; clear;cd 'D:\My Documents\MATLAB' time = now;I = imread('qr4.bmp');figure(1),imshow(I),title('p1_1.bmp'); % show the pictureI2 = rgb2gray(I);figure(2),imshow(I2),title('I2.bmp'); %ÖÐÖµÂ˲¨J = medfilt2(I2); figure(3),imshow(J);imwrite(J,'J.bmp'); [M N] = size(J);J1 = J(1:M/2,1:fix(N/2)); J2 = J(1:M/2,fix(N/2)+1:N); J3 = J(M/2+1:M, 1:fix( N/2)); J4 = J(M/2+1:M, fix(N/2)+1:N); % figure(4), img = J1;T1 = test_gray2bw( img ); % figure(5), img = J2;T2 = test_gray2bw( img ); % figure(6), img = J3;T3 = test_gray2bw( img ); % figure(7), img = J4;T4 = test_gray2bw( img ); T = [T1,T2;T3,T4]; figure,imshow(T)% T1 = edge(T,'sobel'); % figure,imshow(T1); % BW = edge(T,'sobel'); % f igure,imshow(BW);function [bw_img] = test_gray2bw( img ) %大津法[row_img col_img ] = size( img ) all_pix = row_img * col_img% get probability of each pixel(ÏñËØ). count_pix = zeros(1,256) % pro_pix = []for i = 1 : 1 : row_img for j = 1 : 1 : col_imgcount_pix(1,img(i,j)+1) = count_pix(1,img(i,j)+1) + 1 %ͳ¼Æ´ÎÊý end en dpro_pix = count_pix / all_pix% choose k value; max_kesi = -1 T = 0for k = 1 : 1 :while( i <= k )wa = wa + pro_pix(1,i+1) %ǰk¸öi£¬Ã¿¸öÏñËØµÄ»Ò¶È¸ÅÂÊ£¬¸ÅÂÊºÍ ua = ua + i * pro_pix(1,i+1) i = i + 1 endif ( wa == 0.0 ) continue; elseua = ua / wa endub = 0 wb = 0 i = k + 1while( i <= 255 )wb = wb + pro_pix( 1 , i + 1 )ub = ub + i * pro_pix( 1 , i + 1 ) i = i + 1 endif ( wb == 0.0 ) continue; elseub = ub / wb endu = wa * ua + wb * ub% kesi = wa * ( ua - u ) * ( ua - u ) + wb * ( ub - u ) * ( ub -u ) % %ÉÏÏÂÕâÁ½¸ö¹«Ê½Êǵȼ۵Äkesi = wa * wb * (ua - ub)^2; if( kesi > max_kesi ) max_kesi = kesi T = k end end% get bw img bw_img = imgfor i = 1 : 1 : row_img for j = 1 : 1 : col_img if ( img(i,j) <= T ) bw_img(i,j) = 0elsebw_img( i,j ) = 255 end end endimwrite(bw_img,'bw_img.bmp')figure(),imshow('bw_img.bmp')%,title('bw_ing')区域生长法:close all;clear all;clc;A=dicomread('im.dcm');%读入图像(医学CT图像)% seed=[200,220];%选择起始位置thresh=6.3;%相似性选择阈值%A=rgb2gray(A0);%A=A0;%灰度化%A=imadjust(A,[min(min(double(A)))/255,max(max(double(A)))/255],[]); figure,imshow(A,[]);A=double(A); %将图像灰度化[y,x]=getpts; %获得区域生长起始点x1=round(x); %横坐标取整y1=round(y); %纵坐标取整seed=A(x1,y1);B=A;%将A赋予B[r,c]=size(B);%图像尺寸r为行数,c为列数n=r*c;%计算图像所包含点的个数pixel_seed=seed;%原图起始点灰度值q=[x1 y1];%q用来装载起始位置top=1;%循环判断flagM=zeros(r,c);%建立一个与原图形同等大小的矩阵M(x1,y1)=1;%将起始点赋为1,其余为0count=1;%计数器while top~=0%也可以写成top!=0 循环结束条件r1=q(1,1);%起始点行位置c1=q(1,2);%起始点列位置p=A(r1,c1);%起始点灰度值dge=0;for i=-1:1%周围点的循环判断for j=-1:1if r1+i<=r&r1+i>0&c1+j<=c&c1+j>0%保证在点周围范围之内if abs(A(r1+i,c1+j)-p)<=thresh&M(r1+i,c1+j)~=1%判定条件?top=top+1;%满足判定条件top加1,top为多少,则q的行数有多少行q(top,:)=[r1+i c1+j];%将满足判定条件的周围点的位置赋予q,q记载了满足判定的每一外点M(r1+i,c1+j)=1;%满足判定条件将M中相对应的点赋为1count=count+1;%统计满足判定条件的点个数,其实与top此时的值一样B(r1+i,c1+j)=1;%满足判定条件将B中相对应的点赋为1endif M(r1+i,c1+j)==0;%如果M中相对应点的值为0将dge赋为1,也是说这几个点不满足条件dge=1;%将dge赋为1endelsedge=1;%点在图像外将dge赋为1endendend%此时对周围几点判断完毕,在点在图像外或不满足判定条件则将dge赋为1,满足条件dge为0if dge~=1%最后判断的周围点(i=1,j=1)是否满足条件,如dge=0,满足。

dge=1,不满足。

B(r1,c1)=A(x1,y1);%将原图像起始位置灰度值赋予Bendif count>=n%如果满足判定条件的点个数大于等于ntop=1;endq=q(2:top,:);top=top-1;end%subplot(1,2,1),figure,imshow(M,'displayrange',[]);figure,%subplot(1,2,2),imshow(B,[]);%最后是做的一个例子迭代法:clear all;I=imread('rice.png');ZMAX=max(max(I)); %取出最大灰度值ZMIN=min(min(I)); %取出最小灰度值TK=(ZMAX+ZMIN)/2;bcal=1;ISIZE=size(I); %读出图像大小while(bcal)iForeground=0; %定义前景和背景数iBackground=0;ForegroundSum=0; %定义前景和背景灰度总和BackgroundSum=0;for i=1:ISIZE(1) %循环部分求解读下%for j=1:ISIZE(2)tmp=I(i,j);if(tmp>=TK)iForeground=iForeground+1;ForegroundSum=ForegroundSum+double(tmp); %前景灰度值elseiBackground=iBackground+1;BackgroundSum=BackgroundSum+double(tmp);endendendZO=ForegroundSum/iForeground; %计算前景和背景的平均值ZB=BackgroundSum/iBackground;TKTmp=uint8(ZO+ZB)/2;if(TKTmp==TK )bcal=0;elseTK=TKTmp;end %当阈值不再变化的时候,说明迭代结束enddisp(strcat('迭代后的阀值:',num2str(double(TK)))); %显示迭代计算后阈值TKnewI=im2bw(I,double(TK)/255);subplot(1,2,1);imshow(I);xlabel('(a)原始图像');subplot(1,2,2);imshow(newI);xlabel('(b)迭代法分割效果图') %程序OK 没问题。

相关文档
最新文档