C++笔记之Eigen库的使用

news2024/11/24 1:32:32

C++笔记之Eigen库的使用

code review!

文章目录

  • C++笔记之Eigen库的使用
    • 0.矩阵构造和矩阵初始化
    • 1.声明一个2\*3的float矩阵:Matrix<float, 2, 3> matrix_23;
    • 2.初始化Matrix<float, 2, 3> matrix_23;
      • - 使用逗号初始化器:
      • - 使用赋值运算符逐个赋值:
    • 3.声明一个3维向量Vector3d
      • - Vector3d v_3d;
      • - Matrix<double, 3, 1> vd_3d;
    • 4.初始化Vector3d
    • 5.初始化Matrix<float, 3, 1> vd_3d
    • 6.将3维向量或矩阵初始化为零
    • 7.将向量或矩阵初始化为零
    • 8.动态大小的二维矩阵
    • 9.矩阵和向量元素访问
    • 10.矩阵和矩阵相乘
    • 11.矩阵和向量相乘
    • 12.eigen中的成员函数colwise()
    • 13.矩阵相乘前的类型转换
    • 14.矩阵转置
    • 15.矩阵四则运算中的加减
    • 16.矩阵除以标量(矩阵的数乘)
    • 17.矩阵乘以标量(矩阵的数乘)
    • 18.矩阵各元素和
    • 19.矩阵的迹
    • 20.矩阵的逆
    • 21.矩阵除法(实际上是矩阵与逆矩阵的乘法)
    • 23.矩阵的行列式
    • 24.矩阵的特征值和特征向量
    • 25.使用Eigen库中的SelfAdjointEigenSolver类来计算一个3x3矩阵的特征值和特征向量
    • 26.解线性方程组 Ax = b,使用LU分解
    • 27.解线性方程组 Ax = b,使用QR分解
    • 27.解线性方程组 Ax = b,使用Cholesky分解
    • 28.将旋转向量转为旋转矩阵
    • 29.将旋转矩阵转为旋转向量
    • 30.使用旋转向量对向量进行旋转的坐标变换
    • 31.将旋转矩阵转换为欧拉角
    • 32.创建欧氏变换矩阵
    • 33.使用变换矩阵进行坐标变换
    • 34.创建四元数
    • 35.使用四元数旋转向量
    • 36.使用刚体变换(欧氏变换)来进行旋转和平移操作
    • 37.eigen的数据类型
    • 38.eigen的block()函数
    • 39.eigen中的.col()和.row()方法
    • 40.eigen的点乘和叉乘.dot()和.cross()
    • 41.元素乘积.prod()——即向量中所有元素的乘积
    • 42.元素均值.mean()
    • 43.查找向量或矩阵中的最小值和最大值minCoeff()和maxCoeff()
    • 44.生成随机矩阵random()
    • 45.用于处理数组(元素级操作)的数据结构Array类
    • 46.eigen中Array类的常见操作

0.矩阵构造和矩阵初始化

在这里插入图片描述

1.声明一个2*3的float矩阵:Matrix<float, 2, 3> matrix_23;

在这里插入图片描述

2.初始化Matrix<float, 2, 3> matrix_23;

- 使用逗号初始化器:

在这里插入图片描述

- 使用赋值运算符逐个赋值:

在这里插入图片描述

3.声明一个3维向量Vector3d

下述两种方法是等价的

- Vector3d v_3d;

- Matrix<double, 3, 1> vd_3d;

在这里插入图片描述

4.初始化Vector3d

在这里插入图片描述

5.初始化Matrix<float, 3, 1> vd_3d

在这里插入图片描述

6.将3维向量或矩阵初始化为零

在这里插入图片描述

7.将向量或矩阵初始化为零

在这里插入图片描述

8.动态大小的二维矩阵

在这里插入图片描述

9.矩阵和向量元素访问

在这里插入图片描述

10.矩阵和矩阵相乘

在这里插入图片描述

11.矩阵和向量相乘

  • 方法一:使用矩阵乘法运算符
    在这里插入图片描述

  • 方法二:使用矩阵的 dot() 成员函数
    在这里插入图片描述

12.eigen中的成员函数colwise()

在这里插入图片描述

