高翔slam14讲的部分的实例代码:

eigen部分(一)

矩阵的一些定义方法和基本操作

#include <iostream>
#include <ctime>
using namespace std;// Eigen 部分
#include <eigen3/Eigen/Core>
// 稠密矩阵的代数运算(逆,特征值等)
#include <eigen3/Eigen/Dense>#define MATRIX_SIZE 50/****************************
* 本程序演示了 Eigen 基本类型的使用
****************************/int main( int argc, char** argv )
{
// Eigen 以矩阵为基本数据单元。它是一个模板类。它的前三个参数为:数据类型,行,列
// 声明一个 2*3 的 float 矩阵
Eigen::Matrix<float, 2, 3> matrix_23;
// 同时,Eigen 通过 typedef 提供了许多内置类型,不过底层仍是 Eigen::Matrix
// 例如 Vector3d 实质上是 Eigen::Matrix<double, 3, 1>
Eigen::Vector3d v_3d;
// 还有 Matrix3d 实质上是 Eigen::Matrix<double, 3, 3>
Eigen::Matrix3d matrix_33 = Eigen::Matrix3d::Zero(); //初始化为零
// 如果不确定矩阵大小,可以使用动态大小的矩阵
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > matrix_dynamic;
// 更简单的
Eigen::MatrixXd matrix_x;
// 这种类型还有很多,我们不一一列举// 下面是对矩阵的操作
// 输入数据
matrix_23 << 1, 2, 3, 4, 5, 6;
// 输出
cout << matrix_23 << endl;// 用()访问矩阵中的元素
for (int i=0; i<1; i++)
for (int j=0; j<2; j++)
cout<<matrix_23(i,j)<<endl;v_3d << 3, 2, 1;
// 矩阵和向量相乘(实际上仍是矩阵和矩阵)
// 但是在这里你不能混合两种不同类型的矩阵,像这样是错的
// Eigen::Matrix<double, 2, 1> result_wrong_type = matrix_23 * v_3d;// 应该显式转换
Eigen::Matrix<double, 2, 1> result = matrix_23.cast<double>() * v_3d;
cout << "result"<<result<< endl;// 同样你不能搞错矩阵的维度
// 试着取消下面的注释,看看会报什么错
// Eigen::Matrix<double, 2, 3> result_wrong_dimension = matrix_23.cast<double>() * v_3d;// 一些矩阵运算
// 四则运算就不演示了,直接用对应的运算符即可。
matrix_33 = Eigen::Matrix3d::Random();
cout << matrix_33 << endl << endl;cout << matrix_33.transpose() << endl; //转置
cout << matrix_33.sum() << endl; //各元素和
cout << matrix_33.trace() << endl; //迹
cout << 10*matrix_33 << endl; //数乘
cout << matrix_33.inverse() << endl; //逆
cout << matrix_33.determinant() << endl; //行列式// 特征值
// 实对称矩阵可以保证对角化成功
Eigen::SelfAdjointEigenSolver<Eigen::Matrix3d> eigen_solver ( matrix_33.transpose()*matrix_33 );
cout << "Eigen values = " << eigen_solver.eigenvalues() << endl;
cout << "Eigen vectors = " << eigen_solver.eigenvectors() << endl;// 解方程
// 我们求解 matrix_NN * x = v_Nd 这个方程
// N 的大小在前边的宏里定义,矩阵由随机数生成
// 直接求逆自然是最直接的,但是求逆运算量大Eigen::Matrix< double, MATRIX_SIZE, MATRIX_SIZE > matrix_NN;
matrix_NN = Eigen::MatrixXd::Random( MATRIX_SIZE, MATRIX_SIZE );
Eigen::Matrix< double, MATRIX_SIZE, 1> v_Nd;
v_Nd = Eigen::MatrixXd::Random( MATRIX_SIZE,1 );clock_t time_stt = clock(); // 计时
// 直接求逆
Eigen::Matrix<double,MATRIX_SIZE,1> x = matrix_NN.inverse()*v_Nd;
cout <<"time use in normal invers is " << 1000* (clock() - time_stt)/(double)CLOCKS_PER_SEC << "ms"
<< endl;// 通常用矩阵分解来求,例如 QR 分解,速度会快很多
time_stt = clock();
x = matrix_NN.colPivHouseholderQr().solve(v_Nd);
cout <<"time use in Qr compsition is " <<1000* (clock() - time_stt)/(double)CLOCKS_PER_SEC <<"ms"<<endl;return 0;
}

