OpenCV CUDA模块设备层---- 绝对值函数abs()

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

算法描述

这是 OpenCV 的 cv::cudev 模块中用于 CUDA 设备端(device)的绝对值函数,专门处理 uchar1 类型(即单通道无符号字符)。

函数原型

__device__ __forceinline__ uchar1 cv::cudev::abs 	( 	const uchar1 &  	a	) 	
  • device: 表示这个函数只能在 CUDA 设备端(GPU)运行。
  • forceinline: 强制内联,提高性能。
  • uchar1: CUDA 内建类型,表示一个包含 1 个 unsigned char 的向量(类似 struct { unsigned char x; };)。
  • cv::cudev::abs(a): 返回输入值的绝对值。对于 uchar 来说其实等价于直接返回 a,因为它是无符号类型。

示例使用场景

在 CUDA 核函数中对图像像素进行操作时,可能会用到:

__global__ void absKernel(const cv::cudev::PtrStep<uchar> src,cv::cudev::PtrStep<uchar> dst)
{int x = blockIdx.x * blockDim.x + threadIdx.x;int y = blockIdx.y * blockDim.y + threadIdx.y;if (x < src.cols && y < src.rows){uchar val = src(y, x);dst(y, x) = cv::cudev::abs(make_uchar1(val)).x;}
}

示例代码

cu文件:


#include <opencv2/opencv.hpp>
#include <opencv2/cudaimgproc.hpp>
#include <opencv2/cudev/util/vec_math.hpp>using namespace cv;
using namespace cudev;__global__ void absKernel(PtrStepSz<uchar> src, PtrStepSz<uchar> dst)
{int x = blockIdx.x * blockDim.x + threadIdx.x;int y = blockIdx.y * blockDim.y + threadIdx.y;if (x < src.cols && y < src.rows){uchar1 val = make_uchar1(src(y, x));dst(y, x) = cv::cudev::abs(val).x;}
}int main()
{Mat h_src = imread("/media/dingxin/data/study/OpenCV/sources/images/Lenna.png", IMREAD_GRAYSCALE);if (h_src.empty()){std::cerr << "Failed to load image!" << std::endl;return -1;}cuda::GpuMat d_src, d_dst;d_src.upload(h_src);d_dst.create(h_src.size(), h_src.type());PtrStepSz<uchar> srcPtr(d_src);PtrStepSz<uchar> dstPtr(d_dst);dim3 block(16, 16);dim3 grid((srcPtr.cols + block.x - 1) / block.x,(srcPtr.rows + block.y - 1) / block.y);absKernel<<<grid, block>>>(srcPtr, dstPtr);cudaDeviceSynchronize();Mat h_dst;d_dst.download(h_dst);imshow("Original", h_src);imshow("Abs Result", h_dst);waitKey(0);return 0;
}

运行结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/87817.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/87817.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IEC61850 通信协议测试验证方法详解

一、MMS 协议测试方法 MMS&#xff08;制造报文规范&#xff09;是 IEC61850 中用于设备监控和控制的核心协议&#xff0c;测试需覆盖以下维度&#xff1a; &#xff08;一&#xff09;协议栈实现验证 连接管理测试 测试用例&#xff1a;建立和释放 MMS 连接 100 次&#xf…

关于 Kyber:抗量子密码算法 Kyber 详解

一、基本概念 后量子密码学&#xff08;PQC&#xff09; │ ├──> 是一个领域&#xff08;研究如何在“量子时代”保护数据安全&#xff09; │ └──> Kyber 是这个领域中设计出来的一个“抗量子密码算法”└──> Kyber 是用于加密密钥交换的算法&#xff08;叫…

如何保障具身智能系统级安全?鸿道OS给出中国方案

由东土科技自主研发完成的鸿道&#xff08;Intewell&#xff09;工业操作系统正式发布。东土科技董事长李平与该公司全资子公司光亚鸿道总经理邹露君在接受第一财经等采访时&#xff0c;解释了如何通过操作系统为具身智能产业提供底层支撑&#xff0c;解决产业规模化落地的安全…

深入浅出:JavaScript ES6中类(Class)的革新与实践

深入浅出&#xff1a;JavaScript ES6中类&#xff08;Class&#xff09;的革新与实践 在JavaScript的发展历程中&#xff0c;ES6&#xff08;ECMAScript 2015&#xff09;无疑是一个里程碑式的版本。它不仅引入了let、const、箭头函数等特性&#xff0c;更通过**类&#xff08…

华大北斗TAU804M-N2B0双频单北斗高精度定位模块 100%国产双频北斗 打破u-blox技术垄断

华大北斗TAU804M-N2B0双频单北斗模块深度解析 1. 产品定位 TAU804M-N2B0 是华大北斗&#xff08;HDSC&#xff09;推出的 双频单北斗高精度定位模块&#xff0c;支持 B1IB2a双频信号接收&#xff0c;专为 高精度定位、抗多径干扰 场景设计&#xff0c;是北斗三号系统应用的标杆…

IP证书申请攻略细则,有何作用?

IP证书申请攻略细则及作用解析 一、IP证书的作用 数据加密传输 IP证书通过SSL/TLS协议对客户端与服务器之间的数据进行加密&#xff0c;防止数据在传输过程中被窃取或篡改&#xff0c;适用于物联网设备、API接口、测试服务器等直接通过IP访问的场景。 身份验证与防伪造 浏览器…

回文链表C++

给你一个单链表的头节点 head &#xff0c;请你判断该链表是否为回文链表。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 时间复杂度较大的解法&#xff1a; /*** Definition for singly-linked list.* struct ListNode {* int val;* Lis…

