高斯滤波matlab函数,matlab自带函数实现高斯滤波(gauss filter)快速算法

将高斯核分为水平方向和垂直方向,先后对图像进行卷积处理,可提高处理速度。

function output=gaussFilter(I,sigma)

output=I;

ksize=double(uint8(3*sigma)*2+1);%窗口大小一半为3*sigma

window = fspecial('gaussian', [1,ksize], sigma); %使用1行ksize列的高斯核对图像先进行x方向卷积,再进行y方向卷积

for i = 1:size(I,3)

ret = imfilter(I(:,:,i),window,'replicate');

ret = imfilter(ret,window','replicate');

output(:,:,i) = ret;

end

end下面是一般算法

function output=gaussFilter(I,sigma)

output = I.*0;

window=double(uint8(3*sigma)*2+1);%窗口大小一半为3*sigma

H=fspecial('gaussian', window, sigma);

for c=1:size(I,3)

output(:,:,c)=imfilter(I(:,:,c),H,'replicate');

end

end

0818b9ca8b590ca3270a3433284dd417.png

0818b9ca8b590ca3270a3433284dd417.png

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值