13.矩阵相乘前的类型转换

在这里插入图片描述

14.矩阵转置

在这里插入图片描述

15.矩阵四则运算中的加减

在这里插入图片描述

16.矩阵除以标量(矩阵的数乘)

在这里插入图片描述

17.矩阵乘以标量(矩阵的数乘)

在这里插入图片描述

18.矩阵各元素和

在这里插入图片描述

19.矩阵的迹

在这里插入图片描述

20.矩阵的逆

在这里插入图片描述

21.矩阵除法(实际上是矩阵与逆矩阵的乘法)

在这里插入图片描述

23.矩阵的行列式

在这里插入图片描述

24.矩阵的特征值和特征向量

在这里插入图片描述

25.使用Eigen库中的SelfAdjointEigenSolver类来计算一个3x3矩阵的特征值和特征向量

在这里插入图片描述

这个示例演示了使用Eigen库中的SelfAdjointEigenSolver类来计算一个3x3矩阵的特征值和特征向量。它首先创建一个对称矩阵 matrix_33,然后通过计算其转置与自身的乘积来准备进行特征值和特征向量计算。

分析:

  • Eigen::Matrix3d 表示一个3x3的矩阵,matrix_33 是我们创建的对称矩阵。
  • SelfAdjointEigenSolver<Eigen::Matrix3d> 是特征值和特征向量求解器的类型,这里使用 SelfAdjointEigenSolver 类来处理对称矩阵。
  • eigen_solver 是我们创建的特征值和特征向量求解器的实例,它在被构造时会计算给定矩阵的特征值和特征向量。
  • eigen_solver.eigenvalues() 用于获取计算得到的特征值,它返回一个向量,表示矩阵的特征值。
  • eigen_solver.eigenvectors() 用于获取计算得到的特征向量,它返回一个矩阵,其中每一列是一个特征向量。

确保你已经将Eigen库的头文件路径和库链接路径适配到你的项目配置中,然后编译并运行上述代码。你将会看到特征值和特征向量的输出。这个示例演示了如何使用Eigen库来进行矩阵的特征值和特征向量计算。

26.解线性方程组 Ax = b,使用LU分解

在这里插入图片描述

代码

#include <iostream>
#include <Eigen/Dense>

int main() {
    // 创建一个系数矩阵A和一个常数向量b
    Eigen::MatrixXd A(3, 3);
    A << 2, -1, 0,
         -1, 2, -1,
         0, -1, 2;

    Eigen::VectorXd b(3);
    b << 1, 2, 3;

    // 解线性方程组 Ax = b
    Eigen::VectorXd x = A.fullPivLu().solve(b);

    std::cout << "Coefficient Matrix A:\n" << A << "\n";
    std::cout << "Constant Vector b:\n" << b << "\n";
    std::cout << "Solution Vector x:\n" << x << "\n";

    return 0;
}

27.解线性方程组 Ax = b,使用QR分解

在这里插入图片描述

代码

#include <iostream>
#include <Eigen/Dense>

int main() {
    // 创建一个系数矩阵A和一个常数向量b
    Eigen::MatrixXd A(3, 3);
    A << 2, -1, 0,
         -1, 2, -1,
         0, -1, 2;

    Eigen::VectorXd b(3);
    b << 1, 2, 3;

    // 进行QR分解
    Eigen::ColPivHouseholderQR<Eigen::MatrixXd> qr(A);
    
    // 解线性方程组 Ax = b
    Eigen::VectorXd x = qr.solve(b);

    std::cout << "Coefficient Matrix A:\n" << A << "\n";
    std::cout << "Constant Vector b:\n" << b << "\n";
    std::cout << "Solution Vector x:\n" << x << "\n";

    return 0;
}

27.解线性方程组 Ax = b,使用Cholesky分解

在C++中,你可以使用Eigen库进行Cholesky分解来解决线性方程组。Cholesky分解是一种用于对称正定矩阵的分解方法,可以有效地解决线性方程组。以下是一个使用Eigen库进行Cholesky分解解线性方程组的示例代码:

在这里插入图片描述

