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

OpenCV视觉分析之目标跟踪(11)计算两个图像之间的最佳变换矩阵函数findTransformECC的使用

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

算法描述

根据 ECC 标准 78找到两幅图像之间的几何变换(warp)。

该函数根据 ECC 标准 ([78]) 估计最优变换(warpMatrix),也就是说
warpMatrix = arg ⁡ max ⁡ W ECC ( templateImage ( x , y ) , inputImage ( x ′ , y ′ ) ) \texttt{warpMatrix} = \arg\max_{W} \texttt{ECC}(\texttt{templateImage}(x,y),\texttt{inputImage}(x',y')) warpMatrix=argWmaxECC(templateImage(x,y),inputImage(x,y))
此处
[ x ′ y ′ ] = W ⋅ [ x y 1 ] \begin{bmatrix} x' \\ y' \end{bmatrix} = W \cdot \begin{bmatrix} x \\ y \\ 1 \end{bmatrix} [xy]=W xy1

(方程在单应性变换中使用齐次坐标时成立)。它返回最终的增强相关系数,即模板图像和最终变形的输入图像之间的相关系数。当给定一个 3×3 矩阵且 motionType 为 0、1 或 2 时,第三行被忽略。

与 findHomography 和 estimateRigidTransform 不同,findTransformECC 函数实现了一种基于区域的对齐方法,该方法基于强度相似性。本质上,该函数更新初始变换,该变换大致对齐图像。如果缺少这些信息,则使用单位变换(单位矩阵)作为初始化。注意,如果图像经历了强烈的位移/旋转,需要一个初始变换来大致对齐图像(例如,一个简单的欧氏变换/相似变换,允许图像显示大致相同的内容)。在第二幅图像中使用逆向变形,以使图像接近第一幅图像,即在使用 warpAffine 或 warpPerspective 时使用 WARP_INVERSE_MAP 标志。还可以参见 OpenCV 示例 image_alignment.cpp,该示例演示了该函数的使用。注意,如果算法不收敛,该函数会抛出异常。

函数原型

double cv::findTransformECC	
(
	InputArray 	templateImage,
	InputArray 	inputImage,
	InputOutputArray 	warpMatrix,
	int 	motionType,
	TermCriteria 	criteria,
	InputArray 	inputMask,
	int 	gaussFiltSize 
)		

参数

  • 参数 templateImage:单通道模板图像;CV_8U 或 CV_32F 数组。

  • 参数inputImage:单通道输入图像,该图像应使用最终的 warpMatrix 进行变形,以提供与 templateImage 类似的图像,类型与 templateImage 相同。

  • 参数warpMatrix:浮点型 2×3 或 3×3 映射矩阵(变形矩阵)。

  • 参数motionType:参数,指定运动类型:

    • MOTION_TRANSLATION 设置平移运动模型;warpMatrix 是 2×3 的矩阵,前 2×2 部分为单位矩阵,其余两个参数被估计。
    • MOTION_EUCLIDEAN 设置欧氏(刚性)变换作为运动模型;估计三个参数;warpMatrix 是 2×3 的矩阵。
    • MOTION_AFFINE 设置仿射运动模型(默认);估计六个参数;warpMatrix 是 2×3 的矩阵。
  • MOTION_HOMOGRAPHY 设置单应性作为运动模型;估计八个参数;warpMatrix 是 3×3 的矩阵。
    -参数criteria:参数,指定 ECC 算法的终止条件;criteria.epsilon 定义了两次迭代之间相关系数增量的阈值(负的 criteria.epsilon 使 -criteria.maxcount 成为唯一的终止条件)。默认值如上声明所示。

  • 参数inputMask:一个可选的掩码,用于指示 inputImage 的有效值。

  • 参数gaussFiltSize:一个可选值,指示高斯模糊滤波器的大小;(默认值:- 5)

代码示例


#include <opencv2/opencv.hpp>
#include <iostream>

int main() {
    // 读取图像
    cv::Mat image1 = cv::imread("/media/dingxin/data/study/OpenCV/sources/images/ecc1.png", cv::IMREAD_GRAYSCALE);
    cv::Mat image2 = cv::imread("/media/dingxin/data/study/OpenCV/sources/images/ecc2.png", cv::IMREAD_GRAYSCALE);

    if (image1.empty() || image2.empty()) {
        std::cout << "Could not open or find the images" << std::endl;
        return -1;
    }

    // 定义变换矩阵
    cv::Mat warp_matrix = cv::Mat::eye(2, 3, CV_32F);

    // 设置终止条件
    const int MAX_ITER = 1000;
    const double EPSILON = 1e-5;
    cv::TermCriteria criteria(cv::TermCriteria::COUNT + cv::TermCriteria::EPS, MAX_ITER, EPSILON);

    // 计算变换矩阵
    double ecc = cv::findTransformECC(image1, image2, warp_matrix, cv::MOTION_AFFINE, criteria);

    // 输出变换矩阵
    std::cout << "Transformation Matrix:\n" << warp_matrix << std::endl;

    // 使用计算出的变换矩阵对第二张图像进行变换
    cv::Mat aligned_image;
    cv::warpAffine(image2, aligned_image, warp_matrix, image1.size());

    // 显示原图和对齐后的图像
    cv::imshow("Original Image", image1);
    cv::imshow("Aligned Image", aligned_image);
    cv::imshow("Target Image", image2);
    cv::waitKey(0);

    return 0;
}

运行结果

原始图:
在这里插入图片描述
目标图

在这里插入图片描述
对齐的图
在这里插入图片描述

原文地址:https://blog.csdn.net/jndingxin/article/details/143506192
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/387401.html

相关文章:

  • 《Memory Barriers a Hardware View for Software Hackers》阅读笔记
  • SpringMVC新版本踩坑[已解决]
  • tomcat的accept-count、max-connections、max-threads三个参数的含义
  • 【人工智能】Python常用库-Keras:高阶深度学习 API
  • 关于deepin上运行Qt开发的程序
  • 仿 RabbitMQ 的消息队列3(实战项目)
  • MySQL基础-单表查询
  • 【MySQL】数据库整合攻略 :表操作技巧与详解
  • [编译报错]ImportError: No module named _sqlite3解决办法
  • 任天堂闹钟“Alarmo”已被用户破解 可显示自定义图像
  • Linux环境基础和基础开发工具使用
  • 【知识点总结】 Redis 数据类型操作指令
  • GitHub 和 Gitee 的区别和选择指南
  • 【数据集】【YOLO】【目标检测】交通事故识别数据集 8939 张,YOLO道路事故目标检测实战训练教程!
  • js下载excel示例demo
  • Vue keep-alive 深度使用解读
  • 删除conda和 pip 缓存的包
  • 深度剖析RPC框架:为你的分布式应用找到最佳通信方式
  • 每天五分钟深度学习PyTorch:基于全连接神经网络完成手写字体识别
  • 深入Zookeeper节点操作:高级功能与最佳实践
  • IDA*算法 Power Calculus————poj 3134
  • 孔夫子的数字化宝库:用API解锁在售商品的秘密
  • 安装lua-nginx-module实现WAF功能
  • 瞬间对大模型与NLP的兴趣达到了1000000000%
  • 腾讯混元3D-1.0:文本到三维和图像到三维生成的统一框架
  • websphere CVE-2015-7450反序列化和弱口令,后台Getshell