您的位置:首页 > 编程语言 > MATLAB

MATLAB之微分处理图像前向差分

2017-12-02 07:58 1041 查看
 

MATLAB之微分处理图像前向差分
复杂些的滤波算子一般是先利用高斯滤波来平滑,然后计算其1阶和2阶微分。由于它们滤除高频和低频,因此称为带通滤波器(band-pass
filters)。

先介绍必备的图像微分知识。

 

function dimg = mipforwarddiff(img,direction)

% MIPFORWARDDIFF     Finite difference calculations 

%

%   DIMG = MIPFORWARDDIFF(IMG,DIRECTION)

%

%  Calculates the forward-difference for a given direction

%  IMG       : input image

%  DIRECTION : 'dx' or 'dy'

%  DIMG      : resultant image

%

 

imgPad = padarray(img,[1 1],'symmetric','both');%将原图像的边界扩展

[row,col] = size(imgPad);

dimg = zeros(row,col);

switch (direction)   

case 'dx',

   dimg(:,1:col-1) =imgPad(:,2:col)-imgPad(:,1:col-1);%x方向差分计算,

case 'dy',

   dimg(1:row-1,:) =imgPad(2:row,:)-imgPad(1:row-1,:); 

otherwise, disp('Direction is unknown');

end;

dimg = dimg(2:end-1,2:end-1);

 

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%主函数

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

I = imread('lena1.png'); 

figure; imshow(I);

forward_dx = mipforwarddiff(I,'dx'); figure, imshow(forward_dx);

forward_dy = mipforwarddiff(I,'dy'); figure, imshow(forward_dy);



                                          原图



x方向



y方向

欢迎大家关注我的公众号,图像处理扣扣群:

 



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  matlab 图像处理