在这个示例中,我们首先创建一个系数矩阵 A 和一个常数向量 b,代表线性方程组 Ax = b。然后使用LLT类进行Cholesky分解,如果分解成功(正定矩阵才能成功分解),就调用solve(b)方法来解线性方程组并计算得到解向量 x

请注意,Cholesky分解适用于对称正定矩阵。在使用之前,你应该确保矩阵 A 是对称正定的。如果矩阵不满足这些条件,Cholesky分解将会失败。

确保你已经将Eigen库的头文件路径和库链接路径适配到你的项目配置中,然后编译并运行上述代码。你将会看到系数矩阵、常数向量和解向量的输出。这个示例演示了如何使用Eigen库进行Cholesky分解来解决线性方程组。
代码

#include <iostream>
#include <Eigen/Dense>

int main() {
    // 创建一个系数矩阵A和一个常数向量b
    Eigen::MatrixXd A(3, 3);
    A << 4, 2, 2,
         2, 5, 1,
         2, 1, 6;

    Eigen::VectorXd b(3);
    b << 4, 6, 7;

    // 进行Cholesky分解
    Eigen::LLT<Eigen::MatrixXd> lltOfA(A);
    if (lltOfA.info() == Eigen::Success) {
        // 解线性方程组 Ax = b
        Eigen::VectorXd x = lltOfA.solve(b);

        std::cout << "Coefficient Matrix A:\n" << A << "\n";
        std::cout << "Constant Vector b:\n" << b << "\n";
        std::cout << "Solution Vector x:\n" << x << "\n";
    } else {
        std::cout << "Cholesky decomposition failed!" << std::endl;
    }

    return 0;
}

28.将旋转向量转为旋转矩阵

在这里插入图片描述

代码

#include <iostream>
#include <Eigen/Dense>

int main() {
    using namespace Eigen;

    // 创建一个旋转向量,绕 Z 轴旋转 45 度
    AngleAxisd rotation_vector(M_PI / 4, Vector3d(0, 0, 1));

    // 将旋转向量转换为旋转矩阵
    Matrix3d rotation_matrix = rotation_vector.toRotationMatrix();

    // 输出旋转向量
    std::cout << "Rotation Vector: " << rotation_vector.angle() << " around "
              << rotation_vector.axis().transpose() << "\n";

    // 输出旋转矩阵
    std::cout << "Rotation Matrix:\n" << rotation_matrix << "\n";

    return 0;
}

29.将旋转矩阵转为旋转向量

在这里插入图片描述

代码

#include <iostream>
#include <Eigen/Dense>

int main() {
    using namespace Eigen;

    // 创建一个旋转矩阵,绕 Z 轴旋转 45 度
    Matrix3d rotation_matrix;
    rotation_matrix << 0.707107, -0.707107, 0,
                      0.707107, 0.707107, 0,
                      0, 0, 1;

    // 从旋转矩阵中获取旋转向量
    AngleAxisd rotation_vector(rotation_matrix);

    // 输出旋转向量的角度和轴
    std::cout << "Rotation Angle: " << rotation_vector.angle() << " radians\n";
    std::cout << "Rotation Axis: " << rotation_vector.axis().transpose() << "\n";

    return 0;
}

30.使用旋转向量对向量进行旋转的坐标变换

在这里插入图片描述

31.将旋转矩阵转换为欧拉角

在这里插入图片描述

32.创建欧氏变换矩阵

在这里插入图片描述

33.使用变换矩阵进行坐标变换

在这里插入图片描述

34.创建四元数

在这里插入图片描述

35.使用四元数旋转向量

在这里插入图片描述

36.使用刚体变换(欧氏变换)来进行旋转和平移操作

在这里插入图片描述

代码

#include <iostream>
#include <vector>
#include <algorithm>
#include <Eigen/Core>
#include <Eigen/Geometry>

using namespace std;
using namespace Eigen;

