numpy中文手册

本文详细介绍了使用NumPy进行向量循环移动、随机数生成、矩阵运算等关键操作的方法,包括正态分布随机数生成、矩阵合并、转置、相乘、协方差矩阵及特征值计算。

网址:

https://www.numpy.org.cn/

目录

导入模块:

向量循环移动

随机数生成

随机数生成—正态分布

随机数生成—指定分布概率

矩阵合并(矩阵连接)

矩阵转置

矩阵相乘

计算协方差矩阵

计算矩阵特征根和特征向量



 


导入模块:

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.]])

 

### Python NumPy 中文文档与官方手册 对于希望获取 **Python NumPy中文文档或官方手册** 的需求,以下是详细的解答: #### 1. 官方英文文档 NumPy 提供了详尽的官方英文文档,涵盖了从基础知识到高级功能的内容。可以通过以下链接访问: - [NumPy Official Documentation](https://numpy.org/doc/) [^1] 此文档包含了 API 参考、教程以及开发指南等内容。 --- #### 2. 中文翻译版文档 由于部分开发者更倾向于阅读中文资料,社区提供了多种高质量的 NumPy 中文文档资源: ##### (1)GitCode 上的 NumPy 中文文档 由开源项目维护的一份完整的 NumPy 中文文档,适合初学者和进阶用户查阅。可以在此处下载 PDF 或 HTML 版本: - 下载地址:[NumPy 中文文档下载](https://gitcode.com/Open-source-documentation-tutorial/464ff) [^2] ##### (2)其他在线版本 一些网站也托管了 NumPy中文文档,可以直接在线浏览而无需下载: - 推荐站点:[Numpy中文文档](http://www.numpy.org.cn/)(需确认可用性) --- #### 3. 学习建议 虽然许多工具支持 Python 原生列表作为输入参数,但在科学计算领域中,NumPy 数组因其高效的内存管理和丰富的操作接口成为首选数据结构 [^3]。因此,在学习过程中应重点关注以下几个方面: - `ndarray` 的创建与基本属性; - 数据重塑、合并与分割; - 高效的数值运算方法。 可参考如下学习路径的手册内容 [^4]: ```python import numpy as np # 示例代码展示 ndarray 创建与简单操作 arr = np.array([1, 2, 3]) print("原始数组:", arr) reshaped_arr = arr.reshape((1, 3)) print("重塑后的数组:\n", reshaped_arr) ``` --- #### 4. 社区支持与其他资源 如果遇到具体问题无法通过文档解决,还可以尝试以下途径寻求帮助: - 加入 Python 科学计算相关的论坛或 QQ 群; - 浏览 Stack Overflow 和知乎上的相关讨论。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值