C#用MathNet生成矩阵,并打印矩阵元素

文章目录

安装

MathNet.Numerics中提供了线性代数、微积分、特殊函数、概率论、随机函数、插值、最优化等一系列功能,是.net技术中首选的数值计算包。

其中,线性代数包LinearAlgebra包提供了向量、矩阵等数据结构,这些是数值计算的前提,故而相比于其他包更加基础。

下面用VS新建一个控制台项目,并启用顶级语句。点击工具->NuGet包管理器->管理解决方案的NuGet程序包,进入浏览选项卡,搜索MathNet.Numerics,选中安装。

创建和显示矩阵

在使用命名空间之后,可通过Matrix.Build来创建矩阵,矩阵中重写了ToString方法,所以可直接使用$字符串,示例如下

cs 复制代码
using MathNet.Numerics.LinearAlgebra;

Matrix<double> m = Matrix<double>.Build.Random(3,4);
Console.WriteLine($"{m}");

/* 输出结果如下
DenseMatrix 3x4-Double
 -1.34532   0.209099   1.64422   0.13664
  1.15024  -0.751815  0.242772  -1.90048
0.0985362   -1.02023  0.727527  0.137225
*/

即创建的矩阵为

[ − 1.34532 0.209099 1.64422 0.13664 1.15024 − 0.751815 0.242772 − 1.90048 0.0985362 − 1.02023 0.727527 0.137225 ] \begin{bmatrix} -1.34532& 0.209099& 1.64422& 0.13664\\ 1.15024&-0.751815&0.242772&-1.90048\\ 0.0985362& -1.02023&0.727527&0.137225\\ \end{bmatrix} −1.345321.150240.09853620.209099−0.751815−1.020231.644220.2427720.7275270.13664−1.900480.137225

Matrix.Build是MatrixBuilder对象,后文简称MB,用于生成矩阵,如果需要频繁创建矩阵,则可创建一个矩阵生成器,示例如下

cs 复制代码
var MB = Matrix<double>.Build;
m = MB.Random(3, 4);

MB.Dense(3, 4);          //3x4的全0矩阵
MB.Dense(3, 4, 1.0);     //3x4的全1.0矩阵
MB.Dense(3, 4, (i, j) => 100 * i + j);   //通过表达式生成元素
MB.DenseDiagonal(3, 4, 2.0); //3x4对角为2.0
MB.DenseIdentity(3);     // 3x3的单位阵

矩阵类型

MB支持超多种矩阵的生成方式,其中Dense又是最常用的一种,从上面的示例可知,MB提供了多种Dense重载,但前两个输入参数一般为行数和列数,第三个参数则可以是

  • 缺省,则所有元素为0
  • 数值,则所有元素都是这个数
  • 函数,诸如(i, j) => f(i,j),表示 ( i , j ) (i,j) (i,j)处的元素,其值为 f ( i , j ) f(i,j) f(i,j)
  • 数组,将使用数组中的值进行填充

DenseDiagonal用于生成对角矩阵,包括三种重载,

  • 阶数,对角数值
  • 行数,列数,对角数值
  • 行数,列数,对角的生成函数

这两种生成方法,囊括了矩阵生成的一些基本逻辑,从矩阵的形状来说,主要有两种形式,即指定行列数或者指定阶数;而就矩阵的内容而言,则有三种方法,一是用某个值来填充,二是用某个数组中的值来填充,三则是通过函数来生成。

在建立起这种逻辑之后,对于其他矩阵生成方法,也可以逐步尝试

方法 说明
DenseIdentity 单位阵
Diagonal 对角方阵
DiagonalIdentity 对角单位阵
Random 随机矩阵
RandomPositiveDefinite 每个元素是两个随机数的积

其中,随机矩阵Random可以指定随机数种子或者具体的分布,如果未指定分布,则默认是标准正态分布。

相关推荐
weixin_4640780719 分钟前
C#串口温度读取
开发语言·c#
明耀2 小时前
WPF RadioButton 绑定boolean值
c#·wpf
DogDaoDao4 小时前
【预备理论知识——2】深度学习:线性代数概述
人工智能·深度学习·线性代数
Death2004 小时前
Qt 中的 QListWidget、QTreeWidget 和 QTableWidget:简化的数据展示控件
c语言·开发语言·c++·qt·c#
quaer5 小时前
Open-Sora全面开源?
开发语言·算法·机器学习·matlab·矩阵
Death2005 小时前
Qt 3D、QtQuick、QtQuick 3D 和 QML 的关系
c语言·c++·qt·3d·c#
yufei-coder5 小时前
C#基础语法
开发语言·c#·.net
yngsqq5 小时前
031集——文本文件按空格分行——C#学习笔记
笔记·学习·c#
winds~7 小时前
数学基础-向量投影
线性代数
roman_日积跬步-终至千里20 小时前
【线性代数】【第一章】行列式习题
线性代数