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

已知特征值求特征向量c语言,C++ Eigen库计算矩阵特征值及特征向量

本文主要讲解利用Eigen库计算矩阵的特征值及特征向量并与Matlab计算结果进行比较。

C++Eigen库代码

#include

#include

#include

using namespace Eigen;

using namespace std;

void Eig()

{

Matrix3d A;

A << 1, 2, 3, 4, 5, 6, 7, 8, 9;

cout << "Here is a 3x3 matrix, A:" << endl << A << endl << endl;

EigenSolver es(A);

Matrix3d D = es.pseudoEigenvalueMatrix();

Matrix3d V = es.pseudoEigenvectors();

cout << "The pseudo-eigenvalue matrix D is:" << endl << D << endl;

cout << "The pseudo-eigenvector matrix V is:" << endl << V << endl;

cout << "Finally, V * D * V^(-1) = " << endl << V * D * V.inverse() << endl;

}

int main()

{

Eig();

}

计算结果:

d66dff9e5a3bbf1f0f69fffdc3eebea9.png

最大最小特征值及其索引位置

//maxCoeff

//minCoeff

int col_index, row_index;

cout << D.maxCoeff(&row_index, &col_index) << endl;

cout << row_index << " " << col_index << endl;

Matlab 代码

clear all

clc

A = [1 2 3;4 5 6;7 8 9]

[V,D] = eig(A)

Matlab计算结果

b93b83344e4c1474833c9136b29b0fdd.png

使用sort()函数对特征值排序

主成份分析以及许多应用时候,需要对特征值大小排列。

A = magic(6);

[V,D] = eig(A)

[D_S,index] = sort(diag(D),'descend')

V_S = V(:,index)

结果

V =

0.4082 -0.2887 0.4082 0.1507 0.4714 -0.4769

0.4082 0.5774 0.4082 0.4110 0.4714 -0.4937

0.4082 -0.2887 0.4082 -0.2602 -0.2357 0.0864

0.4082 0.2887 -0.4082 0.4279 -0.4714 0.1435

0.4082 -0.5774 -0.4082 -0.7465 -0.4714 0.0338

0.4082 0.2887 -0.4082 0.0171 0.2357 0.7068

D =

111.0000 0 0 0 0 0

0 27.0000 0 0 0 0

0 0 -27.0000 0 0 0

0 0 0 9.7980 0 0

0 0 0 0 -0.0000 0

0 0 0 0 0 -9.7980

D_S =

111.0000

27.0000

9.7980

-0.0000

-9.7980

-27.0000

V_S =

0.4082 -0.2887 0.1507 0.4714 -0.4769 0.4082

0.4082 0.5774 0.4110 0.4714 -0.4937 0.4082

0.4082 -0.2887 -0.2602 -0.2357 0.0864 0.4082

0.4082 0.2887 0.4279 -0.4714 0.1435 -0.4082

0.4082 -0.5774 -0.7465 -0.4714 0.0338 -0.4082

0.4082 0.2887 0.0171 0.2357 0.7068 -0.4082

结语

本人是在实验中利用Eigen库求取最小特征值对应特征向量做PCA分析时使用,曾经再不知道有Eigen库的情况下自己写过矩阵相关运算的模板类,现在接触到Eigen库,就把困扰过自己的问题今天做一个小小总结。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章:

  • 数据库设计范式深入浅出
  • 数据库设计三大范式应用实例剖析
  • c语言 已知三位数数列,C语言程序设计100例之(23):数列求和
  • android 实现qq动画,Android实现仿QQ登录界面背景动画效果
  • “磁碟机”病毒详尽分析报告
  • android自动无限轮播,Android安卓比较完美的无限自动轮播
  • 端点安全:为何只有检测率远远不够
  • android 添加json动画,Lottie 站在巨人的肩膀上实现 Android 酷炫动画效果
  • android 找不到布局id,为什么给layout加上id,ButterKnife就找不到资源了?
  • 安装BizTalk Server 2006出现BizTalk架构编辑器同类型化DataSet设计器冲突
  • android 路由表参数,Android点我达路由DRouter框架设计与解析
  • WEB2.0下的门户网站建设
  • android https 证书过期变更,使用自定义证书的Android https连接
  • android7彩蛋oppo,OPPO ColorOS 7来了!没想到重磅消息却是“彩蛋”Reno3系列?
  • 利用CodeSmith为SQL Server CE生成项目代码
  • “Material Design”设计规范在 ComponentOne For WinForm 的全新尝试!
  • 「译」Node.js Streams 基础
  • C++类的相互关联
  • Centos6.8 使用rpm安装mysql5.7
  • CODING 缺陷管理功能正式开始公测
  • CSS相对定位
  • FastReport在线报表设计器工作原理
  • go语言学习初探(一)
  • Java 网络编程(2):UDP 的使用
  • java8 Stream Pipelines 浅析
  • javascript 哈希表
  • JavaScript类型识别
  • Java基本数据类型之Number
  • JS学习笔记——闭包
  • Laravel Mix运行时关于es2015报错解决方案
  • Linux编程学习笔记 | Linux IO学习[1] - 文件IO
  • Python学习之路16-使用API
  • session共享问题解决方案
  • socket.io+express实现聊天室的思考(三)
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • Unix命令
  • 阿里云购买磁盘后挂载
  • 闭包,sync使用细节
  • 无服务器化是企业 IT 架构的未来吗?
  • 详解移动APP与web APP的区别
  • 源码安装memcached和php memcache扩展
  • 智能合约开发环境搭建及Hello World合约
  • kubernetes资源对象--ingress
  • PostgreSQL 快速给指定表每个字段创建索引 - 1
  • 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解 ...
  • ​软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】​
  • #100天计划# 2013年9月29日
  • (03)光刻——半导体电路的绘制
  • (1)STL算法之遍历容器
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (黑马出品_高级篇_01)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
  • (每日持续更新)jdk api之StringBufferInputStream基础、应用、实战
  • (十三)Java springcloud B2B2C o2o多用户商城 springcloud架构 - SSO单点登录之OAuth2.0 根据token获取用户信息(4)...
  • (算法二)滑动窗口
  • (详细版)Vary: Scaling up the Vision Vocabulary for Large Vision-Language Models