首页 > 运维 > linux运维 > 正文

快速双边滤波源码「建议收藏」

蓮花仙者
发布: 2025-07-14 08:30:31
原创
824人浏览过

大家好,又见面了,我是你们的朋友全栈君。

快速双边滤波源码「建议收藏」% 使用升余弦的快速双边滤波

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % % inImg : 灰度图像 % sigma1 : 空间高斯核的宽度 % sigma2 : 范围高斯核的宽度 % [-w, w]^2 : 空间高斯核的领域 % tol : 截断误差 % % 作者: Kunal N. Chaudhury. % 日期: 2012年3月1日. % 修改: 2014年6月21日. % % 参考文献: % [1] K.N. Chaudhury, D. Sage, 和 M. Unser, “使用三角范围核的快速O(1)双边过滤,” IEEE Trans. Image Proc., % 卷. 20, 号. 11, 2011. % % [2] K.N. Chaudhury, “加速可移动的O(1)算法用于双边过滤和非局部均值,” IEEE Transactions on Image Proc., % 卷. 22, 号. 4, 2013. % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

% 加载测试图像 clc, clear all, close all force; Img = double( imread(‘./images/ckb.jpg’) ); [m, n] = size(Img);

% 创建带噪声图像(加性高斯噪声) sigma = 20; inImg = Img + sigma * randn(m, n);

% 过滤参数 sigma1 = 4; sigma2 = 30; tol = 0.01;

% 设置空间高斯核的窗口 w = 6*sigma1; if (mod(w,2) == 0) w = w+1; end

% 调用双边滤波器 tic; [outImg, param] = shiftableBF(inImg, sigma1, sigma2, w, tol); toc;

% 绘制结果 T = param.T; N = param.N; M = param.M; gamma = 1 / (sqrt(N) * sigma2); twoN = 2^N;

文心快码
文心快码

文心快码(Comate)是百度推出的一款AI辅助编程工具

文心快码 35
查看详情 文心快码

warning(‘off’); %#ok

s = linspace(-T, T, 200); g = exp( -s.^2 / (2 sigma2 sigma2) ); gApprox = cos(gamma s).^N; if M == 0 gTrunc = gApprox; else gTrunc = zeros( 1, length(s) ); for k = M : N - M gTrunc = gTrunc + (nchoosek(N, k) / twoN) … cos( (2k - N) gamma * s ); end end

figure(‘Units’,’normalized’,’Position’,[0 0.5 1 0.5]); plot(s, g, ‘b’); hold on, plot(s, gApprox, ‘m’), hold on, plot(s, gTrunc, ‘r’); axis(‘tight’), grid(‘on’), legend(‘高斯’,’升余弦’,’截断升余弦’,’FontSize’, 10); title(‘范围核的比较’, ‘FontSize’, 10),

peak = 255; PSNR0 = 10 log10(m n peak^2 / sum(sum( (inImg - Img).^2)) ); PSNR1 = 10 log10(m n peak^2 / sum(sum((outImg - Img).^2)) );

figure(‘Units’,’normalized’,’Position’,[0 0.5 1 0.5]); colormap gray, subplot(1,3,1), imshow(uint8(Img)), title(‘原始’, ‘FontSize’, 10), axis(‘image’, ‘off’); subplot(1,3,2), imshow(uint8(inImg)), title([ ‘带噪声, ‘, num2str(PSNR0, ‘%.2f’), ‘dB’] , ‘FontSize’, 10), axis(‘image’, ‘off’); subplot(1,3,3), imshow(uint8(outImg)), title([ ‘滤波后, ‘, num2str(PSNR1, ‘%.2f’), ‘dB’] , ‘FontSize’, 10), axis(‘image’, ‘off’);

发布者:全栈程序员栈长,转载请注明出处:https://www.php.cn/link/8684ff2b6457df6145f160954e1ff7a7

以上就是快速双边滤波源码「建议收藏」的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号