目录
导入模块:
向量循环移动
随机数生成
随机数生成—正态分布
随机数生成—指定分布概率
矩阵合并(矩阵连接)
矩阵转置
矩阵相乘
计算协方差矩阵
计算矩阵特征根和特征向量
导入模块:
import numpy as np
向量循环移动
把向量x向右移动move_step步
numpy.roll(a, shift, axis=None)
函数解释:沿着给定轴滚动数组元素。超出最后位置的元素将会滚动到第一个位置。(将a,沿着axis的方向,滚动shift长度)
参数:
a : (array_like) 输入数组
shift : (int or tuple of ints) 滚动的长度。如果是提供元组的话,下面的轴参数的维度也应该跟shift维度一样。
axis : (int or tuple of ints, optional) 滚动的维度,0为垂直滚动,1为水平滚动(默认情况下,即参数为None时,数组在移位之前会被变成扁平化,之后会恢复原始形状。)
返回值: res : 输出数组(维度和a一样) Examples
>> x = np.arange(10) # x例子
array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])>> np.roll(x, 2) # axis为None,则会先进行扁平化,然后再向水平滚动2个位置
array([8, 9, 0, 1, 2, 3, 4, 5, 6, 7])>> x2 = np.reshape(x, (2,5)) # x2例子
array([[0, 1, 2, 3, 4],
[5, 6, 7, 8, 9]])>> np.roll(x2, 1) # axis为None,则会先进行扁平化,然后再向水平滚动1个位置
array([[9, 0, 1, 2, 3],
[4, 5, 6, 7, 8]])>> np.roll(x2, 1, axis=0) # 5列同时向垂直方向滚动1个位置
array([[5, 6, 7, 8, 9],
[0, 1, 2, 3, 4]])>> np.roll(x2, 1, axis=1) # 2行同时向水平方向滚动1个位置
array([[4, 0, 1, 2, 3],
[9, 5, 6, 7, 8]])
随机数生成
随机数生成—正态分布
loc:float
此概率分布的均值(对应着整个分布的中心centre)
scale:float
此概率分布的标准差(对应于分布的宽度,scale越大越矮胖,scale越小,越瘦高)
size:int or tuple of ints
输出的shape,默认为None,只输出一个值。若size=[n,m],则生成n行m列的随机矩阵np.random.normal(loc=1.0, scale=4.0, size=[n, m])
随机数生成—指定分布概率
从a中抽取3(size)个数据,不放回(replace=False),各个元素被抽到的概率为P
a=5意味着从【0,1,2,3,4】中抽取数字,p的大小和a相同
p如果没有指定(p = None),则是均匀分布的概率
np.random.choice(a=5, size=3, replace=False, p=[0.2, 0.1, 0.3, 0.4, 0.0])得到:array([3, 1, 0])
矩阵合并(矩阵连接)
x = np.array([1,2,3])
y = np.array([4,5,6])
data1 = np.c_[x, y] #列合并
data2 = np.r_[x, y] #行合并
结果:
data1 =
array([[1, 4],
[2, 5],
[3, 6]])
data2 =
array([1, 2, 3, 4, 5, 6])
矩阵转置
data = np.array([[1,2],[3,4],[5,6],[7,8]])
data_T = data.T #矩阵转置
# 或者这样也行
data_T = np.transpose(data)data =
array([[1, 2],
[3, 4],
[5, 6],
[7, 8]])data_T =
array([[1, 3, 5, 7],
[2, 4, 6, 8]])
矩阵相乘
a=np.array([[1,2],[3,4]])
b=np.array([[5,6],[7,8]])
c=np.dot(a, b)
结果:
a =
array([[1, 2],
[3, 4]])
b =
array([[5, 6],
[7, 8]])
c =
array([[19, 22],
[43, 50]])
计算协方差矩阵
data=np.array([[1,2],[3,4],[5,6],[7,8]])
cov = np.cov(data.T) #计算协方差矩阵
结果:
data =
array([[1, 2],
[3, 4],
[5, 6],
[7, 8]])cov =
array([[11.81243026, 4.05894877],
[ 4.05894877, 5.40936976]])
计算矩阵特征根和特征向量
data=np.array([[1,0,0],[0,2,0],[0,0,3]]) #要求矩阵是方阵
eig_val, eig_vec = np.linalg.eig(data)
结果:
data =
array([[1, 0, 0],
[0, 2, 0],
[0, 0, 3]])# eig_val:特征值
eig_val =
array([1., 2., 3.])# eig_vec:特征向量
eig_vec =
array([[1., 0., 0.],
[0., 1., 0.],
[0., 0., 1.]])