当前位置: 首页 > news >正文

OpenCV计算摄影学(3)CUDA 图像去噪函数fastNlMeansDenoising()

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

使用非局部均值去噪算法(Non-local Means Denoising algorithm)执行图像去噪,该算法来源于 http://www.ipol.im/pub/algo/bcm_non_local_means_denoising,并包含了若干计算优化。预期噪声为高斯白噪声。

cv::cuda::fastNlMeansDenoising 是 OpenCV 的 CUDA 模块中用于图像去噪的一个函数。此函数实现了快速非局部均值去噪算法,旨在减少图像中的噪声同时尽可能保留边缘细节。

函数原型


void cv::cuda::fastNlMeansDenoising	
(	InputArray 	src,OutputArray 	dst,float 	h,int 	search_window = 21,int 	block_size = 7,Stream & 	stream = Stream::Null() 
)	

参数

  • 参数src 输入8位1通道、2通道或3通道的图像。
  • 参数sdst 与 src 具有相同大小和类型的输出图像。
  • 参数sh 调节滤波强度的参数。较大的 h 值能完美地去除噪声,但也会去除图像细节;较小的 h 值则会保留细节,但也会保留一些噪声。
  • 参数ssearch_window 用于计算给定像素加权平均值的窗口大小(以像素为单位)。应该是奇数。性能受其影响呈线性关系:更大的 search_window 意味着更长的去噪时间。推荐值为21像素。
  • 参数sblock_size 用于计算权重的模板块大小(以像素为单位)。应该是奇数。推荐值为7像素。
  • 参数sstream 用于异步调用的流。 该函数预期应用于灰度图像。对于彩色图像,请参阅 FastNonLocalMeansDenoising::labMethod。

代码示例

电脑没有Nvidia的显卡,程序编译不了,opencv不支持cuda的也编译不了。

#include <opencv2/opencv.hpp>
#include <opencv2/cudaimgproc.hpp>
#include <opencv2/core/cuda.hpp>int main() {// 加载输入图像cv::Mat src = cv::imread("noisy_image.jpg", cv::IMREAD_COLOR);if (src.empty()) {std::cerr << "无法加载图像文件" << std::endl;return -1;}// 创建与src相同大小和类型的输出图像dstcv::Mat dst;// 将输入图像上传到GPUcv::cuda::GpuMat gpu_src, gpu_dst;gpu_src.upload(src);// 创建CUDA流(可选)cv::cuda::Stream stream;// 应用快速非局部均值去噪算法cv::cuda::fastNlMeansDenoising(gpu_src, gpu_dst, 3.0f /* h */, 21 /* search_window */, 7 /* block_size */, stream);// 将去噪后的图像从GPU下载到CPUgpu_dst.download(dst);// 保存去噪后的图像cv::imwrite("denoised_image.jpg", dst);// 显示原始图像和去噪后的图像cv::imshow("Noisy Image", src);cv::imshow("Denoised Image", dst);cv::waitKey();return 0;
}
http://www.lryc.cn/news/545234.html

相关文章:

  • 【react】快速上手基础教程
  • leaflet扩展插件esri-leaflet.js
  • electron-builder打包时github包下载失败【解决办法】
  • 分片加载网络图片
  • 考研复试问题总结-数据结构(1)
  • DeepSeek 助力 Vue3 开发:打造丝滑的网格布局(Grid Layout)
  • 架构案例:从初创互联网公司到分布式存储与反应式编程框架的架构设计
  • 51页精品PPT | 农产品区块链溯源信息化平台整体解决方案
  • 【Pytest】setup和teardown的四个级别
  • JavaScript系列03-异步编程全解析
  • Linux学习——退出vi编辑模式
  • 第2章_保护您的第一个应用程序
  • 【AGI】DeepSeek开源周:The whale is making waves!
  • Unity中动态切换光照贴图的方法
  • 第三十四:6.4.【v-model】
  • React底层常见的设计模式
  • 从零基础到通过考试
  • UniApp 按钮组件 open-type 属性详解:功能、场景与平台差异
  • 【无标题】ABP更换MySql数据库
  • 大模型微调入门(Transformers + Pytorch)
  • 【开源免费】基于SpringBoot+Vue.JS网络海鲜市场系统(JAVA毕业设计)
  • 在线会议时, 笔记本电脑的麦克风收音效果差是为什么
  • 理解文件系统
  • 第二十四:5.2【搭建 pinia 环境】axios 异步调用数据
  • Vue2+Element实现Excel文件上传下载预览【超详细图解】
  • C# 装箱(Boxing)与拆箱(Unboxing)
  • 【AD】3-10 原理图PDF导出
  • SQL命令详解之增删改数据
  • Docker 部署 MinIO 对象存储服务
  • IP段转CIDR:原理Java实现