Numpy中的读取文件操作和高级库

Numpy中的读取文件操作和高级库_第1张图片

跟Python的IO读写功能一样,numpy中也有文件的读写功能,将ndarray对象也可以保存到磁盘文件并从磁盘文件加载。方便保存使用numpy编写的代码。在numpy中也有一些高级的库,今天我们这里简单讲一下矩阵库和线性代数的库,让我们更了解numpy这个模块。

一、IO操作

Numpy 可以读写磁盘上的文本数据或二进制数据。NumPy 为 ndarray 对象引入了一个简单的文件格式:npy。npy 文件用于存储重建 ndarray 所需的数据、图形、dtype 和其他信息。现在在Numpy中可用的IO功能有:

  • Load()和save()函数处理numpy二进制文件(需要带npy扩展名)
  • Loadtxt()和savetxt()函数处理正常的文本文件

Numpy为ndarray对象引入了一个简单的文件格式,这个npy文件在磁盘文件中,存储重建ndarray 所需的数据、图形、dtype 和其他信息,以便正确获取数组,即使该文件在具有不同架构的另一台机器上。

  1. numpy.save()

函数将输入的数组存储在具有npy扩展名的磁盘文件中。



为了从outfile.npy重建数组,需要使用load()函数



save() 和 load() 函数接受一个附加的布尔参数 allow_pickles。Python 中的 pickle 用于 在保存到磁盘文件或从磁盘文件读取之前,对对象进行序列化和反序列化。

2、savetxt()

函数以简单文本文件格式存储和获取数组数据,是通过 savetxt() 和 loadtx() 函数完成的。



savetxt() 和 loadtxt() 函数接受附加的可选参数,例如页首,页尾和分隔符。

二、numpy中的矩阵库

NumPy 包包含一个 Matrix 库 numpy.matlib 。此模块的函数返回矩阵而不是返回 ndarray对象。一个m*n的矩阵是一个由m行(row)n列(column)元素排列成的矩形阵列。矩阵里的元素可以是数字、符号或数学式。


  1. matlib.empty()

函数返回一个新的矩阵,且不初始化元素。



2、numpy.matlib.zeros()

此函数返回以0填充的矩阵。



3、numpy.matlib.ones()

此函数返回以1填充的矩阵。



4、numpy.matlib.eye()

这个函数返回一个矩阵,对角线元素为 1,其他位置为零。



5、numpy.matlib.identity()

函数返回给定大小的单位矩阵。单位矩阵是主对角线元素都为 1 的方阵。



6、numpy.matlib.rand()

函数返回给定大小的填充随机值的矩阵



在这里需要注意的是,矩阵总是二维的,而ndarray是一个n维数组,两个对象都是可以互换的,但是两个对象并不是相同的。

三、线性代数库

相信大家在学习线性代数的时候,都会觉得线性代数是非常难学的,线性代数就像一层硬纸,刚开始学习的时候是非常难以穿透的,但是只要认真的学下去,那么穿过那个点之后呢就恍然大悟,当然对线性代数掌握不是很好的人也没事,numpy中有专门的库numpy.linalg可以提供线性代数所需要的所有功能,我们可以先学习如何处理,然后在慢慢的去学习线性代数基础知识。

Numpy中提供的方法如下:

  • numpy.dot() 返回两个数组的点积
  • numpy.vdot() 返回两个向量的点积
  • numpy.inner() 返回一维数组的向量内积
  • numpy.matmul() 返回两个数组的矩阵乘积
  • numpy.linalg.det() 计算输入矩阵的行列式
  • numpy.linalg.solve() 求解矩阵形式的线性方程的解
  • numpy.linalg.inv() 计算矩阵的逆

接下来我们就一个一个方法开始学习如何处理线性代数的方法。

1、numpy.dot()

这个函数返回两个数组的点积。对于二维向量,相当于是矩阵乘法。对于一维数组,它是向量的内积。对于 N 维数组,它是a的最后一个轴上的和与b的倒数第二个轴的乘积。

1.1什么是矩阵乘法

在这里我在带领大家复习一下什么矩阵乘法,首先在百度中矩阵乘法的定义是这样的:

