Eigen::svd和 np.linalg.svd的不同之处

目录

  • python
  • c++
  • 结论
  • 参考

SVD奇异值分解与PCA主成分分析

SVD动画图解–Wiki
请添加图片描述
Eigen Svd 和 np.linalg.svd都可以用于SVD计算,但两者却存在细微的差别。

python

import numpy as np
data=np.array([[0.99337785, 0.08483806, 0.07747866, -92.91055059],[-0.07889607, 0.99392169, -0.07677948, -42.2437898],[-0.08352154, 0.07015827, 0.99403318, 396.22910711],[0, 0, 0, 1]])
U, S, Vt = np.linalg.svd(data)
k = 4
U_reduced = U[:, :k]
S_reduced = np.diag(S[:k])
Vt_reduced = Vt[:k, :]# 重构原始数据
# reconstructed_data = np.dot(U_reduced, np.dot(S_reduced, Vt_reduced))
reconstructed_data = np.dot(U*S, Vt)
print(f"原始数据:\n{data}")
print(f"重构的数据:\n{reconstructed_data}")
print(f"U:\n{U_reduced}")
print(f"S:\n{S}")
print(f"Vt:\n{Vt_reduced}")np.allclose(data, reconstructed_data, rtol=1e-05, atol=1e-08) #true

原始数据:
[[ 0.99337785 0.08483806 0.07747866 -92.91055059]
[ -0.07889607 0.99392169 -0.07677948 -42.2437898 ]
[ -0.08352154 0.07015827 0.99403318 396.22910711]
[ 0. 0. 0. 1. ]]
重构的数据:
[[ 0.99337785 0.08483806 0.07747866 -92.91055059]
[ -0.07889607 0.99392169 -0.07677948 -42.2437898 ]
[ -0.08352154 0.07015827 0.99403318 396.22910711]
[ -0. 0. -0. 1. ]]
U:
[[-0.22707395 0.44440135 0.86657057 -0.00055497]
[-0.10324408 0.87381543 -0.47517069 -0.00025233]
[ 0.96838634 0.19736775 0.15253937 0.00236674]
[ 0.00244399 0. -0. -0.99999701]]
S:
[409.16550869 1. 0.99999999 0.002444 ]
Vt:
[[-0.00072906 -0.00013183 0.00232899 0.99999701]
[ 0.35603339 0.92005324 0.16353062 0. ]
[ 0.88558079 -0.38806239 0.25525328 -0. ]
[-0.2983058 -0.05394073 0.9529418 -0.00244399]]
True

c++

// 定义给定的变换矩阵
Eigen::Matrix4f transformation_matrix1;
transformation_matrix1 << 0.99337785, 0.08483806, 0.07747866, -92.91055059,-0.07889607, 0.99392169, -0.07677948, -42.2437898,-0.08352154, 0.07015827, 0.99403318, 396.22910711,0, 0, 0, 1;// 从变换矩阵中解析欧拉角
Eigen::Vector3f euler_angles1 = transformation_matrix1.block<3, 3>(0, 0).eulerAngles(0, 2, 1);// 输出解析出的欧拉角
std::cout << "解析出的欧拉角 (ZYX 顺序):"<<euler_angles1 << std::endl;Eigen::JacobiSVD<Eigen::MatrixXf> svd;
//svd.setThreshold(1e-10);
svd.compute(transformation_matrix1, Eigen::ComputeFullU | Eigen::ComputeFullV);
Eigen::VectorXf singularValues = svd.singularValues();
Eigen::MatrixXf singularValueMatrix = singularValues.asDiagonal();
Eigen::MatrixXf U = svd.matrixU();
Eigen::MatrixXf V = svd.matrixV();
//Displaying the results
std::cout << "原始数据:\n" << transformation_matrix1  << std::endl;
std::cout << "重构数据:\n" << U * singularValueMatrix * V.transpose() << std::endl;
std::cout << "U:\n" << U << "\n\n";
std::cout <<  "S:\n" << singularValueMatrix << "\n\n";
std::cout << "V:\n" << V << "\n\n";

原始数据:
0.993378 0.0848381 0.0774787 -92.9106
-0.0788961 0.993922 -0.0767795 -42.2438
-0.0835215 0.0701583 0.994033 396.229
0 0 0 1
重构数据:
0.9934 0.0848412 0.077413 -92.9106
-0.0788853 0.993924 -0.0768136 -42.2438
-0.0835193 0.070161 0.994014 396.229
0 9.21136e-09 2.32831e-10 1
U:
-0.227074 0.457935 0.859496 -0.000554795
-0.103244 -0.888896 0.446323 -0.000252237
0.968386 0.0126106 0.249125 0.00236679
0.00244399 8.88704e-10 2.06488e-07 -0.999997
S:
409.166 0 0 0
0 1 0 0
0 0 1 0
0 0 0 0.002444
V:
-0.000729068 0.52398 0.797807 -0.298242
-0.000131827 -0.843758 0.534011 -0.0538979
0.00232899 0.116264 0.279886 0.952964
0.999997 3.72529e-09 2.01166e-07 -0.00244399