int main(int argc, char** argv) {
  // 创建两个旋转四元数 q1 和 q2,表示两个刚体的旋转
  Quaterniond q1(0.35, 0.2, 0.3, 0.1), q2(-0.5, 0.4, -0.1, 0.2);
  
  // 归一化旋转四元数,确保表示合法的旋转
  q1.normalize();
  q2.normalize();
  
  // 创建两个平移向量 t1 和 t2,表示两个刚体的平移
  Vector3d t1(0.3, 0.1, 0.1), t2(-0.1, 0.5, 0.3);
  
  // 创建一个点 p1,表示在初始坐标系中的一个点
  Vector3d p1(0.5, 0, 0.2);

  // 创建两个欧氏变换矩阵 T1w 和 T2w,表示初始坐标系到两个刚体的变换
  Isometry3d T1w(q1), T2w(q2);
  
  // 将平移向量 t1 和 t2 分别添加到变换矩阵 T1w 和 T2w 中
  T1w.pretranslate(t1);
  T2w.pretranslate(t2);

  // 计算新的坐标 p2,在第二个刚体的坐标系中的坐标
  Vector3d p2 = T2w * T1w.inverse() * p1;

  // 输出变换后的坐标 p2
  cout << "Transformed Point p2: " << p2.transpose() << endl;

  return 0;
}

37.eigen的数据类型

在这里插入图片描述

38.eigen的block()函数

在这里插入图片描述

39.eigen中的.col()和.row()方法

在这里插入图片描述

40.eigen的点乘和叉乘.dot()和.cross()

在这里插入图片描述

41.元素乘积.prod()——即向量中所有元素的乘积

在这里插入图片描述

42.元素均值.mean()

在这里插入图片描述

43.查找向量或矩阵中的最小值和最大值minCoeff()和maxCoeff()

在这里插入图片描述

44.生成随机矩阵random()

在这里插入图片描述

45.用于处理数组(元素级操作)的数据结构Array类

在这里插入图片描述
在这里插入图片描述

46.eigen中Array类的常见操作

在这里插入图片描述

代码

// 逐元素操作Vectorized operations on each element independently  
// Eigen                       // Matlab        //注释  
R = P.cwiseProduct(Q);         // R = P .* Q    //逐元素乘法  
R = P.array() * s.array();     // R = P .* s    //逐元素乘法(s为标量)  
R = P.cwiseQuotient(Q);        // R = P ./ Q    //逐元素除法  
R = P.array() / Q.array();     // R = P ./ Q    //逐元素除法  
R = P.array() + s.array();     // R = P + s     //逐元素加法(s为标量)  
R = P.array() - s.array();     // R = P - s     //逐元素减法(s为标量)  
R.array() += s;                // R = R + s     //逐元素加法(s为标量)  
R.array() -= s;                // R = R - s     //逐元素减法(s为标量)  
R.array() < Q.array();         // R < Q         //逐元素比较运算  
R.array() <= Q.array();        // R <= Q        //逐元素比较运算  
R.cwiseInverse();              // 1 ./ P        //逐元素取倒数  
R.array().inverse();           // 1 ./ P        //逐元素取倒数  
R.array().sin()                // sin(P)        //逐元素计算正弦函数  
R.array().cos()                // cos(P)        //逐元素计算余弦函数  
R.array().pow(s)               // P .^ s        //逐元素计算幂函数  
R.array().square()             // P .^ 2        //逐元素计算平方  
R.array().cube()               // P .^ 3        //逐元素计算立方  
R.cwiseSqrt()                  // sqrt(P)       //逐元素计算平方根  
R.array().sqrt()               // sqrt(P)       //逐元素计算平方根  
R.array().exp()                // exp(P)        //逐元素计算指数函数  
R.array().log()                // log(P)        //逐元素计算对数函数  
R.cwiseMax(P)                  // max(R, P)     //逐元素计算R和P的最大值  
R.array().max(P.array())       // max(R, P)     //逐元素计算R和P的最大值  
R.cwiseMin(P)                  // min(R, P)     //逐元素计算R和P的最小值  
R.array().min(P.array())       // min(R, P)     //逐元素计算R和P的最小值  
R.cwiseAbs(P)                   // abs(P)        //逐元素计算R和P的绝对值  
R.array().abs()                // abs(P)        //逐元素计算绝对值  
R.cwiseAbs2()                  // abs(P.^2)     //逐元素计算平方  
R.array().abs2()               // abs(P.^2)     //逐元素计算平方  
(R.array() < s).select(P,Q);  // (R < s ? P : Q)         //根据R的元素值是否小于s,选择P和Q的对应元素  
R = (Q.array()==0).select(P,A) // R(Q==0) = P(Q==0) R(Q!=0) = P(Q!=0)      //根据Q中元素等于零的位置选择P中元素  
R = P.unaryExpr(ptr_fun(func)) // R = arrayfun(func, P)     // 对P中的每个元素应用func函数  