高翔slam14讲的部分的实例代码: eigen部分(一)相关推荐

  1. slam14讲 |二、三维空间刚体运动

    文章目录 参考资料 1. 旋转矩阵 1.1 内积.外积 1.2 坐标变换 1.2.1 旋转 1.2.2 平移 1.2.3 变换矩阵与齐次坐标 2. 旋转向量和欧拉角 2.1 旋转向量 2.2 欧拉角 ...

  2. slam14讲-第二版-安装包

    slam14讲 源码介绍 slam14讲第二版源码:slambook2 注意:slam14讲有两个版本,也有两个源码.第二版是目前最新. slambook2---->3rdparty------ ...

  3. 【教程】nrf51822实例代码解析及修改实例

    [教程]nrf51822实例代码解析及修改实例 http://www.eeboard.com/bbs/thread-42757-1-1.html 说在前面:此说明用于nrf51822的主从机的实例代码 ...

  4. Java 线程池详解及实例代码

    转载自  Java 线程池详解及实例代码 这篇文章主要介绍了Java 线程池的相关资料,并符实例代码,帮助大家学习参考,需要的朋友可以参考下 线程池的技术背景 在面向对象编程中,创建和销毁对象是很费时 ...

  5. php做一个微信退款,PHP实现微信申请退款流程实例代码

    前面讲了怎么实现微信支付,详见博文:php实现微信支付(jsapi支付)流程  和ThinkPHP中实现微信支付(jsapi支付)流程.由于业务需求,还需要有微信退款,经过研究和摸索,也终于搞定了. ...

  6. android右滑返回动画,Android仿微信右滑返回功能的实例代码

    先上效果图,如下: 先分析一下功能的主要技术点,右滑即手势判断,当滑到一直距离时才执行返回,并且手指按下的位置是在屏幕的最左边(这个也是有一定范围的),  这些可以实现onTouchEvent来实现. ...

  7. java画太极加图片_Android 画一个太极图实例代码

    今天练手一下,一起来画个太极图吧~ 最终效果如下: 最终效果 一般都是先讲原理,我就反其道而行,先讲实现吧. 1.继承实现初始化方法 继承View,实现基本的构造函数: public TestView ...

  8. 视觉slam14讲学习(一)之se3上的定位表示:轨迹显示与轨迹误差

    文章目录 1.读出trajectory.txt中的轨迹信息 2. 用pangolin画出轨迹poses 3. 利用Eigen进行欧拉角和四元数的转化 4. 画出两条轨迹,对定位精度进行分析 5.结果显 ...

  9. php制作万年历的步骤_php制作一个万年历查询的实例代码教程

    下面是php制作一个万年历查询的实例代码教程的相关内容,文章教程主要讲述与万年历 php 相关的一些技术与知识,更多的内容欢迎大家访问http://www.alixixi.com,获取更多最新教程,下 ...

最新文章

  1. JSONObject 和 JSONArray 获取value 的方法
  2. 使用Nginx的proxy_cache缓存功能取代Squid
  3. [译] TypeScript:拥有超能力的 JavaScript(下)
  4. 基于Leaflet和高德Web API扩展地理编码服务
  5. 收藏!84页PPT讲解电力变压器参数计算
  6. infinity mysql_MySql锁机制
  7. tornado服务器动态文件,tornado 实现服务器消息推送功能
  8. 《React 学习之道》The Road to learn React (简体中文版)
  9. struts.properties文件
  10. linux中sed命令用例,sed解析和用例(马哥视频笔记)
  11. 置换群burnside引理(bzoj 1004: [HNOI2008]Cards)
  12. 水很深的深度学习(四)——卷积神经网络CNN
  13. Java定时任务(一) Timer及TimerTask的案例解析及源码分析
  14. zabbix获取mysql主从状态_zabbix监控MySQL主从状态
  15. 中国超算世界第一 日本拟造最快超级计算机反超
  16. python如何确定拐点_如何在嘈杂的曲线中找到拐点?
  17. 笔记本电脑间的串口通信
  18. 雷达扫描定位 android,Android仿微信雷达扫描
  19. Citavi导入中国知网caj文件
  20. 是不是可以赚钱的APP越来越多

热门文章

  1. 疯子网页采集器之提取内容教程
  2. CVPR2022 目标检测方向文章(附摘要)
  3. 0丢失之谜:解决Oracle中0开头小数被截断的问题
  4. 生产制造企业一物一码解决方案_爱码SaaS
  5. Ubuntu18.04安装evo及简单使用方法
  6. 教师资格面试逐字稿(一)
  7. Prometheus和Grafana告警服务创建与对接腾讯云短信告警平台(prometheus_alert)
  8. 2017-2018年度刷题记录
  9. PLM系统的技术现状和发展趋势
  10. loopback端口作用