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

OpenCV CUDA模块光流计算-----实现Farneback光流算法的类cv::cuda::FarnebackOpticalFlow

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

算法描述

cv::cuda::FarnebackOpticalFlow 是 OpenCV CUDA 模块中实现 Farneback 光流算法 的类。该类用于在 GPU 上高效地计算两帧图像之间的稠密光流(Dense Optical Flow),特别适合视频分析和运动估计。

类定义概览

属性说明
头文件<opencv2/cudaoptflow.hpp>
命名空间cv::cuda
继承自cv::cuda::DenseOpticalFlow
用途计算两个图像帧之间的稠密光流(每个像素都有一个运动向量)
GPU 加速支持 CUDA GPU 加速

创建与初始化

创建对象

cv::Ptr<cv::cuda::FarnebackOpticalFlow> farneback = cv::cuda::FarnebackOpticalFlow::create();

你也可以通过设置参数来定制化这个对象:

cv::Ptr<cv::cuda::FarnebackOpticalFlow> farneback = cv::cuda::FarnebackOpticalFlow::create(int numLevels = 5,           // 图像金字塔的层数double pyrScale = 0.5,       // 金字塔缩放因子bool fastPyramids = false,   // 是否使用快速金字塔构建int winSize = 13,            // 滑动窗口大小int numIters = 10,           // 迭代次数int polyN = 5,               // 多项式展开邻域大小double polySigma = 1.1,      // 高斯权重的标准差int flags = 0                // 标志位
);

或者,你可以创建默认对象后单独设置参数:

farneback->setNumLevels(5);          // 设置金字塔层数
farneback->setPyrScale(0.5);         // 设置金字塔缩放因子
farneback->setFastPyramids(false);   // 是否使用快速金字塔
farneback->setWinSize(13);           // 设置滑动窗口大小
farneback->setNumIters(10);          // 设置迭代次数
farneback->setPolyN(5);              // 设置多项式展开邻域大小
farneback->setPolySigma(1.1);        // 设置高斯权重的标准差
farneback->setFlags(0);              // 设置标志位

代码示例

#include <opencv2/cudaimgproc.hpp>  // for upload/download
#include <opencv2/cudaoptflow.hpp>
#include <opencv2/opencv.hpp>  // for imread, imshow 等int main()
{// Step 1: 加载灰度图像cv::Mat frame1 = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/frame1.png", cv::IMREAD_GRAYSCALE );cv::Mat frame2 = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/frame2.png", cv::IMREAD_GRAYSCALE );
if (frame1.empty() || frame2.empty()) {std::cerr << "无法加载图像" << std::endl;return -1;}// Step 2: 上传到 GPUcv::cuda::GpuMat d_frame1, d_frame2;d_frame1.upload(frame1);d_frame2.upload(frame2);// Step 3: 创建 FarnebackOpticalFlow 对象,并设置参数cv::Ptr<cv::cuda::FarnebackOpticalFlow> farneback =cv::cuda::FarnebackOpticalFlow::create(5,       // numLevels0.5,     // pyrScalefalse,   // fastPyramids21,      // winSize20,      // numIters7,       // polyN1.5,     // polySigma0        // flags);// Step 4: 准备输出 flow 图像(CV_32FC2)cv::cuda::GpuMat d_flow;farneback->calc(d_frame1, d_frame2, d_flow);// Step 5: 下载结果到 CPUcv::Mat host_flow;d_flow.download(host_flow);  // CV_32FC2// Step 6: 分离 dx 和 dy 通道std::vector<cv::Mat> flow_parts(2);cv::split(host_flow, flow_parts);  // flow_parts[0] = dx, flow_parts[1] = dy// Step 7: 计算 magnitude 和 anglecv::Mat mag, ang;cv::cartToPolar(flow_parts[0], flow_parts[1], mag, ang, true);  // 角度单位为 degree// Step 8: 构建 HSV 图像std::vector<cv::Mat> hsv_channels;// Hue: 角度归一化到 [0, 1]ang.convertTo(ang, CV_32F);ang = ang.mul(cv::Mat::ones(ang.size(), CV_32F) / 360.0f);  // [0, 1]// Saturation: 固定最大cv::Mat sat = cv::Mat::ones(ang.size(), CV_32F) * 255;  // [0, 255]// Value: magnitude 归一化到 [0, 255]cv::Mat val;cv::normalize(mag, val, 0, 255, cv::NORM_MINMAX, CV_32F);// 合并通道hsv_channels.push_back(ang);   // H: [0, 1]hsv_channels.push_back(sat);   // S: [0, 255]hsv_channels.push_back(val);   // V: [0, 255]cv::Mat hsv_merged;cv::merge(hsv_channels, hsv_merged);// Step 9: 转换为 BGR 显示cv::Mat bgr_out;hsv_merged.convertTo(hsv_merged, CV_8U);  // 必须先转成 8Ucv::cvtColor(hsv_merged, bgr_out, cv::COLOR_HSV2BGR);// Step 10: 显示图像cv::imshow("Optical Flow (Magnitude)", mag);cv::imshow("Optical Flow (Angle)", ang);cv::imshow("Optical Flow (HSV)", bgr_out);cv::waitKey(0);return 0;
}

运行结果

在这里插入图片描述

相关文章:

  • FreeRTOS队列
  • c语言——字符函数
  • 查询宝塔的数据库信息
  • 多轮对话实现
  • 【大模型】RankRAG:基于大模型的上下文排序与检索增强生成的统一框架
  • 格恩朗超声波水表 绿色助农 精准领航​
  • 02.运算符
  • [ linux-系统 ] 进程控制
  • helm使用说明和实例
  • 赞助打赏单页HTML源码(源码下载)
  • 基于算法竞赛的c++编程(24)位运算及其应用
  • python3基础语法梳理(一)
  • 安全领域新突破:可视化让隐患无处遁形
  • Easy Excel
  • c语言(持续更新)
  • 使用DataX同步MySQL数据
  • OSPF域内路由
  • matlab时序预测并绘制预测值和真实值对比曲线
  • 6.9本日总结
  • DPC密度峰值聚类
  • wordpress首页插入广告/唐山seo推广公司
  • 沈阳网站建设渠道/抖音引流推广怎么做
  • 宝安做棋牌网站建设哪家服务好/太原seo排名收费
  • 做网站排名赚钱吗/电商运营培训班多少钱
  • 网站代理商/站长工具忘忧草
  • java动态网站开发/石狮seo