还记得过去写过径向模糊,不过当时效果似乎不好。
这次效果还可以,程序中用的算法是:
1.求当前处理点和图像中心点之间的距离r与角度ang;
2.通过对r的修改得到径向模糊。
3.通过对ang的修改得到旋转模糊。
一看代码就能全部明白,不仔细解释了。
原图如下:
处理后效果:
matlab代码如下:
clear all;close all;clc img=imread('lena.jpg');
[h w]=size(img);
imshow(img) imgn=zeros(h,w);
for y=:h
for x=:w
r=sqrt((y-h/)^+(x-w/)^);
ang=atan2(y-h/,x-w/); pix=;
pixNum=;
rot=;
for i=:0.1:
rot=rot-0.001; %旋转系数 %r-i是距离当前像素的距离为r-i的像素,在当前像素和中心像素同一条直线上
yy=round(abs(r-i)*sin(ang+rot))+h/;
xx=round(abs(r-i)*cos(ang+rot))+w/;
if yy>= && yy<=h && xx>= && xx<=w
pix=pix+double(img(yy,xx));
pixNum=pixNum+;
end
end
pix=pix/pixNum;
imgn(y,x)=pix;
end
end figure;
imshow(imgn,[]);