【C/C++开源库】C/C++矩阵运算开源库

64 篇文章 98 订阅
24 篇文章 19 订阅

这篇博客总结一下C/C++中的矩阵运算库。

一、C++矩阵运算库 - eigen

Eigen是使用C++封装好的的一个矩阵运算库,可以很方便地实现各类矩阵运算,而且不用安装,只需要简单配置即可。

1.下载及安装

1.1Linux安装及配置
sudo apt-get install libeigen3-dev

Eigen只包含头文件,因此它不需要实现编译(只需要使用#include),指定好Eigen的头文件路径,编译项目即可。

Eigen头文件的默认安装位置是:“/usr/include/eigen3”.

1.2Windows配置

下载地址:http://eigen.tuxfamily.org/index.php?title=Main_Page#Download

下载文件解压后,文件目录如下:

image-20210819215257932

  • 只需要将eigen-3.4.0的路径加入到头文件查找路径。

  • 使用时包含头文件即可,比如 #include <Eigen\Dense>

2.测试使用

本博客在Windows下使用DevC++和Clion两款C/C++来测试一下。

为了应对不同的需求,Eigen库被分为多个功能模块,每个模块都有自己相对应的头文件,以供调用。 其中,Dense模块整合了绝大部分的模块,而Eigen模块更是整合了所有模块(也就是整个Eigen库)。

在这里插入图片描述

2.1DevC++

添加头文件路径

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210819220638799.png

测试代码

#include <iostream>
#include <Eigen\Dense>
using namespace std;
using namespace Eigen;
int main()
{
    Matrix2d a;
    a << 1, 2,
        3, 4;
    MatrixXd b(2, 2);
    b << 2, 3,
        1, 4;
    cout << "a + b =\n" << a + b << endl;
    cout << "a - b =\n" << a - b << endl;
    cout << "Doing a += b;" << endl;
    a += b;
    cout << "Now a =\n" << a << endl;
    cout << "a^T=  " << a.transpose() << endl;
    cout << "a*b= " << a*b << endl;
    Vector3d v(1, 2, 3);
    Vector3d w(1, 0, 0);
    cout << "-v + w - v =\n" << -v + w - v << endl;
    cout << v << endl;
    cout << v.transpose() << endl;
    system("pause");
}

运行结果如下

image-20210819220836562

2.2Clion

clion中添加头文件可以在CMakeLists.txt中添加,也可以在项目目录中添加。

  1. (推荐)编辑项目目录下的 CMakeLists.txt,添加一行
include_directories("/path/to/headers") #换成头文件所在目录
  1. 将对应的头文件或文件夹复制到项目根目录,然后在源文件中使用 #include “文件名” 包含

这里我们使用第一种方法,更改之后,CMakeLists.txt文件内容如下:

cmake_minimum_required(VERSION 3.19)
project(untitled1)

set(CMAKE_CXX_STANDARD 14)

include_directories("D:\\eigen-3.4.0")

add_executable(untitled1 main.cpp)

测试代码依旧是上面的代码

#include <iostream>
#include <Eigen\Dense>
using namespace std;
using namespace Eigen;
int main()
{
    Matrix2d a;
    a << 1, 2,
        3, 4;
    MatrixXd b(2, 2);
    b << 2, 3,
        1, 4;
    cout << "a + b =\n" << a + b << endl;
    cout << "a - b =\n" << a - b << endl;
    cout << "Doing a += b;" << endl;
    a += b;
    cout << "Now a =\n" << a << endl;
    cout << "a^T=  " << a.transpose() << endl;
    cout << "a*b= " << a*b << endl;
    Vector3d v(1, 2, 3);
    Vector3d w(1, 0, 0);
    cout << "-v + w - v =\n" << -v + w - v << endl;
    cout << v << endl;
    cout << v.transpose() << endl;
    system("pause");
}

运行结果如下

https://raw.githubusercontent.com/xkyvvv/blogpic/main/pic1/image-20210819222406819.png

3.深入学习

本博客只是对矩阵运算库的简介、汇总、环境配置,因此不会讲太详细的使用。主要是本人太菜了,讲不来。不过为了内容的完整型,我会给几个好的比较完整的eigen学习教程。



二、C++矩阵运算库 - Armadillo

Armadillo是一个开源高性能C++线性代数库,提供了和Matlab中常用命令接近的函数接口,可以方便地将Matlab/Octave开发的算法移植到C++中。特别地,我们可以先在Matlab环境中编程进行算法原型验证,待算法充分验证通过之后再利用Armadillo移植到C++中编译为独立的可执行程序。虽然Matlab也支持利用mcc直接将m文件编译生成动态链接库文件或者可执行程序,但是这些代码的运行需要Matlab运行环境(MCR)的支持;而通过Armadillo进行移植则可以完全脱离Matlab环境。

1.下载及安装

1.1Linux安装

执行命令:

sudo apt-get install libopenblas-dev
sudo apt-get install liblapack-dev
sudo apt-get install libarpack2-dev
sudo apt-get install libsuperlu-dev

下载Armadillo包,链接:https://sourceforge.net/projects/arma/files/armadillo-9.600.6.tar.xz/download

在Armadillo的安装目录打开终端执行:

cmake .
make
1.2Windows配置

因为Armadillo需要C++11的支持,而DEVC++好久没更新编译器了,支持不好,因此我们换用visual studio2019来测试。

下载Armadillo包,链接:https://sourceforge.net/projects/arma/files/armadillo-9.600.6.tar.xz/download

下载解压后需要配置头文件和库文件的路径。

可以参考这篇文章:基于vs2017的armadillo配置教程(超详细!)

2.测试使用

测试代码如下:

#include <iostream>
#include <armadillo>
using namespace arma;
int main()
{
    //生成一个随机矩阵A,大小为5x5,矩阵每个元素的范围为:(0,10)
    mat A = randu<mat>(5, 5) * 10;
    A.print("原矩阵A = \n");
}

在这里插入图片描述

3.深入学习

看了下,好像中文没啥好的教程,不如直接看帮助手册。

三、C++矩阵运算库 - boost

Boost在C++中地位非常高,被称为C++的准标准库,其中的ublas模块包含矩阵类,用法如下:

#include <boost/numeric/ublas/matrix.hpp>
#include <boost/numeric/ublas/io.hpp>
#include <iostream>
namespace ublas = boost::numeric::ublas;
int main()
{
    ublas::matrix<double> A(3, 3);
    for (unsigned i = 0; i < A.size1(); ++i)
        for (unsigned j = 0; j < A.size2(); ++j)
            A(i, j) = 3*i + j;
	std::cout << A << std::endl;
    return 0;
}

关于boost的配置问题,可以参考博客boost库在visual studio、DevC++和vscode上的环境配置



四、C语言矩阵运算库 -

其实C++矩阵运算库已经很好用了,但是可能在某些场景下,因为项目历史或者编译器的原因,我们必须要使用C语言来实现矩阵运算。

好像几乎没有特别知名C语言矩阵运算库,因此在此总结各位网友写的C语言矩阵运算库。

1.C语言矩阵库1

地址:如何用纯c语言优雅地实现一个矩阵运算库

这个详细讲解了怎么自己实现一个矩阵运算库,想学习写一个自己的C语言矩阵运算库可以参考一下。

2.C语言矩阵库2

地址:我的C语言矩阵库

github地址:https://github.com/colourfate/math_matrix

3.C语言矩阵库3

地址:C语言矩阵实现库运算, 简单的数组直接运算两种方式

4.C语言矩阵库4

地址:基于C语言的矩阵运算库

5.C语言矩阵库5

地址:超好用的纯C语言矩阵运算库

github地址:https://github.com/fellylanma/easyMatrix

6.C语言矩阵库6

地址:C语言矩阵运算库(Light Matrix)

github地址:https://github.com/zjc666/LightMatrix

7.C语言矩阵库7

github地址:https://github.com/kimwolf-fs/c_data_structure/tree/master/matrix

8.C语言矩阵库8

地址:异想家纯C语言矩阵运算库

9.C语言矩阵库9

github地址:https://github.com/Amoiensis/Matrix_hub

10.C++矩阵运算库

这个库是我同学写的,帮他传播一下!!!

地址:C++矩阵库

github地址:https://github.com/TING2938/Analysis


总结

在条件允许的情况下,可以优先使用eigen矩阵运算库。

如果条件不允许或者希望自己能用一个更加小巧顺手的矩阵运算库,那可以参考上面,自己实现一个。

  • 31
    点赞
  • 198
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: 在Python中,使用NumPy进行矩阵运算是最常见和最方便的选择。 NumPy是一个强大的数值计算,提供了丰富的功能来进行各种矩阵操作。通过使用NumPy,可以轻松地进行矩阵的创建、转置、求逆、乘法、加法等运算。 下面是一些常见的NumPy函数: 创建矩阵: numpy.array() 矩阵转置: numpy.transpose() 求矩阵的逆: numpy.linalg.inv() 矩阵乘法: numpy.dot() 矩阵加法: numpy.add() 通过使用这些函数,可以很方便地进行各种矩阵运算。同时,NumPy也提供了其他一些功能,如计算矩阵特征值、特征向量、奇异值分解等。通过熟练掌握NumPy的使用,可以更高效地进行矩阵运算,并且可以进行更复杂的数值计算和科学计算任务。 ### 回答2: 在Python中,可以使用NumPy来进行矩阵运算。 NumPy是一个功能强大的数值计算,它提供了高效的数组操作和数学函数,可以进行矢量化计算。在NumPy中,可以使用多维数组(即矩阵)来表示和操作数据。 使用NumPy进行矩阵运算非常方便。可以使用NumPy的数组对象来创建矩阵,并且可以直接对这些矩阵进行各种运算,例如加法、减法、乘法、矩阵乘法、转置等等。此外,NumPy还提供了丰富的数学函数和线性代数函数,可以用于矩阵的数值计算和分析。 下面是一个使用NumPy进行矩阵运算的简单示例: ```python import numpy as np # 创建矩阵 A = np.array([[1, 2], [3, 4]]) B = np.array([[5, 6], [7, 8]]) # 矩阵加法 C = A + B # 矩阵乘法 D = np.dot(A, B) # 矩阵转置 E = np.transpose(A) # 打印结果 print("矩阵加法结果:", C) print("矩阵乘法结果:", D) print("矩阵转置结果:", E) ``` 通过使用NumPy,我们可以方便地进行矩阵运算,提高了计算效率和代码的简洁性。因此,对于矩阵运算,建议使用NumPy。 ### 回答3: 在Python中,我们可以使用NumPy来进行矩阵运算。 NumPy(Numerical Python)是一个开源的Python科学计算,提供了丰富的高性能数学函数和数组对象,用于进行各种数值计算,包括矩阵运算。 NumPy中的核心对象是多维数组(ndarray),它可以表示矩阵和向量等各种数值数据。NumPy提供了丰富的函数和方法,可以进行各种矩阵运算,例如矩阵乘法、加法、减法、转置、逆矩阵等。 使用NumPy进行矩阵运算具有以下优点: 1. 高性能:NumPy使用C语言编写的底层代码,对大规模的数据进行高效处理。 2. 数值计算功能强大:NumPy提供了丰富的数学函数和方法,可以完成各种复杂的数值计算任务。 3. 简单易用:NumPy提供了简洁、一致的接口,方便开发者进行矩阵运算。 要使用NumPy进行矩阵运算,我们首先需要安装NumPy。可以通过以下命令来安装NumPy: ``` pip install numpy ``` 安装完成后,我们可以通过导入NumPy来使用其中的函数和方法。例如,下面的示例展示了如何使用NumPy进行矩阵乘法运算: ```python import numpy as np # 创建两个矩阵 matrix1 = np.array([[1, 2], [3, 4]]) matrix2 = np.array([[5, 6], [7, 8]]) # 矩阵乘法 result = np.dot(matrix1, matrix2) print(result) ``` 以上就是使用NumPy进行矩阵运算的简要介绍。通过学习和应用NumPy,我们可以方便地进行各种复杂的矩阵运算操作。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小熊coder

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值