空间变换其参数化二

news2024/11/14 14:59:51

目录

刚性变换的问题描述

最优平移向量求解

最优旋转矩阵求解

反射矩阵消除

基于SVD刚性变换矩阵计算流程总结


刚性变换的问题描述

令P={p_1,p_2,...,p_n}和Q={q_1,q_2,...,q_n}是R^d空间内的两组对应的点。希望找到一个刚性的变换,在最小二乘的意义上最优地对齐两个点集,也就是说,寻求一个旋转矩阵R和一个平移向量t来满足: (R,t)=argmin┬RϵSO(d),tϵR^d∑_i=1^n▒ω_i‖(Rp_i+t)−q_i‖^2                (1) 其中ω_i>0是每个对点的权重。

最优平移向量求解

假设R被固定并定义F(t)=∑_i=1^n▒ω_i‖(Rp_i+t)−q_i‖^2。参考The Matrix Cookbook可知∂‖x‖_2/∂x=∂(x^Tx)/∂x=2x。可以通过取F(t)相对于t的导数并计算它的根来找到最优平移向量t: 0=∂F/∂x=∑_i=1^n▒2ω_i(Rp_i+t−q_i)                                        (2) =2t(∑_i=1^n▒ω_i)+2R(∑_i=1^n▒ω_ip_i)−2∑_i=1^n▒ω_iq_i (3) 定义 p ̅=∑_i=1^n▒ω_ip_i/∑_i=1^n▒ω_i,q ̅=∑_i=1^n▒ω_iq_i/∑_i=1^n▒ω_i                                            (4) 通过重新排列上面公式的项,可以得到: t=q ̅−Rp ̅                                                          (5) 换句话说,最优平移向量t将被变换的点集P的加权质心映射到点集Q的加权质心。将最优平移向量t代入目标函数: ∑_i=1^n▒ω_i‖(Rp_i+t)−q_i‖^2=∑_i=1^n▒ω_i‖Rp_i+q ̅−Rp ̅−q_i‖^2 (6)                                     =∑_i=1^n▒ω_i‖R(p_i−q_i)−((q_i) ̅−q ̅)‖^2                        (7)  所以寻找的最佳旋转矩阵R,使其满足: R= argmin┬RϵSO(d),tϵR^d∑_i=1^n▒ω_i‖Rx_i−y_i‖^2 (8)

最优旋转矩阵求解

对公式(8)重新整理可得: ‖Rx_i−y_i‖^2=(Rx_i−y_i)^T(Rx_i−y_i)=(x_i^TR^T−y_i^T)(Rx_i−y_i) =x_i^TR^TRx_i−y_i^T Rx_i−x_i^TR^Ty_i+y_i^Ty_i =x_i^Tx_i−y_i^T Rx_i−x_i^TR^Ty_i+y_i^Ty_i (9) 通过旋转矩阵的正交性RR^T=R^TR=Ⅰ(Ⅰ是单位矩阵)。 需要注意的是,x_i^TR^Ty_i是一个标量:x_i^T维度为1×d,R^T维度为d×d并且y_i的维度为d×1。对于任何标量a,通常都有a=a^T,因此 x_i^TR^Ty_i=(x_i^TR^Ty_i)^T=y_i^TRx_i (10) 因此有 ‖Rx_i−y_i‖^2=x_i^Tx_i−2y_i^T Rx_i+y_i^Ty_i (11) 将公式(11)替换公式(8): argmin┬RϵSO(d)∑_i=1^n▒ω_i‖Rx_i−y_i‖^2=argmin┬RϵSO(d)∑_i=1^n▒ω_i(x_i^Tx_i−2y_i^T Rx_i+y_i^Ty_i) =argmin┬RϵSO(d)(∑_i^n▒ω_ix_i^Tx_i−2∑_i^n▒ω_iy_i^T Rx_i+∑_i^n▒ω_iy_i^Ty_i) =argmin┬RϵSO(d)(−2∑_i^n▒ω_iy_i^T Rx_i) (12)

最后一步(移除∑_i=1^n▒ω_ix_i^Tx_i和∑_i=1^n▒ω_iy_i^Ty_i)成立,因为这些表达式不依赖于R,所以移除他们不会影响最小值。最小化表达式乘以标量也是如此,所以有 argmin┬RϵSO(d)(−2∑_i^n▒ω_iy_i^T Rx_i)=argmax┬RϵSO(d)∑_i=1^n▒ω_iy_i^T Rx_i (13) 将上式可以改为矩阵形式如下: ∑_i=1^n▒ω_iy_i^T Rx_i=tr(WY^TRX) (14) 其中W=diag(ω_1,ω_2,…,ω_n)是带加权对角元素ω_i的n×n对角矩阵;Y是一个以y_i为列的d×n矩阵,X是一个以x_i为列的d×n矩阵。在这里提醒读者,方阵的迹是对角线上元素的和:tr(A)=∑_i=1^n▒a_ii。下图给出了代数操作的说明。

