图像反转

 I=imread(\’nickyboom.jpg\’);

J=double(I);
J=-J+(256-1);                 %图像反转线性变换
H=uint8(J);
subplot(1,2,1),imshow(I);

subplot(1,2,2),imshow(H);




直方图均衡化

MATLAB 程序实现例如以下:

I=imread(\’nickyboom.jpg);

I=rgb2gray(I);

figure;

subplot(2,2,1);

imshow(I);

subplot(2,2,2);

imhist(I);

I1=histeq(I);

figure;

subplot(2,2,1);

imshow(I1);

subplot(2,2,2);

imhist(I1);




均值滤波器

I=imread(\’nickyboom.jpg\’);

subplot(231)

imshow(I)

title(\’原始图像\’)

I=rgb2gray(I);

I1=imnoise(I,\’salt & pepper\’,0.02);

subplot(232)

imshow(I1)

title(\’ 加入椒盐噪声的图像\’)

k1=filter2(fspecial(\’average\’,3),I1)/255;          %进行3*3模板平滑滤波

k2=filter2(fspecial(\’average\’,5),I1)/255;          %进行5*5模板平滑滤波

k3=filter2(fspecial(\’average\’,7),I1)/255;          %进行7*7模板平滑滤波

k4=filter2(fspecial(\’average\’,9),I1)/255;          %进行9*9模板平滑滤波

subplot(233),imshow(k1);title(\’3*3 模板平滑滤波\’);

subplot(234),imshow(k2);title(\’5*5 模板平滑滤波\’);

subplot(235),imshow(k3);title(\’7*7 模板平滑滤波\’);

subplot(236),imshow(k4);title(\’9*9 模板平滑滤波\’);




中值滤波器

I=imread(\’nickyboom.jpg\’);
I=rgb2gray(I);
J=imnoise(I,\’salt & pepper\’,0.02);
subplot(231),imshow(I);title(\’原图像\’);
subplot(232),imshow(J);title(\’加入椒盐噪声图像\’);
k1=medfilt2(J);            %进行3*3模板中值滤波
k2=medfilt2(J,[5,5]);      %进行5*5模板中值滤波
k3=medfilt2(J,[7,7]);      %进行7*7模板中值滤波
k4=medfilt2(J,[9,9]);      %进行9*9模板中值滤波
subplot(233),imshow(k1);title(\’3*3模板中值滤波\’);
subplot(234),imshow(k2);title(\’5*5模板中值滤波 \’);
subplot(235),imshow(k3);title(\’7*7模 板中值滤波\’);
subplot(236),imshow(k4);title(\’9*9 模板中值滤波\’);




边缘检測

I=imread(\’nickyboom.jpg\’);
subplot(2,3,1);
imshow(I);
title(\’原始图像\’);
axis([50,250,50,200]);
grid on;                  %显示网格线
axis on;                  %显示坐标系
I1=im2bw(I);
subplot(2,3,2);
imshow(I1);
title(\’二值图像\’);
axis([50,250,50,200]);
grid on;                  %显示网格线
axis on;                  %显示坐标系
I2=edge(I1,\’roberts\’);
subplot(2,3,3);
imshow(I2);
title(\’roberts算子边缘检測\’);
axis([50,250,50,200]);
grid on;                  %显示网格线
axis on;                  %显示坐标系
I3=edge(I1,\’sobel\’);
subplot(2,3,4);
imshow(I3);
title(\’sobel算子边缘检測\’);
axis([50,250,50,200]);
grid on;                  %显示网格线
axis on;                  %显示坐标系
I4=edge(I1,\’Prewitt\’);
subplot(2,3,5);
imshow(I4);
title(\’Prewitt算子边缘检測 \’);
axis([50,250,50,200]);
grid on;                  %显示网格线
axis on;                  %显示坐标系

I5=edge(I1,\’log\’);

subplot(2,3,6);
imshow(I5);

title(\’log算子边缘检測\’);

axis([50,250,50,200]);
grid on;                  %显示网格线
axis on;                  %显示坐标系




自己主动阈值法:Otsu法

用MATLAB实现Otsu算法:

clc

clear all

I=imread(\’nickyboom.jpg\’);

subplot(1,2,1),imshow(I);

title(\’原始图像\’)

axis([50,250,50,200]);

grid on;                  %显示网格线

axis on;                  %显示坐标系

level=graythresh(I);     %确定灰度阈值

BW=im2bw(I,level);

subplot(1,2,2),imshow(BW);

title(\’Otsu 法阈值切割图像\’)

axis([50,250,50,200]);

grid on;                  %显示网格线

axis on;                  %显示坐标系



膨胀操作

I=imread(\’nickyboom.jpg\’);          %加载图像

I1=rgb2gray(I);

subplot(1,2,1);

imshow(I1);

title(\’灰度图像\’)     

axis([50,250,50,200]);

grid on;                  %显示网格线

axis on;                  %显示坐标系

se=strel(\’disk\’,1);          %生成圆形结构元素

I2=imdilate(I1,se);             %用生成的结构元素对图像进行膨胀

subplot(1,2,2);

imshow(I2);

title(\’ 膨胀后图像\’);

axis([50,250,50,200]);

grid on;                  %显示网格线

axis on;                  %显示坐标系



腐蚀操作

MATLAB 实现腐蚀操作

I=imread(\’xian.bmp\’);          %加载图像

I1=rgb2gray(I);

subplot(1,2,1);

imshow(I1);

title(\’灰度图像\’)     

axis([50,250,50,200]);

grid on;                  %显示网格线

axis on;                  %显示坐标系

se=strel(\’disk\’,1);       %生成圆形结构元素

I2=imerode(I1,se);        %用生成的结构元素对图像进行腐蚀

subplot(1,2,2);

imshow(I2);

title(\’腐蚀后图像\’);

axis([50,250,50,200]);

grid on;                  %显示网格线

axis on;                  %显示坐标系




版权声明:本文为cxchanpin原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/cxchanpin/p/6751554.html