基于MATLAB的图像处理的课程设计.docx
- 文档编号:5933513
- 上传时间:2023-01-02
- 格式:DOCX
- 页数:30
- 大小:232.14KB
基于MATLAB的图像处理的课程设计.docx
《基于MATLAB的图像处理的课程设计.docx》由会员分享,可在线阅读,更多相关《基于MATLAB的图像处理的课程设计.docx(30页珍藏版)》请在冰豆网上搜索。
基于MATLAB的图像处理的课程设计
基于MATLAB的图像处理的课程设计
…………………..………………….…………3
………………….………………………….….3
………………..……………………….……3
…………………………………………….………..3
……………….…………………………….……….4
……………………………………………..…….…56.1、文件……………….………………………………….……….56.1.1、打开………..…………………………………….…………56.1.2、保存…………………………..………………….…………56.1.3、退出……………………..……………………………….…56.2、编辑…………………………..…………………………………56.2.1、灰度………………………..………………….……………56.2.2、亮度………………………..………………….……………66.2.3、截图…………………………..……………….……………76.2.4、缩放…………………………..…………….………………76.3、旋转…………………………………..…………………………96.3.1、上下翻转…………………….…………….………………96.3.2、左右翻转………………….…………….…………………96.3.3任意角度翻转…………………………….…………………96.4、噪声………………………………..…………..………………106.5、滤波……………………………………..………..……………106.6、直方图统计……………………………………………………116.7、频谱分析………………………………………..…..…………126.7.1、频谱图…………………………………………….……126.7.2、通过高通滤波器……………………….……………….126.7.3、通过低通滤波器………………………………..……….136.8、灰度图像处理………………………………………….…….146.8.1、二值图像………………………………………………...146.8.2、创建索引图像……………………………………….…..146.9、颜色模型转换……………………………..…..……………146.10、操作界面设计……………………………………..…………15
………………….……………………15
…………………………….………………………16
…………………………….………………………17
………………………….………………………………18
1
MATLAB
数字图像处理技术是20世纪60年代发展起来的一门新兴学科,随着图像处
理理论和方法的进一步完善,使得数字图像处理技术在各个领域得到了广泛应
用,并显示出广阔的应用前景。
MATLAB既是一种直观、高效的计算机语言,同
时又是一个科学计算平台。
它为数据分析和数据可视化、算法和应用程序开发提
供了最核心的数学和高级图形工具。
根据它提供的500多个数学和工程函数,工程技术人员和科学工作者可以在它的集成环境中交互或编程以完成各自的计算。
MATLAB中集成了功能强大的图像处理工具箱。
由于MATLAB语言的语法特征与C语言极为相似,而且更加简单,更加符合科技人员对数学表达式的书写格
式,而且这种语言可移植性好、可扩展性强,再加上其中有丰富的图像处理函数,
所以MATLAB在图像处理的应用中具有很大的优势。
MATLAB,数字图像处理
课程设计目的
综合运用MATLAB工具箱实现图像处理的GUI程序设计。
课程设计要求
1)熟悉和掌握MATLAB程序设计方法
2)掌握MATLABGUI程序设计
3)学习和熟悉MATLAB图像处理工具箱
4)学会运用MATLAB工具箱对图像进行处理和分析
课程设计的内容
学习MATLABGUI程序设计,利用MATLAB图像处理工具箱,设计和实现自己的Photoshop。
要求:
按照软件工程方法,根据需求进行程序的功能分析和界面设计,给出设
计详细说明。
然后按照自己拟定的功能要求进行程序设计和调试。
以下几点是程序必须实现的功能。
1)图像的读取和保存。
2)设计图形用户界面,让用户能够对图像进行任意的亮度和对比度变化调整,显示和
对比变换前后的图像。
3)设计图形用户界面,让用户能够用鼠标选取图像感兴趣区域,显示和保存该选择区
域。
4)编写程序通过最近邻插值和双线性插值等算法将用户所选取的图像区域进行放大和
缩小整数倍的操作,并保存,比较几种插值的效果。
5)图像直方图统计和直方图均衡,要求显示直方图统计,比较直方图均衡后的效果。
6)能对图像加入各种噪声,并通过几种滤波算法实现去噪并显示结果。
比较去噪效果。
题目分析
信息化社会中,计算机在各种信息处理中发挥着重要的作用。
我们可以借助计算机,
对数字图像进行处理,以达到不同的效果。
根据题目的要求,除了实现要求的功能外,还有
2
很多的功能需要用到。
(1)、将一个RGB图像转换为灰度图像。
(2)、可以对图像做各种变换,如旋转等。
(3)、有时并不需要图像显示其细节部分,只要其轮廓,这时候不要很高的灰度级。
可以把
图像转换为二值图像,进行图像腐蚀,或是创建索引图像等。
(4)、分析一个图像的频谱特征,利用傅里叶变换,将图像从空间域变换到频域,然后进行
各种处理,经过高通滤波器或是低通滤波器。
(5)、为了科学地定量描述和使用颜色,人们提出了各种颜色模型,按用途可分为三类:
计
算颜色模型,视觉颜色模型和工业颜色模型。
有时为了不同的需要,要对颜色模型进行转换。
总体设计
由于要实现的功能并不是很多,所以在排版的过程中,把各个功能都安排
在目录栏上,整体安排如下图所示:
同时在调节亮度时,虽然可以同对话框的形式输入调节的比例系数,但是
这样效果不好了,不容易调节,因此这里考虑用滚动条来调节。
因此,总体的
设计界面如下图所示:
3
具体设计
6.1、文件
6.1.1、打开
为了让使用者更方便的使用,所以在设计的时候,通过对话框的形式来选择
文件,选择uigetfile函数来实现,uigetfile函数显示一个打开文件对话框,该对
话框自动列出当前路径下的目录和文件,由于这个GUI程序的操作对象是图像文件,所以设置这里的缺省后缀名为“.bmp”。
Uigetfile函数的调用格式为[name,path]=yigetfile(…),在按下对话框中的执行按钮“打开”后,返回选择的文件名和路径,分别保存到“name”和“path”
中。
如果按下取消按钮或是发生错误,则返回值是0。
根据返回值的情况,如果是0,则弹出提示错误的对话框,否则,通过imread函数读出图像数据,把图像数据赋值给全局变量handles.img。
6.1.2、保存
同样也通过对话框的形式来保存图像数据,通过uigetfile函数选择文件名和路径,用getimage(gca)取出坐标2变换后的图像数据保存到变量i,最后用imwrite
函数,把数据i存到指定的文件。
6.1.3、退出
退出比较简单,程序如下所示:
clc;
closeall;
close(gcf);
6.2、编辑
6.2.1、灰度
由于RGB图像是三维图像,所以图像数据是一个三维数组,为了显示灰度
图像,把三维图像降为二维,可以只取其中的二维数据,实现方法程序为:
y=(handles.img(:
:
1));%当然也可以选择(:
:
2)或(:
:
3)••••
imshow(y);
但是这样的话,根据程序所选的不同,图像数据也不同,显示也就不一样。
另一种方法就是,运用rgb2gray函数实现彩色图像到灰度图像的转换。
程序
为:
y=rgb2gray(handles.img);•••••
imshow(y);
这个程序只能用于RGB图像转换灰度图像,当原始图像本来就是灰度图像
时,运行该程序时就会出错,但是使用者在使用时有时并不知道这些,为了使该
程序更加完善,应该在使用者原先图像时灰度图像时使用该功能时,应该要显示
提示类信息。
所以在开始时应该要有一个RGB图像或是灰度图像的判断过程。
完整的程序如下:
ifisrgb(handles.img)
y=rgb2gray(handles.img);•••••
imshow(y);
else
msgbox('这已经是灰度图像','转换失败');
end
4
如果原图是RGB,执行该操作的结果如下图:
如果原图本身已经是灰度图像了,执行该操作弹出如右图所示的提示对话框
6.2.2、亮度
用imadjust函数,其调用格式如下:
g=imadust(f,[low_inhigh_in],[low_outhigh_out]),gamma)
gamma表示映射性质,默认值是1表示线性映射。
由于该函数有五个参数需要输入,为了方便用户改变,
所以这里设计一个输入对话框,用户通过对话框把五个参数
赋值给[low_inhigh_in],[low_outhigh_out],gamma这五个参数,如下一组命令建立了如图所示的输入对话框:
prompt={'输入参数1','输入参数2','输入gamma'};
defans={'[00.7]','[01]','1'};
p=inputdlg(prompt,'输入参数',1,defans);
但是,这种方法并不能很好的让用户能够对图像进行任
意的亮度和对比度变化调整,有时并不事先知道参数的值要
多少,也不关心,而是任意调节的,直到满意为止。
所以应
该用滑动条来调节图像的亮度和对比度,这样更适合用户的使用习惯。
由于imadjust函数有五个参数,所以原则上需要设计五个滑动条来调节对比
度,这对用户来说显然比较麻烦,因此在设计的时候固定其中的三个参数,通过
调节两个参数的值来改变亮度和对比度。
[0handles.beta],[01],handles.gm,这里的变量handles.beta和handles.gm就
通过滑动条得到,滑动条设计如下图:
亮度调整的tag名为ld,取值范围0~1,gamma值的tag名为gamma,取值
范围为0~5。
获取滑动条参数的程序如下:
5
handles.beta=get(handles.ld,'value');
handles.gm=get(handles.gamma,'value');
执行该操作,调节滑动条到上图所示位置,结果如下图:
6.2.3、截图
在MATLAB中,用函数imcrop实现对图像的剪切操作。
该操作剪切的是图
像中的一个矩形子图,用户可以通过参数指定这个矩形四个顶点的坐标,也可以
交互地用鼠标选取这个矩形。
Imcrop函数的调用格式如下:
y=imcrop(handles.img);
不管handles.img是三维的还是二维数据,该函数都能进行操作。
下图就是
对三维图像的截图:
6.2.4、缩放
在MATLAB中,用函数imresize来实现对图像的放大或缩小。
插值方法可
选用三种方法,最近邻插值,双线性插值,双三次插值。
该函数的调用格式如下:
B=imresize(A,m,method)
其中:
参数method用于指定插值的方法,可选的值为“nearest”(最近邻法),“bilinear”
(双线性插值)、“bicubic”(双三次插值),缺省值为“nearest”。
B=imresizee(A.m,method)表示返回原图A的m倍放大图像(m小
于1时实际上是缩小);
下图就是采用邻近插值法的放大和缩小图像,参数值保持默认设置:
6
虽然处理后看不出放大的效果,这是由于坐标轴限制的原因,如果把处理后
的图片保存起来,再把处理后的文件打开,就可以看到比较明显的放大效果。
缩小后的结果如下:
7
6.3、旋转
6.3.1、上下翻转
函数flipud是实现一个二维矩阵的上下翻转,如a=[12;34],经过该函数处理后,原矩阵变为[34;12];所以利用该函数也可以对图像进行上下翻转处理,但由于该函数针对二维数据的处理,所以在写程序时,要
对RGB图像和灰度图像分开处理,这就要用到isrgb函数来判断,如果是灰度图像,则可以直接用这个函数进行处理,否则就要对RGB图像进行降维处理,
fork=1:
3
y(:
:
k)=flipud(x(:
:
k));
end
处理结果如图:
6.3.2、左右翻转
对图像的左右翻转也可以用fliplr函数来处理,同样的,也要对灰度和彩色
图像分开处理,处理结果如图:
6.3.3任意角度翻转
用函数imrotate来实现对图像的插值旋转。
该函数的调用格式如下:
B=imrotate(A,angle,method,’crop’)
其中,参数method用于指定插值的方法,可选的值可以有三种,分别为邻
近插值,双线性插值,双三次插值,缺省时为邻近插值,参数angle代表旋转的
角度。
8
一般来说,旋转后的图像会比原图大,用户可以指定“crop”参数对旋转后的图像进行剪切(取图像的中间部分),使返回的图像与原图大小相同。
执行结果
为:
6.4、噪声
经常用到的噪声有三种,高斯噪声,椒盐噪声,乘性噪声,可以通过以下三
个函数来实现:
y=imnoise(handles.img,'gaussian',p1,p2);%高斯噪声
y=imnoise(x,'salt&pepper',p1);%椒盐噪声
y=imnoise(handles.img,'speckle',p1);%乘性噪声
p1,p2的参数也通过输入对话框的形式得到,原图加入高斯噪声后结果如
下所示:
6.5、滤波
这里选择三种滤波方法,
k=medfilt2(handles.noise_img);%中值滤波
k=wiener2(handles.noise_img,[5,5]);%自适应滤波
k=filter2(fspecial('average',3),handles.noise_img)/255;%平滑滤波
同样的,这些函数也是针对二维数据,所以要先判断是彩色图像还是灰度图
像,然后分别进行处理,下面是对彩色图像的自适应滤波处理:
9
i=handles.noise_img;
ifisrgb(i)
a=handles.noise_img(:
:
1);
b=handles.noise_img(:
:
2);
c=handles.noise_img(:
:
3);
k(:
:
1)=wiener2(a,[5,5]);
k(:
:
2)=wiener2(b,[5,5]);
k(:
:
3)=wiener2(c,[5,5]);
imshow(k);
执行结果如图:
对其他方法的滤波程序也类似,由于把各个滤波方法放在一个选择框里,所
以程序要用以下的选择语句:
switchstr
case'中值滤波'
case'自适应滤波'
case'平滑滤波'
end
6.6、直方图统计
用imhist函数对图像数据进行直方图统计,
x=imhist(handles.img(:
:
1));
bar(horz,x);
其中,x矩阵的数据是0~255灰度值的统计个数,如果直接对x矩阵数据进
行图形图显示,由于有256个数据,在坐标系中就会很密集,为了更清楚的显示条形图,所以在程序设计时,把x数据进行部分提取,
x1=x(1:
10:
256);
horz=1:
10:
256;
bar(horz,x1);
除了显示数据的直方图统计外,还可以对图像进行均衡处理,所用到的函数
是histeq,这两个函数同样只使用于二维数据,所以也要对二维和三维数据分开
处理。
直方图显示和均衡后的图像分别如下图所示
10
6.7、频谱分析
6.7.1、频谱图
为了得到图像的频谱图,先要对数据进行傅里叶变换,用fft2函数对二维数据进行快速傅里叶变换,同时为了更好的观察频谱图,需要把fft2变换后的数据进行平移,利用fftshift函数,把快速傅里叶变换的DC组件移到光谱中心。
这样图像能量的低频成分将集中到频谱中心,图像上的边缘、线条细节信息等高频
成分将分散在图像频谱的边缘。
如下图所示:
6.7.2、通过高通滤波器
axes(handles.axes2);
x=(handles.img);
ifisrgb(x)
msgbox('这是彩色图像,不能通过高通滤波器','失败');
else
y1=imnoise(x,'gaussian');%加高斯噪声
f=double(y1);%数据类型转换
k=fft2(f);%傅立叶变换
g=fftshift(k);%转换数据矩阵
[M,N]=size(g);
nn=2;
d0=3;%截止频率为3
m=fix(M/2);n=fix(N/2);
fori=1:
M
11
forj=1:
N
d=sqrt((i-m)^2+(j-n)^2);%计算高通滤波器传递函数
ifd<=d0
h=0;
elseh=1;
end
result(i,j)=h*g(i,j);
end
end
result=ifftshift(result);
y2=ifft2(result);
y3=uint8(real(y2));
imshow(y3);
end
6.7.3、通过低通滤波器
axes(handles.axes2);
x=(handles.img);
ifisrgb(x)
msgbox('这是彩色图像,不能通过低通滤波器','失败');else
y1=imnoise(x,'salt&pepper');%叠加椒盐噪声f=double(y1);%数据类型转换,不支持图像的无符号整型的计算
g=fft2(f);%傅立叶变换g=fftshift(g);%转换数据矩阵[M,N]=size(g);
nn=2;%二阶巴特沃斯(Butterworth)低通滤波器
d0=10;%截止频率为10m=fix(M/2);n=fix(N/2);
fori=1:
M
forj=1:
N
d=sqrt((i-m)^2+(j-n)^2);
h=1/(1+0.414*(d/d0)^(2*nn));%计算低通滤波器传递函数
result(i,j)=h*g(i,j);
end
end
result=ifftshift(result);
y2=ifft2(result);
y3=uint8(real(y2));
imshow(y3);%显示滤波处理后的图像end
12
6.8、灰度图像处理
6.8.1、二值图像
用j=im2bw(x);来对灰度图像到二值图像的转换。
转换结果为:
6.8.2、创建索引图像
用X=grayslice(I,n)函数来实现,转换后得到的图像为:
6.9、颜色模型转换
下面是RGB颜色模型到HSV模型的转换程序:
axes(handles.axes2);
x=(handles.img);
ifisrgb(x)
HSV=rgb2hsv(x);
imshow(HSV);
else
msgbox('这是灰度图像,不能转换','转换失败');
end
转换后的结果为:
13
同样的,转化为ntsc和ycbcr模型,只要改为相应的函数即可。
函数如下:
rgb2ntsc(x);%rgb模型转ntsc模型
rgb2ycbcr(x);%rgb模型转ycbcr模型
6.10、操作界面设计
为了使整个操作界面更加的美观,对背景颜色和字体颜色进行设置。
程序调试及结果分析
在程序设计过程中,碰到很多的问题。
1、一个函数只能对灰度图像处理,不能对RGB图像处理,那么如何才
能对RGB图像处理呢?
这主要是对MATLAB函数的不够清楚,用到的很多函数是针对二维数据的,
而RGB图像的数据是一个三维矩阵,所以处理要与灰度图像不同,在开始的时
候,我认为应该找一个能够应用于三维矩阵的函数,结果却没找到,后来想到可
以把三维数据进行降维处理,同样使用二维的函数,只要是同样处理三次。
比如,
彩色图像的滤波处理,直方图均衡等。
2、同一个操作对灰度图像可以使用,当用户选择的是彩色图像时,该操
作就会出错?
这是由于设计程序时,本身程序是有针对性的,有些程序只能对灰度图像
有效,有些对彩色图像有效,但是用户并不清楚这些,所以在设计的过程中就
要考虑全面,要分开设计。
在本次课程设计中,我均对每个程序的开始时,用
ifisrgb(x)进行判断。
3、在没有加入噪声的情况下,点击“中值滤波”或是其它滤波,会提示
错误?
这是由于在滤波程序设计的过程中,开始用到的变量是handles.noise_img,
而这个变量是在加入噪声时候才定义的,所以在没有加入噪声的情况下,点击各
个滤波就会弹出变量没有定义的错误,解决方法就是在文件打开的时候就给定义
handles.noise_img=x。
4、本次设计存在一个比较大的问题,就是每次操作都是独立的,比如:
要对图像加入噪声,然后在此基础上进行亮度调整,截图,频谱分析
等等就不行。
我认为应该是整个程序设计过程中对变量的设置没有做好,应该每次操作
后,把处理后的数据保存在一个全局变量,这样还要对处理后的数据进行在处
理时,只要把这个全局变量作为原始数据带入就可。
14
心得体会
1、在这次课程设计过程中,感触很深,由于对MATLAB图像处理的函数
不熟悉,导致自己走了很多的弯路,比如在设计图像左转90度和右转90度时,由
于开始并不知道imrotate函数,只知道上下翻转flipud和左右翻转fliplr函数,想着
要怎么用这两个函数来实现左转和右转呢,如果当当只用矩阵转置的话,并不能
达到要求,后来想可以结合flipud和fliplr函数来实现,下面程序是实现左转90度:
axes(handles.axes2);
x=(handles.img);
ifisrgb(handles.img)
a=x(:
:
1);
b=x(:
:
2);
c=x(:
:
3);
e=a';
g=b';
f=c';
y(:
:
1)=e;
y(:
:
2)=g;
y(:
:
3)=f;
axes(handles.axes2);
fork=1:
3
f(:
:
k)=flipud(y(:
:
k));
end
imshow(f);
else
m=x';
y
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 MATLAB 图像 处理 课程设计