Eigen入门系列 —— Eigen::Matrix矩阵点乘、叉乘、转置、求逆、求和、行列式、迹、数乘

Eigen入门系列 —— Eigen::Matrix矩阵点乘、叉乘、转置、求逆、求和、行列式、迹、数乘


前言

随着工业自动化、智能化的不断推进,机器视觉(2D/3D)在工业领域的应用和重要程度也同步激增(识别、定位、抓取、测量,缺陷检测等),而针对不同作业场景进行解决方案设计时,通常会借助PCL、OpenCV、Eigen等简单方便的开源算法库进行方案的快速验证和迭代以满足作业场景下的目标需求。

为了让对工业机器视觉方向感兴趣的同学能够少走一些弯路,故推出了此一系列简易入门教程示例,让初次使用者能够最简单直观地感受到当前所用算法模块的执行效果。

后续会逐步扩增与工业机器视觉相关的一些其它内容,如:

项目案例剖析场景数据分析基础算法模块相机评测 等;

如有兴趣可加入群聊(若入群二维码被屏蔽,则可以通过Q群(1032861997)或评论、私信博主“群聊”,邀请入群),与同道同学及圈内同行一起交流讨论。

在这里插入图片描述


程序说明

展示Eigen::Matrix矩阵运算,点乘、叉乘、转置、求逆、求和、行列式、迹、数乘等;

输出结果

在这里插入图片描述

代码示例

/*
 * @File: matrix_arithmetic.cpp
 * @Brief: eigen course
 * @Description: 展示Eigen::Matrix矩阵运算
 * @Version: 0.0.1
 * @Author: MuYv
 */
#include <iostream>
#include <Eigen/Dense>



int main(int argc, char** argv){
    
    
    // Eigen::Matrix为模板类,可自由定义不同维度的矩阵,
    // 此处仅展示较为常用的几种数据类型,其它定制化需求类型的使用,可以此类推;

    // 自定义创建4x4的矩阵,模板参数依次为:数据类型,行数,列数;
    Eigen::Matrix<float, 4, 4> matrix_4f;
    // 使用常数值进行初始化填充;
    matrix_4f = Eigen::Matrix<float,4,4>::Random();
    std::cout<<"matrix_4f random init:\n"<<matrix_4f<<std::endl<<std::endl;
    std::cout << "transpose:\n" << matrix_4f.transpose()<<std::endl<<std::endl;     // 转置
    std::cout << "sum: " << matrix_4f.sum()<<std::endl;                             // 各元素和
    std::cout << "det: " << matrix_4f.determinant()<<std::endl;                     // 行列式
    std::cout << "trace: " << matrix_4f.trace()<<std::endl<<std::endl;              // 迹
    std::cout << "times 10:\n" << 10 * matrix_4f<<std::endl<<std::endl;             // 数乘
    std::cout << "inverse:\n" << matrix_4f.inverse()<<std::endl<<std::endl;         // 逆
    
    
    // 3x1 列向量
    Eigen::Vector3f vector_3f(1.0f, 2.0f, 3.0f);
    std::cout<<"vector_3f:\n"<<vector_3f<<std::endl;

    Eigen::Vector3f vector_3f_tmp = Eigen::Vector3f::Constant(4.0f);
    std::cout<<"vector_3f_tmp:\n"<<vector_3f_tmp<<std::endl<<std::endl;

    // 点乘
    std::cout<<"vector_3f.dot(vector_3f_tmp): "<<(vector_3f.dot(vector_3f_tmp))<<std::endl<<std::endl;
    // 叉乘
    std::cout<<"vector_3f.cross(vector_3f_tmp):\n"<<(vector_3f.cross(vector_3f_tmp))<<std::endl<<std::endl;
    // 与矩阵变换
    Eigen::Matrix3f rotation = Eigen::Matrix3f::Random();
    std::cout<<"matrix transform:\n"<<(rotation*vector_3f)<<std::endl<<std::endl;
    

    return 0;
}

猜你喜欢

转载自blog.csdn.net/memorynode/article/details/124620795