我有这个过滤函数,它接受输入图像,使用给定的内核执行卷积,并返回结果图像。但是,我似乎无法弄清楚如何让它采用不同的内核大小。例如,代替代码中下面的预定义 3x3 内核,它可以采用 5x5 或 7x7。然后用户可以输入他们想要的内核/过滤器的类型(取决于预期的效果)。我似乎无法置身事外。我对matlab很陌生。
function [newImg] = kernelFunc(imgB)
img=imread(imgB);
figure,imshow(img);
img2=zeros(size(img)+2);
newImg=zeros(size(img));
for rgb=1:3
for x=1:size(img,1)
for y=1:size(img,2)
img2(x+1,y+1,rgb)=img(x,y,rgb);
end
end
end
for rgb=1:3
for i= 1:size(img2,1)-2
for j=1:size(img2,2)-2
window=zeros(9,1);
inc=1;
for x=1:3
for y=1:3
window(inc)=img2(i+x-1,j+y-1,rgb);
inc=inc+1;
end
end
kernel=[1;2;1;2;4;2;1;2;1]/16;
med=window.*kernel;
disp(med);
med=sum(med);
med=floor(med);
newImg(i,j,rgb)=med;
end
end
end
newImg=uint8(newImg);
figure,imshow(newImg);
end