结论

M = U Σ V T M = U \Sigma V^{T} M=UΣVT

当分解的矩阵M相同时,不同库得出的U, Σ \Sigma Σ是相同的,V却不相同。numpy给出的直接就是VT,而EIGEN得出的为V.

参考

  1. https://eigen.tuxfamily.org/dox/group__SVD__Module.html
  2. https://numpy.org/doc/stable/reference/generated/numpy.linalg.svd.html
  3. https://stackoverflow.com/questions/75500005/linalg-svd-and-jacobisvdmatrixxf-svd-the-results-are-different
  4. https://stackoverflow.com/questions/74322089/difference-between-eigen-svd-and-np-linag-svd
  5. https://en.wikipedia.org/wiki/Singular_value_decomposition

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

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

相关文章

【Qt常用控件】—— 多元素控件

目录 1.1 List Widget 1.2 Table Widget 1.3 Tree Widget 1.4 小结 Qt 中提供的多元素控件有: QListWidget QListView QTableWidget QTableView QTreeWidget QTreeView xxWidget 和 xxView 之间的区别 以 QTableWidget 和 QTableView 为例&#xff1a; QTableView 是基于…

03-JAVA设计模式-备忘录模式

备忘录模式 什么是备忘录模式 Java中的备忘录模式&#xff08;Memento Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许在不破坏封装性的前提下捕获一个对象的内部状态&#xff0c;并在该对象之外保存这个状态&#xff0c;以便以后可以将对象恢复到原先保存的状态…

Idea:阿里巴巴Java编码插件

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 一、Alibaba Java Coding Guidelines插件介绍 二、使用步骤 总结 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、Alibaba Java Coding …

【AI】Deepstream入门(2)Ubuntu20.04安装Deepstream

1、安装GPU驱动 本人显卡型号:RTX4060 Laptop(笔记本专用显卡) 【AI】惠普暗夜精灵9安装Ubuntu20.04+nvidia驱动 2、安装cuda、cuDNN 【AI】Ubuntu20.04安装cuda、cuDNN 3、安装TensorRT 1)下载 下载地址:https://docs.nvidia.com/deeplearning/tensorrt/archives/i…

用于肺结节分类的常规 EHR 的纵向多模态Transformer集成成像和潜在临床特征

Longitudinal Multimodal Transformer Integrating Imaging and Latent Clinical Signatures from Routine EHRs for Pulmonary Nodule Classification 摘要 该研究提出了一种基于Transformer 的多模态策略&#xff0c;用于将重复成像与常规电子健康记录&#xff08;EHRs&…

低空经济概念

低空经济是指利用低空空域资源&#xff0c;通过低空交通工具和技术创新发展&#xff0c;促进航空产业、旅游、物流、紧急救援等多领域经济增长和产业融合。随着科技的不断进步和航空产业的快速发展&#xff0c;低空经济正逐渐成为全球经济的重要组成部分。 一、低空经济的主要特…

「珞石机器人」完成超5亿元战略+轮融资

珞石机器人ROKAE. 新一代智能机器人专家 近日&#xff0c;襄禾资本投资企业「珞石机器人」宣布完成超5亿元的战略轮融资&#xff0c;本次融资获得了国家制造业转型升级基金和邹城市新动能产业投资基金的共同加持&#xff0c;资金将主要用于市场开发、国际化开拓、产品升级迭代…

【【gitlab解决git Clone 出现 Permission denied, please try again.】】

【gitlab解决git Clone 出现 Permission denied, please try again.】 问题解决随便找一个地方 点击右键输入ssh -keygen -C "邮件"显示结果输入 登录gitlab然后再次git Clone就可以了。 问题 git clone的时候出现 Permission denied, please try again 解决 随便…

怎么使用下载视频号视频?详细视频下载使用教程

越来越多的人开始使用视频号等平台来分享和观看视频内容。然而&#xff0c;有时候我们可能会遇到需要将视频保存到本地设备以便离线观看或进一步编辑的情况。 本文将为您详细介绍如何使用视频下载plus&#xff0c;来下载视频号的视频内容。 一、了解视频号下载功能 首先&…

http忽略ssl认证

