Qt 配置Eigen矩阵库 - 并简单测试

Qt 配置Eigen矩阵库 - 并简单测试

引言

Eigen是一个开源的C++模板库,提供了线性代数和矩阵运算的功能。它被设计为一个高性能、可扩展和易用的库,可以用于科学计算、机器学习和计算机图形学等领域。Eigen库的主要特点包括:

  1. 高性能:Eigen使用了矩阵表达式模板技术,能够在编译时优化矩阵运算,同时还提供了高度优化的数学函数库,可以充分利用硬件的并行计算能力。
  2. 可扩展:Eigen支持多种矩阵和向量类型,例如动态大小的矩阵、静态大小的矩阵,以及稀疏矩阵等。同时,Eigen还提供了丰富的数学函数和算法,满足不同应用的需求。
  3. 易用性:Eigen提供了简洁的API接口,使得用户可以轻松地进行矩阵运算和线性代数操作。它还提供了详细的文档和示例代码,方便用户学习和使用。

Eigen库被广泛应用于科学计算、机器学习、计算机图形学等领域。很多开源项目和工具,如OpenCV、PCL等,都使用了Eigen作为其数学库的核心。应用Eigen 的项目:https://blog.csdn.net/weixin_40948750/article/details/136492837

  • 整SLAM的时候接触到的数学库,很方便速度也快. 本文主要说明如何在Qt中配置Eigen 以及 写了一个低通滤波器小Demo进行测试 - 如上图所示

一、在Qt中配置Eigen

二、低通Demo源码

  • 只展示了mainwindow.cpp的代码,比较简单
cpp 复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "Eigen/Dense"
#include <unsupported/Eigen/FFT>
#include "qcustomplot/qcustomplot.h"
#include <iostream>

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    // EigenDemo
    int n = 100;
    srand(static_cast<unsigned>(time(nullptr)));
    Eigen::VectorXd v = Eigen::VectorXd::Random(n);

    // 傅里叶变换,去除高频部分
    Eigen::FFT<double> fft;
    Eigen::VectorXcd tmp(n);
    Eigen::VectorXd v_(n);
    fft.fwd(tmp, v);           // 傅里叶变换

    for(int i = n/10; i < n; i++){
        tmp[i] = 0;
    }
    fft.inv(v_, tmp);           // 逆变换
    //std::cout << v_;

    // 可视化
    QCustomPlot *customPlot =  new QCustomPlot();  // 创建qcustomplot

    // 赋值原始值
    customPlot->addGraph();
    QCPGraph * curGraph1 = customPlot->graph(0);
    curGraph1->setScatterStyle(QCPScatterStyle(QCPScatterStyle::ssCustom, 1));
    QVector<double> x(n), y(n);
    for(int i = 0; i < n; i++){
        x[i] = i;
        y[i] = v[i];
    }
    customPlot->graph(0)->setPen(QPen(QColor(255, 0, 0)));
    customPlot->graph(0)->setData(x, y);

    // 赋值处理后的值
    customPlot->addGraph();
    QCPGraph * curGraph2 = customPlot->graph(1);
    curGraph2->setScatterStyle(QCPScatterStyle(QCPScatterStyle::ssCustom, 1));
    QVector<double> xx(n), yy(n);
    for(int i = 0; i < n; i++){
        xx[i] = i;
        yy[i] = v_[i];
    }
    customPlot->graph(1)->setPen(QPen(QColor(0, 0, 255)));
    customPlot->graph(1)->setData(xx, yy);


    // 设定显示范围
    auto max_x = std::max_element(std::begin(x), std::end(x));
    auto min_x = std::min_element(std::begin(x), std::end(x));
    auto max_y = std::max_element(std::begin(y), std::end(y));
    auto min_y = std::min_element(std::begin(y), std::end(y));
    customPlot->xAxis->setRange(*min_x, *max_x);
    customPlot->yAxis->setRange(*min_y, *max_y);


    this->setCentralWidget(customPlot);
}

MainWindow::~MainWindow()
{
    delete ui;
}

三、参考链接以及其他

Qt 配置Eigen:https://www.cnblogs.com/ybqjymy/p/18110273

大家推荐一个矩阵类?https://www.zhihu.com/question/22655757

Engin库和Armadillo库矩阵计算性能比较?https://www.zhihu.com/question/50586395

Armadillo官网:https://arma.sourceforge.net/

C++线代运算库Armadillo配置(Qt & CLion & VSCode):https://blog.csdn.net/Arry_W/article/details/130725096

  • 以及使用Armadillo实现的低通滤波.
cpp 复制代码
arma::arma_rng::set_seed(0);
arma::vec v1 = randg<vec>(300);
int n = static_cast<int>(v1.size());
cx_vec fft_v1 = fft(v1);
//fft_v1.print("V1:");
for(int i = 100; i < n; i++){
    fft_v1[static_cast<quint64>(i)] = 0;  
}
//fft_v1.print("V1_:");
cx_vec ifft_v1 = ifft(fft_v1);
vec v2 = real(ifft_v1);
相关推荐
IT猿手几秒前
基于 CBF 的多无人机编队动态避障路径规划研究,无人机及障碍物数量可以自定义修改,MATLAB代码
开发语言·matlab·无人机·动态路径规划
炸膛坦客2 分钟前
单片机/C/C++八股:(十六)C 中 malloc/free 和 C++ 中 new/delete 有什么区别?
c语言·开发语言·c++
@insist1232 分钟前
软件设计师-组网技术基础:网络设备、传输介质与局域网核心协议
开发语言·网络·软考·软件设计师·软件水平考试
CSDN_Colinw16 分钟前
C++中的工厂方法模式
开发语言·c++·算法
liulilittle20 分钟前
范围随机算法实现
开发语言·c++·算法·lua·c·js
乌索普-23 分钟前
基于vue2的简易购物车
开发语言·前端·javascript
走粥24 分钟前
使用indexOf查找对象结合Pinia持久化引发的问题
开发语言·前端·javascript
csbysj202040 分钟前
Python break 语句详解
开发语言
2401_857918291 小时前
C++中的访问者模式实战
开发语言·c++·算法
格林威1 小时前
工业相机图像高速存储(C++版):RAID 0 NVMe SSD 阵列暴力提速,附海康实战代码!
开发语言·c++·人工智能·数码相机·计算机视觉·工业相机·堡盟相机