反射矩阵消除

上面得到的矩阵并不能保证是一个旋转矩阵,可能为反射矩阵(Reflection matrix),此时可以通过验证VU^T的行列式来判断到底是旋转(det(VU^T)=1)还是反射(det(VU^T)=−1)。为了确保是旋转矩阵,这时需要对公式(21)进一步处理。 假设det(VU^T)=−1,则限制R为旋转矩阵就意味着M=V^TRU为反射矩阵,于是找到一个反射矩阵M来最大化: tr(∑M)=σ_1m_11+σ_2m_22+…+σ_dm_dd=: f(m_11,m_22,…,m_dd) (22) 其中f是以m_11,m_22,…,m_dd为变量的线性函数,由于m_ii∈[−1,1],其极大值在其定义域的边界处。于是当∀i,m_ii=1时,f取得最大值,但是此时的R为反射矩阵,所以并不能这样取值。然后来看第二个极大值点(1,1,…,−1),有: f=tr(∑M)=σ_1+σ_2+…+σ_d−1−σ_d (23) 这个值大于任何其他的自变量取值(±1,±1,…,±1)除了(1,1,…,1)的组合,因为奇异值是经过排序的,σ_d是最小的奇异值。

基于SVD刚性变换矩阵计算流程总结

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

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

相关文章

如何使用pholcus库进行多线程网页标题抓取以提高效率?

在当今信息爆炸的时代,数据抓取已成为获取信息的重要手段。Go语言因其高效的并发处理能力而成为编写爬虫的首选语言之一。pholcus库,作为一个强大的Go语言爬虫框架,提供了多线程抓取的能力,可以显著提高数据抓取的效率。本文将介绍…

搭建内网开发环境(四)|基于nexus搭建maven私服

引言 在前面一篇教程中,通过 docker-compose 快速搭建好了开发环境所需的应用,本文介绍基于 nexus 搭建 maven 私服;虽然本篇教程是基于内网的,但是本文会分别介绍在拥有外网的情况下配置私服和内网的情况下配置私服,…

【论文阅读03】用于海洋物体检测的多注意力路径聚合网络

来源:用于海洋物体检测的多注意力路径聚合网络 |应用智能 (springer.com) 一、背景: 水下图像存在偏色、对比度低、能见度低等问题,使得海洋物体难以被探测到。这些都增加了海上目标探测的难度。 目前流行的检测器方法是基于卷积神经网络&…

怎么将pdf转为ppt文件?pdf转ppt的8个方法

在诸多职场与学术交流的场合中,我们时常面临将详尽的PDF文件转化为生动且易于编辑的PPT演示文稿的需求。这一转换不仅是为了满足演示时的灵活性,更是为了提升信息传递的效率与观众的理解度。从简单的在线工具到功能全面的专业软件,我们拥有多…

使用balenaEtcher制作 macOS 系统启动u盘

第一步:首先准备一个U盘要求8G(macOS Catalina 10.15.x及以上要求16G)或以上的空U盘,有资料会被格式化 第二步:下载并安装etcher https://www.apple114.com/threads/83/ 第三步:下载macOS引导镜像 (通过序列号查询电脑确认电脑…

Hive3:常用查询语句整理