我们在发请求时&#xff0c;会遇到需要ssl证书验证的报错&#xff0c;针对该错误以及所使用的不同的创建连接的方式&#xff0c;进行ssl证书忽略 忽略SSL证书的流程 简介&#xff1a;需要告诉client使用一个不同的TrustManager。TrustManager是一个检查给定的证书是否有效的类…

【可下载】CDA 1级教材《精益业务数据分析》2023最新版

CDA一级认证教材&#xff1a;《精益业务数据分析》 全面、系统地讲述业务描述性分析为企业决策行为创造价值的全流程技能&#xff0c;涵盖描述性数据分析方法、业务分析方法、数据分析结果应用方法等内容。 条理清晰的结构、通俗易懂的语言、完整立体的知识框架为读者铺开一幅…

python逆向基础流程(纯小白教程)

一&#xff0c;例题链接 NSSCTF | 在线CTF平台 二&#xff0c;文件特征 使用工具查看文件信息&#xff0c;发现是pyinsatller打包的exe文件&#xff0c;如果硬用ida分析成汇编或c语言根本摸清楚程序的逻辑&#xff0c;所以思路是反编译成py文件直接分析python代码 三&#xf…

【go零基础】go-zero从零基础学习到实战教程 - 2项目初始化

到项目初始化过程了&#xff0c;这边的项目设计完全按照作者自己的喜好来进行定义和设置的&#xff0c;所以各位完全可以按照自己的偏好自喜设置哈。 首先是创建一个工作文件夹哈。 别问为啥不直接quickstart&#xff0c;因为quickstart生成的api名字是greet&#xff0c;改起来…

【EMQX】使用websocket订阅EMQX数据

需求&#xff1a;某平台希望通过 websocket 来订阅 EMQX平台上的某些 Topic数据进行处理 1、EMQX 服务配置 前提是EMQX服务正常安装运行了&#xff0c;如果EMQX服务未安装的话&#xff0c;详见以下文章关于如何安装部署服务&#xff1a; 搭建自己的MQTT服务器、实现设备上云(W…

uniapp-css:拼图(不规则图片拼插)、碎片

拼图案例样式 高斯模糊的地方可以对应的使用fliter属性和opacity来调节样式。 其余碎片和图片对应: 这段代码实现了一个拼图效果的Vue组件。以下是对代码的详细解析: 模板部分: 在模板中使用v-for指令遍历imgs数组中的每个图片对象,为每个图片创建一个元素。 使用:cla…

实验一: 设备密码配置与远程管理

1.实验环境 用路由器和交换机搭建实验环境 2.需求描述 实现管理员主机对交换机和路由器的远程管理 设备上配置的密码都要被加密 3.推荐步骤 对路由器配置的步骤如下&#xff1a; 实现路由器和PC的连通性配置VTY密码和特权模式密码在PC上Telnet 到路由器。 对交换机配置的…

柏曼和琪朗护眼灯哪个好?书客、柏曼、琪朗护眼大路灯横测

护眼大路灯是一种备受用户认可的照明电器&#xff0c;但是市面上众多大路灯品牌的评价都良莠不齐&#xff0c;外观几乎清一色的大路灯在品质上却有着很大的区别&#xff0c;很多朋友想要入手但是却迟迟不敢下手。那么&#xff0c;怎么才能买到性能优越、各方面又出色的大路灯呢…

JAVA实现easyExcel模版导出

easyExcel文档 模板注意&#xff1a; 用 {} 来表示你要用的变量 &#xff0c;如果本来就有"{“,”}" &#xff0c;特殊字符用"{“,”}"代替{} 代表普通变量{.}代表是list的变量 添加pom依赖 <dependency><groupId>com.alibaba</groupId&g…

MyPerf4J:一个针对高并发、低延迟应用设计的高性能 Java 性能监控和统计工具。

试用效果&#xff1a; git地址&#xff1a;https://github.com/LinShunKang/MyPerf4J 下载&#xff1a; https://github.com/LinShunKang/Objects/blob/master/zips/CN/MyPerf4J-ASM-3.4.0-SNAPSHOT.zip?rawtrue 配置&#xff1a; # 配置监控应用的名称 app_name MyApp#…

半导体晶圆厂内外网数据单向导出,什么样的方案才安全又便捷?

半导体晶圆厂企业为了隔绝外部⽹络有害攻击、保护⽹络和数据安全&#xff0c;通常采⽤物理隔离的⽅式&#xff0c;将企业内⽹与互联⽹隔离。⽹络隔离后&#xff0c;基于业务开展需求&#xff0c;部分重要数据仍需由内⽹导⼊及导出⾄外部⽹络区域。为保障数据的安全合规性&#…