前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >eigen库使用_eigen3

eigen库使用_eigen3

作者头像
全栈程序员站长
发布2022-11-04 16:57:39
发布2022-11-04 16:57:39
1.5K00
代码可运行
举报
运行总次数:0
代码可运行

Eigen 库的安装

1. Visual Studio 2017 安装 eigen 库

1.1 下载 eigen 库

eigen官网下载地址

找到自己需要的版本下载,我下载的是3.3.9,箭头指向的 zip。 解压缩得到文件eigen-3.3.9,放到自己想放置的路径下(后面会引用此处的路径)。

1.2 配置

在VS 2017中新建一个空项目,取名为“eigen_demo”。输入以下测试代码(官方测试代码):

代码语言:javascript
代码运行次数:0
复制
#include <iostream>
#include <Eigen/Dense>
using namespace Eigen;
using namespace std;
int main()
{ 

#pragma region Addition and subtraction
Matrix2d a;
a << 1, 2,
3, 4;
MatrixXd b(2, 2);
b << 2, 3,
1, 4;
std::cout << "a + b =\n" << a + b << std::endl;
std::cout << "a - b =\n" << a - b << std::endl;
std::cout << "Doing a += b;" << std::endl;
a += b;
std::cout << "Now a =\n" << a << std::endl;
Vector3d v(1, 2, 3);
Vector3d w(1, 0, 0);
std::cout << "-v + w - v =\n" << -v + w - v << std::endl;
#pragma endregion
#pragma region Scalar multiplication and division
// Matrix2d a; //duplicate definition
a << 1, 2,
3, 4;
// Vector3d v(1, 2, 3); //duplicate definition
std::cout << "a * 2.5 =\n" << a * 2.5 << std::endl;
std::cout << "0.1 * v =\n" << 0.1 * v << std::endl;
std::cout << "Doing v *= 2;" << std::endl;
v *= 2;
std::cout << "Now v =\n" << v << std::endl;
#pragma endregion
#pragma region Transposition and conjugation
MatrixXcf a_matrix = MatrixXcf::Random(2, 2);
cout << "Here is the matrix a_matrix\n" << a_matrix << endl;
cout << "Here is the matrix a_matrix^T\n" << a_matrix.transpose() << endl;
cout << "Here is the conjugate of a_matrix\n" << a_matrix.conjugate() << endl;
cout << "Here is the matrix a_matrix^*\n" << a_matrix.adjoint() << endl;
//This is the so-called aliasing issue
Matrix2i a_matrix2;
a_matrix2 << 1, 2, 3, 4;
cout << "Here is the matrix a_matrix2:\n" << a_matrix2 << endl;
// a_matrix2 = a_matrix2.transpose(); // !!! do NOT do this !!!
cout << "and the result of the aliasing effect:\n" << a_matrix2 << endl;
#pragma endregion
#pragma region Matrix-matrix and matrix-vector multiplication
Matrix2d mat;
mat << 1, 2,
3, 4;
Vector2d u_1(-1, 1), v_1(2, 0);
std::cout << "Here is mat*mat:\n" << mat * mat << std::endl;
std::cout << "Here is mat*u_1:\n" << mat * u_1 << std::endl;
std::cout << "Here is u_1^T*mat:\n" << u_1.transpose()*mat << std::endl;
std::cout << "Here is u_1^T*v:\n" << u_1.transpose()*v_1 << std::endl;
std::cout << "Here is u_1*v_1^T:\n" << u_1 * v_1.transpose() << std::endl;
std::cout << "Let's multiply mat by itself" << std::endl;
mat = mat * mat;
std::cout << "Now mat is mat:\n" << mat << std::endl;
#pragma endregion 
#pragma region Dot product and cross product
Vector3d v_2(1, 2, 3);
Vector3d w_2(0, 1, 2);
cout << "Dot product: " << v_2.dot(w_2) << endl;
double dp = v_2.adjoint()*w_2; // automatic conversion of the inner product to a scalar
cout << "Dot product via a matrix product: " << dp << endl;
cout << "Cross product:\n" << v_2.cross(w_2) << endl;
#pragma endregion
#pragma region Basic arithmetic reduction operations
Eigen::Matrix2d mat_3;
mat_3 << 1, 2,
3, 4;
cout << "Here is mat_3.sum(): " << mat_3.sum() << endl;
cout << "Here is mat_3.prod(): " << mat_3.prod() << endl;
cout << "Here is mat_3.mean(): " << mat_3.mean() << endl;
cout << "Here is mat_3.minCoeff(): " << mat_3.minCoeff() << endl;
cout << "Here is mat_3.maxCoeff(): " << mat_3.maxCoeff() << endl;
cout << "Here is mat_3.trace(): " << mat_3.trace() << endl;
Matrix3f m = Matrix3f::Random();
std::ptrdiff_t i, j;
float minOfM = m.minCoeff(&i, &j);
cout << "Here is the matrix m:\n" << m << endl;
cout << "Its minimum coefficient (" << minOfM
<< ") is at position (" << i << "," << j << ")\n\n";
RowVector4i v_4 = RowVector4i::Random();
int maxOfV = v_4.maxCoeff(&i);
cout << "Here is the vector v_4: " << v_4 << endl;
cout << "Its maximum coefficient (" << maxOfV
<< ") is at position " << i << endl;
#pragma endregion
/**************This is the end of example codes in Eigen3 online document. **********************/
system("pause");
}

此时项目默认为“DEBUG”模式,活动平台为“x64″。

如果后面更改了模式或平台,均要重新执行全部以下步骤。

鼠标右击项目 -> 选择属性 -> C/C++ -> 常规 -> 附加包含目录,将解压后的库文件夹所在路径:“ \Eigen 库\eigen-3.3.9 ”添加进去,点击确定。

再次打开此页面,链接器 -> 常规 -> 附加库目录,将路径“\Eigen 库\eigen-3.3.9”再次添加,点击确定。

1.3 运行测试

运行程序,看到正确运行的输出,Eigen库链接成功!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/180246.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月19日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Eigen 库的安装
  • 1. Visual Studio 2017 安装 eigen 库
    • 1.1 下载 eigen 库
    • 1.2 配置
    • 1.3 运行测试
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档