参考链接:一文学会Eigen库

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

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

相关文章

JZ38 字符串的排列

题目地址&#xff1a;字符串的排列_牛客题霸_牛客网 题目回顾&#xff1a; 解题思路&#xff1a; 这里用到了全排列和剪枝。 首先我们来说全排列&#xff0c;设置一个vis数组来记录当期元素是否被使用过&#xff0c;然后dfs遍历整个数组&#xff0c;列出所有符合条件的路径就是…

【ts】【cocos creator】excel表格转JSON

需要将表格导出为text格式放到项目resources/text文件夹下 新建场景&#xff0c;挂载到Canvas上运行 表格文件格式&#xff1a; 保存格式选text tableToJson : import CryptoJS require(./FileSaver);const { ccclass, property } cc._decorator;ccclass export default c…

完结,从零开始学python(十八)想成为一名APP逆向工程师,需要掌握那些技术点?

作为从零学python的最后一篇文章&#xff0c;我们来简单的回顾一下内容 1.编程语法 语法编程并发编程 网络编程多线程/多进程/协程 数据库编程 MySQLRedisMongoDB 2.机器学习 3.全栈开发 4.数据分析 NumpypandasMatplotlibHadoopSpark 5.爬虫工程师养成 采集功底自动化…

js合并数组对象(将数组中具有相同属性对象合并到一起,组成一个新的数组)

一、根据数组对象中某一key值&#xff0c;合并相同key值的字段&#xff0c;到同一个数组对象中&#xff0c;组成新的数组 1.原数组&#xff1a; var array [{ id: 1, name: Alice },{ id: 2, name: Bob },{ id: 1, age: 25 },{ id: 3, name: Charlie, age: 30 } ];2.合并后数…

【JVM】Java内存泄露的排查思路?

文章目录 Java内存为什么会泄露&#xff1f;java内存泄露的排查思路 Java内存为什么会泄露&#xff1f; Java内存泄露&#xff08;Memory Leak&#xff09;是指在Java程序中&#xff0c;无用的对象占用了堆内存&#xff0c;但无法被垃圾回收器回收释放&#xff0c;从而导致可用…

Java地图专题课 基本API BMapGLLib 地图找房案例 MongoDB

本课程基于百度地图技术&#xff0c;由基础入门开始到应用实战&#xff0c;适合零基础入门学习。将企业项目中地图相关常见应用场景的落地实战&#xff0c;包括有地图找房、轻骑小程序、金运物流等。同时讲了基于Netty实现高性能的web服务&#xff0c;来处理高并发的问题。还讲…

Vue前端 更具router.js 中的meta的roles实现路由卫士,实现权限判断。

参考了之篇文章 1、我在登陆时获取到登录用户的角色名roles&#xff0c;并存入sessionStorage中&#xff0c;具体是在login页面实现&#xff0c;还是在menu页面实现都可以。在menu页面实现&#xff0c;可以显得登陆快一些。 2、编写router.js&#xff0c;注意&#xff0c;一个…

链表(基础详解、实现、OJ笔试题)

文章目录 &#x1f9da;什么是链表&#xff08;链表概念及分类&#xff09;链表分类单链表和双链表的区别 &#x1f6b4;‍♂️单链表、双向链表的实现单链表的实现双向链表的实现 &#x1f349;链表经典OJ笔试题反转单链表移除链表元素合并两个有序链表链表分割链表的中间结点…

Ajax入门+aixos+HTTP协议

一.Ajax入门 概念:AJAX是浏览器与服务器进行数据通信的技术 axios使用: 引入axios.js使用axios函数:传入配置对象,再用.then回调函数接受结果,并做后续处理 <!DOCTYPE html> <html><head><meta charset"utf-8"><title>01.axios使用…

【软件工程】面向对象方法-RUP