限流系列之三:TDMQ for Apache Pulsar 限流技术深度解析

导语 在高速、高吞吐量的消息处理场景中&#xff0c;TDMQ Pulsar 版以其卓越的性能和可扩展性成为众多企业的首选。然而&#xff0c;随着生产者和消费者以极高的速度生产/消费大量消息&#xff0c;服务器资源如 CPU、内存、网络及磁盘 IO 等可能会面临饱和风险。为此&#xff…

非研发部门参与产品开发过程的价值体现

汉捷咨询 胡红卫 企业已经越来越意识到新产品开发项目需要市场、销售、制造、采购、服务、财务等非研发部门的参与&#xff0c;尝试建立跨部门的项目组&#xff0c;安排相关人员参与项目&#xff0c;但是效果如何呢&#xff1f;在汉捷咨询对很多企业调研诊断过程中&#xff0c;…

Kafka的存储与索引:数据处理的底层奥秘

一、引言 Kafka 之所以能在海量数据的传输和处理过程中保持高效的性能和低延迟&#xff0c;背后隐藏着众多精妙的设计&#xff0c;而其存储与索引机制便是其中的核心奥秘。接下来&#xff0c;让我们深入探寻 Kafka 存储机制的基石与架构。 二、分区与日志组织​ Kafka 中的消…

大模型与搜索引擎的技术博弈及未来智能范式演进

基于认知革命与技术替代的全景综述 一、大模型对搜索引擎的替代性分析&#xff1a;技术范式与市场重构 &#xff08;1&#xff09;技术原理的代际分野 传统搜索引擎遵循 "爬虫抓取 - 索引构建 - 关键词排序" 的三段式架构&#xff0c;其核心是基于 PageRank 算法的…

XC7K325T数据采集卡设计原理图:786-基于X86 CPU+XC7K325T的16路16bit 1M sps同步数据采集卡

基于X86 CPUXC7K325T的16路16bit 1M sps同步数据采集卡 一、板卡概述 板卡为紧凑型的X86FPGA的工业监测处理平台&#xff0c;高度集成的硬件和完整的labview开发软件&#xff0c;大大方便客户现场使用。 二、板卡功能 板卡功能 参数内容 X86 SOM核心板 主频 2.0GHz …

单片机3种按键程序消抖方法

1&#xff0c;查询法延时模式 u8 key01;u8 x0;KEY1;while(1){if(KEY0) //"按键按下"{delay(10); //延时10msif(KEY0 && kdy01) //按下有10ms 且上状态是1。即下降沿时{key00; //将上状态置0.防止按住不放时&#xff0…

【java面试】线程篇

【java面试】线程篇 一、基础知识1 线程与进程的区别2 并行与并发的区别3 创建线程的方式4 线程包含了哪些状态&#xff0c;状态之间是如何变化的&#xff1f;5 新建三个线程&#xff0c;如何保证他们按照顺序执行&#xff1f;6、java中的wait和sleep方法的不同7 如何停止一个正…

RAGFlow是一个基于深度文档理解的开源RAG引擎

RAGFlow概述 RAGFlow是一款基于深度文档理解的开源RAG&#xff08;检索增强生成&#xff09;引擎&#xff0c;专注于处理复杂文档结构并提供精准的语义检索与生成能力。其核心优势在于结合多模态文档解析和智能分段技术&#xff0c;优化传统RAG流程中的信息提取与答案生成效果…

Git Commit 模板完整配置指南

Git Commit 模板完整配置指南 &#x1f4cb; 目录 Git Commit 模板完整配置指南 &#x1f4cb; 目录&#x1f3af; 为什么需要 Commit 模板&#x1f4dd; 推荐的 Commit 模板 标准模板格式C 项目特化模板 ⚙️ 系统级配置 1. 创建模板文件2. 配置 Git 使用模板3. 验证配置 &a…

【ELK服务搭建】

Ubuntu 20.04环境下部署Elastic Stack 8.18日志系统完整指南 一、环境准备 系统要求 Ubuntu 20.04 LTS硬件配置&#xff1a;4核CPU / 8GB内存 / 100GB硬盘网络&#xff1a;需外网访问权限 1. 基础环境配置 首先安装SSH服务以便远程管理&#xff1a; # 更新软件源 apt u…

Mac电脑 Office 2024 LTSC 长期支持版(Excel、Word、PPT)

Office 2024 mac&#xff0c;是一款是一款专为苹果电脑用户设计的高性能、高安全性的办公套装 集成了Word、Excel、PowerPoint、Outlook等经典应用&#xff0c;为用户提供了一站式的办公解决方案。 不仅继承了Office系列一贯的卓越性能&#xff0c;还在功能性和用户体验上进行…

深入解析 Schema 在不同数据库中的百变面孔

在数据库的世界里&#xff0c;数据是核心资产&#xff0c;但如何高效、有序、安全地组织和理解这些数据&#xff1f;答案就是 Schema&#xff08;模式或架构&#xff09;。它如同建筑的图纸、乐队的乐谱&#xff0c;是数据库的设计蓝图和运行规则手册。今天&#xff0c;我们就来…

Python 数据分析与可视化 Day 2 - 数据清洗基础

&#x1f3af; 今日目标 学会识别和处理缺失数据&#xff08;NaN&#xff09;学会删除/填补缺失值清理重复数据修改列类型&#xff0c;准备数据分析 &#x1f9fc; 一、缺失值处理&#xff08;NaN&#xff09; ✅ 1. 检查缺失值 import pandas as pd df pd.read_csv("…