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

OPenCV CUDA模块图形变换----构建透视变换映射表函数buildWarpPerspectiveMaps()

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

算法描述

该函数用于构建一个透视变换(Perspective Transform)的映射表(xmap / ymap),可用于后续的图像重映射操作(如 remap)。
适用于 GPU 加速的图像处理流程,是 cv::warpPerspective 的底层实现之一。

函数原型

void cv::cuda::buildWarpPerspectiveMaps 
(InputArray  	M,bool  	inverse,Size  	dsize,OutputArray  	xmap,OutputArray  	ymap,Stream &  	stream = Stream::Null() 
) 		

参数

参数名类型与说明
M一个 3x3 的 Mat 或 UMat 类型的变换矩阵。
inverse标志位,指定 M 是一个逆变换(即从目标图像到源图像的映射)。
dsize目标图像的尺寸。
xmapX 坐标的映射值,类型为 CV_32FC1
ymapY 坐标的映射值,类型为 CV_32FC1
stream用于异步操作的流对象,默认为 Stream::Null()

代码示例

#include <opencv2/cudaimgproc.hpp>
#include <opencv2/cudawarping.hpp>
#include <opencv2/opencv.hpp>int main()
{// 读取图像cv::Mat h_src = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/Lenna.png", cv::IMREAD_COLOR );if ( h_src.empty() ){std::cerr << "无法加载图像!" << std::endl;return -1;}// 上传图像到 GPUcv::cuda::GpuMat d_src, d_dst;d_src.upload( h_src );// 定义四个点对(源点和目标点)cv::Point2f srcQuad[ 4 ], dstQuad[ 4 ];srcQuad[ 0 ] = cv::Point2f( 0, 0 );                    // 左上角srcQuad[ 1 ] = cv::Point2f( h_src.cols, 0 );           // 右上角srcQuad[ 2 ] = cv::Point2f( h_src.cols, h_src.rows );  // 右下角srcQuad[ 3 ] = cv::Point2f( 0, h_src.rows );           // 左下角dstQuad[ 0 ] = cv::Point2f( 0, 0 );dstQuad[ 1 ] = cv::Point2f( h_src.cols * 0.9F, h_src.rows * 0.1F );dstQuad[ 2 ] = cv::Point2f( h_src.cols * 0.8F, h_src.rows * 0.9F );dstQuad[ 3 ] = cv::Point2f( h_src.cols * 0.1F, h_src.rows );// 构建透视变换矩阵cv::Mat M = cv::getPerspectiveTransform( srcQuad, dstQuad );// 设置输出尺寸cv::Size dsize( h_src.cols, h_src.rows );// 创建映射表cv::cuda::GpuMat d_xmap, d_ymap;cv::cuda::buildWarpPerspectiveMaps( M, false, dsize, d_xmap, d_ymap );// 执行图像变形cv::cuda::remap( d_src, d_dst, d_xmap, d_ymap, cv::INTER_LINEAR );// 下载结果并显示cv::Mat h_dst;d_dst.download( h_dst );cv::imshow( "Original Image", h_src );cv::imshow( "Warped Image", h_dst );cv::waitKey( 0 );return 0;
}

运行结果

在这里插入图片描述

http://www.xdnf.cn/news/985357.html

相关文章:

  • AUTOSAR实战教程--DoIP_03_ 代码分析与调用栈观测(ISOLAR版)
  • 详解多模态
  • 项目制造型企业如何实现高效管理?从金属工具制造说起
  • 【LeetCode 热题 100】只出现一次的数字 / 多数元素 / 颜色分类 / 寻找重复数
  • 建造者模式(Builder Pattern)
  • 设计模式-组合模式
  • Ubuntu20.04更新Cmake版本
  • 找到字符串中所有字母异位词
  • 使用 PyTorch 和 TensorBoard 实时可视化模型训练
  • SpringBoot学习day1-SpringBoot的简介与搭建
  • Phthon3 学习记录-0611
  • Windows 删除文件出现错误代码0x80070570:文件或目录损坏且无法读取
  • 第五章网络管理
  • vibe coding 2025工具全景图
  • 构建高效开发节奏:我的IDEA休息提醒插件实践
  • fastadmin自动保存格式datetime
  • JavaEE-SpringBoot
  • 基于SpringBoot实现的课程答疑系统设计与实现【源码+文档】
  • 【MySQL数据库 | 第四篇】 数据类型+DDL表操作1
  • 从零开始了解数据采集技术篇(2)——如何提高数据采集的精度与速度
  • ALIGN_COMMA_ENABLE参数
  • 贪心选择 (Greedy Choice)
  • 大语言模型智能体开发的技术框架与应用前景
  • 日期的数据格式转换
  • 红队手法:从web漏洞到ssh横向移动 实战方案
  • vue3笔记(1)自用
  • 选择、填空、判断
  • 深入理解Python协程:async def、async for、await、yield详解
  • 学习日记-day27-6.11
  • Debian/Ubuntu systemd coredump调试程序Crash