一、数据准备 建库 CREATE DATABASE itheima; USE itheima;订单表 CREATE TABLE itheima.orders (orderId bigint COMMENT 订单id,orderNo string COMMENT 订单编号,shopId bigint COMMENT 门店id,userId bigint COMMENT 用户id,orderStatus tinyint COMMENT 订单状态 -3:用…

记录前后端接口使用AES+RSA混合加解密

一、前言 由于项目需求,需要用到前后端数据的加解密操作。在网上查找了了相关资料,但在实际应用中遇到了一些问题,不能完全满足我的要求。 以此为基础(前后端接口AESRSA混合加解密详解(vueSpringBoot)附完…

讲解 狼人杀中的买单双是什么意思

买单双这个概念通常出现在有第三方的板子中 比如 咒狐板子 丘比特板子 咒狐板子 第一天狼队只要推掉预言家 第二天就可以与咒狐协商绑票 推出其他好人 以及丘比特板子 如果拉出一个人狼链 那么如果孤独再连一个狼人 那么 狼队第一天就可以直接派人上去拿警徽,这样…

NDP(Neighbor Discovery Protocol)简介

定义 邻居发现协议NDP(Neighbor Discovery Protocol)是IPv6协议体系中一个重要的基础协议。邻居发现协议替代了IPv4的ARP(Address Resolution Protocol)和ICMP路由设备发现(Router Discovery),…

萌啦数据插件使用情况分析,萌啦数据插件下载

在当今数字化时代,数据已成为企业决策与个人分析不可或缺的重要资源。随着数据分析工具的日益丰富,一款高效、易用的数据插件成为了众多用户的心头好。其中,“萌啦数据插件”凭借其独特的优势,在众多竞品中脱颖而出,成…

[数据集][图像分类]肾脏病变分类数据集识别囊肿肿瘤结石数据集11756张4类别

数据集类型:图像分类用,不可用于目标检测无标注文件 数据集格式:仅仅包含jpg图片,每个类别文件夹下面存放着对应图片 图片数量(jpg文件个数):11756 分类类别数:4 类别名称:["cyst","normal&…

上海晋名室外危化品暂存柜助力燃料电池行业

近日又有一个SAVEST室外危化品暂存柜项目成功验收交付使用。 用户是一家致力于为燃料电池行业提供研发、创新解决方案和技术支持的科技型中小企业。 用户在日常经营活动中涉及到氢气实验过程中的安全问题, 4月初在网上看到上海晋名室外暂存柜系列很感兴趣&#xf…

[EC Final 2020] ICPC2020 东亚赛区决赛重现赛题解

比赛链接:EC Final 2020 和 cyx20110930 组的队,用他的号交的题。顺便帮助他橙名,好耶!(rk 25,我俩各写 2 道) Problem B: 这道是 cyx20110930 写的,顺便安利(copy)一下他的题解。 题目意思…

html+css网页制作 化妆品电商4个页面

htmlcss网页制作 化妆品电商4个页面 网页作品代码简单,可使用任意HTML编辑软件(如:Dreamweaver、HBuilder、Vscode 、Sublime 、Webstorm、Text 、Notepad 等任意html编辑软件进行运行及修改编辑等操作)。 获取源码 1&#xff…

操作系统(Linux实战)-进程创建、同步与锁、通信、调度算法-学习笔记

1. 进程的基础概念 1.1 进程是什么? 定义: 进程是操作系统管理的一个程序实例。它包含程序代码及其当前活动的状态。每个进程有自己的内存地址空间,拥有独立的栈、堆、全局变量等。操作系统通过进程来分配资源(如 CPU 时间、内…

LabVIEW光纤管道泄漏检测系统

光纤管道泄漏定位系统利用干涉型光纤传感器和数据采集卡进行信号获取与处理,实现了高灵敏度的泄漏点定位。通过软件对泄漏信号进行实时降噪处理和数据库管理,提高了系统的自动化和智能化水平。 项目背景: 长输管道在石油、天然气等行业中发挥…

【C++第十二课-多态】多态概念、多态原理

目录 多态的概念概念多态形成的条件虚函数的重写虚函数重写的两个例外 多态的题目C11增加的关于多态的关键字finaloverride 多态原理虚函数表指针 vfptr多态的实现静态绑定和动态绑定打印虚函数表补充 抽象类概念接口继承和实现继承 多态的概念 概念 具体点就是去完成某个行为…

Centos安装Kafka

安装Kafka 安装Java,因为Kafka运行需要JDK运行环境 sudo yum install java-1.8.0-openjdk-devel.x86_64如果不知道JDK版本,可以使用下面命令查看可用的JDK版本 sudo yum search openjdk添加EPEL仓库 sudo yum install epel-release下载Kafka 先去查看…

nginx初步学习

Nginx 安装 官方源码包下载地址:nginx: download 配置一台虚拟机尽量给的配置高些这样速度快些。 下载文件并解压 加载对应模块 ./configure --prefix/usr/local/nginx \ --usernginx \ # 指定nginx运行用户 --groupnginx \ # 指定ng…

BUUCTF 极客大挑战2019 Upload 1

上传图片,然后抓包 我们可以看到回显 我们改一下content-type 这里我们可以改一下filename为100.phtml,也可以不改 然后我们通过该指令查看一下是否被解析 我们发现flag就在这里 我们cat一下,得到了flag