矩阵相乘最重要的方法是一般矩阵乘积。它只有在第一个矩阵的列数(column)和第二个矩阵的行数(row)相同时才有意义。一般单指矩阵乘积时,指的便是一般矩阵乘积。一个m×n的矩阵就是m×n个数排成m行n列的一个数阵。由于它把许多数据紧凑的集中到了一起,所以有时候可以简便地表示一些复杂的模型。

这么看其实是比较复杂的,但是咱们分开来学,也是很简单的,假设A矩阵为m行p列,B矩阵为p行n列,矩阵相乘后,A*B=C,那么C矩阵就是m行n列,也就是说矩阵C的行数=矩阵A的行数,矩阵C的列数=矩阵B的列数,矩阵相乘就是A矩阵的行去乘以B矩阵的列。这么说可能还是有一些复杂,咱们看一下实例就能明白了。

1.2实例

Numpy中的读取文件操作和高级库_第2张图片


在这个例子中,C矩阵的第一行第一个元素的结果是A矩阵的第一行 B矩阵的第一列,也就是11+2 13=37,第一行第二个元素的结果为112+2 14=40。第二行第一个元素为311+4 13=85,第二行第二个元素为312+4*14=92。这么看的话是不是感觉就很清楚了。

在Python的较新版本中还支持了直接使用@号作为矩阵的乘法,避免在调用numpy.dot()方法了。



2、numpy.vdot()

这个函数返回两个向量的点积。如果第一个参数是复数,那么它的共轭复数会用于计算。如果参数是多维数组,它会被展开。

Numpy中的读取文件操作和高级库_第3张图片

在这里看,点积也就是对应的元素相乘,也就是1 11+212+3 13+414=130,这个方法要求两个向量的元素相同不在乎行和列,如果不同的话则会报错。
Numpy中的读取文件操作和高级库_第4张图片

3、numpy.inner()

这个函数返回一维数组的向量内积。对于更高的维度,它返回最后一个轴上的乘积的和。

3.1、一维数组


结果等价于1 0+21+3*0

3.2、二维数组


Numpy中的读取文件操作和高级库_第5张图片


上面的列子中,内积的计算如下

Array([[111+212,113+214],

[311+412,313+414]])

4、numpy.matmul()

这个函数结果返回两个数组的矩阵乘积。虽然它返回二维数组的正常乘积,但如果任一参数的维数大于 2,则将其视为存在于最后两个索引的矩阵的栈,并进行相应广播。另一方面,如果任一参数是一 维数组,则通过在其维度上附加 1 来将其提升为矩阵,并在乘法之后被去除。

4.1、对于二维数组来说,它就是矩阵的乘法


Numpy中的读取文件操作和高级库_第6张图片

4.2、二维和一维的运算


Numpy中的读取文件操作和高级库_第7张图片

计算的过程为:

Np.matmul(a,b)=[111+212 312+412]

Np.matmul(b,a)=[111+123 112+124]

4.3、维度大于2的数组


Numpy中的读取文件操作和高级库_第8张图片

计算过程为

Array([[[00+12,01+31],

[20+36,21+33]],

[[40+52,41+53],

[60+72,61+73]]])

5、numpy.linalg.det()

这个函数计算输入矩阵的行列式。行列式在线性代数中是非常有用的值。


Numpy中的读取文件操作和高级库_第9张图片

Numpy中的读取文件操作和高级库_第10张图片

6、numpy.linalg.solve()

函数给出了矩阵形式的线性方程的解。

例如,考虑以下线性方程:

x + y + z = 6

2y + 5z = -4

2x + 5y - z = 27

可以使用矩阵表示为:

1 2 3

4 5 6 .$\left[\begin{matrix}x\y\z\end{matrix|\right]

7 8 9

$

6

-4

27

如果矩阵成为A、X和B,方程变为B


Numpy中的读取文件操作和高级库_第11张图片

7、numpy.linalg.inv()

这个函数是用来计算矩阵的逆。


Numpy中的读取文件操作和高级库_第12张图片

你可能感兴趣的:(Numpy中的读取文件操作和高级库)