RUP&#xff08;Rational Unified Process&#xff0c;统一软件开发过程&#xff09;。 RUP特点 以用况驱动的&#xff0c;以体系结构为中心的&#xff0c;迭代增量式开发 用况驱动 用况是能够向用户提供有价值结果的系统中的一种功能用况获取的是功能需求 在系统的生存周期中…

机器学习笔记:李宏毅 stable diffusion

1 基本框架 ①&#xff1a;文字变成向量 ②&#xff1a;喂入噪声文字encoder&#xff0c;产生中间产物 ③&#xff1a;decoder 还原图片 2 text encoder 这张图越往右下表示效果越好&#xff0c;可以看到text encoder尺寸越大&#xff0c;对后续生成图片的增益越多 3 评价图…

【linux基础操作】如何一键下载 各个版本的python库文件

把需要下载的库名字&版本号&#xff0c;存在.txt文件中 2. 输入命令执行&#xff0c;下载 pip install -r your_file_name该命令的作用是从指定的文本文件中安装 Python 依赖库。 在这个命令中&#xff0c;-r 参数表示从一个文本文件&#xff08;通常以 .txt 结尾&#xf…

FastAPI入门

目录 FastAPI FastAPI 是什么 为什么要用 FastAPI FastAPI 入门 安装 用 FastAPI 写个接口 调试接口 创建快捷请求 保存为快捷请求 发送请求 总结 FastAPI FastAPI 是什么 什么是 FastAPI 呢&#xff1f; FastAPI 是 Python 的一个框架&#xff0c;如果要类比的话…

Java 的 Stream

一、创建 Stream 1.1、创建 Stream 流 1.1.1、List 集合获取 Stream 流 Collection<String> list new ArrayList<>(); Stream<String> s1 list.stream(); 1.1.2、Map 集合获取 stream 流 Map<String, Integer> map new HashMap<>(); // …

动态链接(8/13)

静态链接的缺点&#xff1a;生成的可执行文件体积较大&#xff0c;当多个程序引用相同的公共代码时&#xff0c;这些公共代码会多次加载到内存&#xff0c;浪费内存资源。 为了解决这个问题&#xff0c;动态链接对静态链接做了一些优化&#xff1a;对一些公用的代码&#xff0…

Titanic--细节记录三

目录 image sklearn模型算法选择路径图 留出法划分数据集 ‘留出’的含义 基本步骤和解释 具体例子 创造一个数据集 留出法划分 预测结果可视化 分层抽样 设置方法 划分数据集的常用方法 train_test_split 什么情况下切割数据集的时候不用进行随机选取 逻辑回归…

Linux系统下安装Git软件

环境说明 Linux系统&#xff1a;CentOS 7.9 安装GCC等 JDK版本&#xff1a;jdk-8u202-linux-x64.tar.gz Maven版本&#xff1a;apache-maven-3.8.8-bin.tar.gz 在以上环境下安装Git&#xff08;git-2.41.0.tar.gz&#xff09;软件。 查看是否安装Git软件 查看Git版本&#…

python代码一行过长怎么办,python中一行代码太长

这篇文章主要介绍了python每行代码长度不能超过100个字符&#xff0c;具有一定借鉴价值&#xff0c;需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获&#xff0c;下面让小编带着大家一起了解一下。 30行python代码实现豆瓣电影排行爬取 实现过程完整代码 今天我们想实…

四、Linux常用命令(一)

1、ls命令 (1)ls: list&#xff0c;列表。 (2)作用&#xff1a;使用列表把当前文件夹下所有文件显示出来。 (3)ls -a: 显示所有文件&#xff0c;包括隐藏文件。 (3)ls -l: 显示文件的详细信息。 (3)显示所有文件且显示详细信息&#xff0c;以下四种方式都可以。 ls -a -l…

腾讯云2核2g轻量应用服务器能容纳多少人?

腾讯云轻量应用服务器2核2g能容纳多少人&#xff1f;轻量应用服务器2核2g配置自带4M公网带宽&#xff0c;以网站应用为例&#xff0c;假设优化后的网页平均大小为60KB&#xff0c;2核2G4M带宽轻量服务器可以支持10个并发数&#xff0c;即同时10个人在1秒内同时打开网站&#xf…