【numpy基础】--通用计算

numpy,基础,通用,计算 · 浏览次数 : 40

小编点评

**4.1. 指定输出位置进行两个数组的计算时,比如x数组和y数组,计算的结果常常要用新的数组(比如z数组)来保存。如果计算之后x数组或y数组不再需要的话,我们可以把运算结果保存在x数组或y数组中,这样就不用申请信的内存。** **4.2. 简单的聚合对于任意一个数组,按行或者列聚合合计值时:** * per列的合计值print(np.add.reduce(x)) * 每行的合计值print(np.add.reduce(x, axis=1)) **4.1. 指定输出位置进行两个数组的计算时,比如x数组和y数组,计算的结果常常要用新的数组(比如z数组)来保存。如果计算之后x数组或y数组不再需要的话,我们可以把运算结果保存在x数组或y数组中,这样就不用申请信的内存。** **4.2. 简单的聚合对于任意一个数组,按行或者列聚合合计值时:** * per列的合计值print(np.add.reduce(x)) * 每行的合计值print(np.add.reduce(x, axis=1)) **5. 总结回顾本篇主要介绍了 numpy array的通用计算方法,通用计算把数组元素循环的复杂度封装起来,让我们用直观的方式计算数组,更容易实现各种数学公式和定理。**

正文

numpy提供了简单灵活的接口,用于优化数据数组的计算。
通用计算最大的优势在于通过向量化操作,将循环推送至numpy之下的编译层,从而取得更快的执行效率。

numpy的通用计算让我们计算数组时就像计算单独一个变量一样,
不用写循环去遍历数组中的各个元素。
比如,对于一般的python二维数组,我们要给数组中每个值加1:

l = [[1, 2], [3, 4]]
print(l)
#运行结果
[[1, 2], [3, 4]]

for i in range(len(l)):
    for j in range(len(l[i])):
        l[i][j] += 1

print(l)
#运行结果
[[2, 3], [4, 5]]

如果用numpy的通用计算的话:

import numpy as np

l = np.array([[1,2], [3,4]])
print(l)
#运行结果
[[1, 2], [3, 4]]

l = l + 1
print(l)
#运行结果
[[2, 3], [4, 5]]

1. 算术计算

算术计算是最基本的,numpy数组支持直接用运算符或者通用函数来进行运算。

运算符 通用函数 说明
+ np.add 加法运算
- np.subtract 减法运算
* np.multiply 乘法运算
/ np.divide 除法运算
// np.floor_divide 向下整除运算
** np.power 指数运算
% np.mod 模运算

算术运算比较简单,就不一一演示各个运算符了。

需要注意的一点是,当numpy数组和单一数字运算时,数组中每个元素都单独和此数字运算。

arr = np.array([[1,2], [3, 4]])
print(arr)
#运行结果
[[1 2]
 [3 4]]

print(arr * 2)
#运行结果
[[2 4]
 [6 8]]

arr * 2 相当于arr中每个元素都 * 2

numpy数组和另一个numpy数组运算时,是两个数组对应位置的元素进行运算。
这就要求两个数组的 shape 要一样,否则会出错。

arr1 = np.array([[1, 2], [3, 4]])
arr2 = np.array([[1, 0], [0, 1]])
print(arr1, arr2)
#运行结果
[[1 2]
 [3 4]]

[[1 0]
 [0 1]]

print(arr1 * arr2)
#运行结果
[[1 0]
 [0 4]]

对应元素相乘,所以只保留了对角线上的元素。

2. 三角函数

除了常用的算术运算,numpy的数组支持各类三角函数运算。
下面演示几个常用的三角函数:

arr = np.array([0, np.pi/6, np.pi/4, np.pi/2])

print("sin(arr)     = ", np.sin(arr))
print("cos(arr)     = ", np.cos(arr))
print("tan(arr)     = ", np.tan(arr))
#运行结果
sin(arr)     =  [0.         0.5        0.70710678 1.        ]
cos(arr)     =  [1.00000000e+00 8.66025404e-01 7.07106781e-01 6.12323400e-17]
tan(arr)     =  [0.00000000e+00 5.77350269e-01 1.00000000e+00 1.63312394e+16]

arr = np.array([-1, 0, 1])
print("arcsin(arr)  = ", np.arcsin(arr))
print("arccos(arr)  = ", np.arccos(arr))
print("arctan(arr)  = ", np.arctan(arr))
#运行结果
arcsin(arr)  =  [-1.57079633  0.          1.57079633]
arccos(arr)  =  [3.14159265 1.57079633 0.        ]
arctan(arr)  =  [-0.78539816  0.          0.78539816]

3. 指数和对数

常用的指数和对数如下:

x = np.array([1, 2, 4, 10])

print("e^x = ", np.exp(x))
print("2^x = ", np.exp2(x))
print("3^x = ", np.power(3, x))
#运行结果
e^x =  [2.71828183e+00 7.38905610e+00 5.45981500e+01 2.20264658e+04]
2^x =  [   2.    4.   16. 1024.]
3^x =  [    3     9    81 59049]

print("ln(x)    = ", np.log(x))
print("log2(x)  = ", np.log2(x))
print("log10(x) = ", np.log10(x))
#运行结果
ln(x)    =  [0.         0.69314718 1.38629436 2.30258509]
log2(x)  =  [0.         1.         2.         3.32192809]
log10(x) =  [0.         0.30103    0.60205999 1.        ]

4. 通用特性

除了通用的计算方法,还有一些特性也很有用。
下面介绍两个常用的特性,一个可以节约内存,提高程序的运行效率;另一个可以简化编码,提高程序的编写效率。

4.1. 指定输出位置

进行两个数组的计算时,比如x数组和y数组,计算的结果常常要用新的数组(比如z数组)来保存。

如果计算之后x数组或y数组不再需要的话,我们可以把运算结果保存在x数组或y数组中,这样就不用申请信的内存。

x = np.random.randint(1, 10, (3,3))
y = np.random.randint(1, 10, (3,3))

print(x)
print(y)
#运行结果
[[3 9 3]
 [8 6 9]
 [9 7 4]]
[[4 4 5]
 [1 6 6]
 [2 5 6]]

np.multiply(x, y, out=y)
print(x)
print(y)
#运行结果
[[3 9 3]
 [8 6 9]
 [9 7 4]]
[[12 36 15]
 [ 8 36 54]
 [18 35 24]]

设置参数 out=y,可以看到计算结果保存在了y数组中。

4.2. 简单的聚合

对于任意一个数组,按行或者列聚合合计值时:

x = np.random.randint(1, 10, (3,3))
print(x)
#运行结果
[[8 6 5]
 [4 8 4]
 [9 2 3]]

#每列的合计值
print(np.add.reduce(x))
#运行结果
[21 16 12]

#每行的合计值
print(np.add.reduce(x, axis=1))
#运行结果
[19 16 14]

上面是用np.add来聚合的,也可以使用 np.multiplynp.divide等等前面介绍的各种算术计算。

除了聚合合计值,numpy还提供了一个可以计算合计过程中每步计算结果的方法accumulate

x = np.random.randint(1, 10, 5)
print(x)
#运算结果
[6 1 6 9 7]

print(np.add.accumulate(x))
#运算结果:[x[0], x[0]+x[1], x[0]+x[1]+x[2]...]
[ 6  7 13 22 29]

print(np.multiply.accumulate(x))
#运算结果:[x[0], x[0]*x[1], x[0]*x[1]*x[2]...]
[6    6   36  324 2268]

5. 总结回顾

本篇主要介绍了 numpy数组的通用计算方法,通用计算把数组元素循环的复杂度封装起来,让我们用直观的方式计算数组,更容易实现各种数学公式和定理。

本篇介绍的算术计算三角函数,以及指数和对数等常用的方法,但不是全部的通用计算方法,更加复杂的微分和积分计算请参考官方的文档。

与【numpy基础】--通用计算相似的内容:

【numpy基础】--通用计算

`numpy`提供了简单灵活的接口,用于优化数据数组的计算。 通用计算最大的优势在于通过向量化操作,将循环推送至`numpy`之下的编译层,从而取得更快的执行效率。 `numpy`的通用计算让我们计算数组时就像计算单独一个变量一样, 不用写循环去遍历数组中的各个元素。 比如,对于一般的`python

【numpy基础】--聚合计算

上一篇介绍的**通用计算**是关于多个`numpy`数组的计算, 本篇介绍的**聚合计算**一般是针对单个数据集的各种统计结果,同样,使用**聚合函数**,也可以避免繁琐的循环语句的编写。 # 元素的和 数组中的元素求和也就是合计值。 ## 调用方式 **聚合计算**有两种调用方式,一种是面向对象的

【numpy基础】--数组排序

`numpy` 数组通常是用于数值计算的多维数组,而排序功能可以快速、准确地对数据进行排序,从而得到更加清晰、易于分析的结果。 在数据分析和处理过程中,常常需要对数据进行排序,以便更好地理解和发现其中的规律和趋势。 排序会应用在很多场景中,比如: 1. 数据分类:将数据按照一定的特征进行分类,可以通

【numpy基础】--数组过滤

在`numpy`中,数组可以看作是一系列数值的有序集合,可以通过下标访问其中的元素。处理数组的过程中,经常需要用到数组过滤功能。 过滤功能可以在处理数据时非常有用,因为它可以使数据更加干净和可读性更强。例如,在进行数据分析时,通常需要去除异常值,过滤掉不必要的元素可以使数据更加易于分析和处理。 `n

学会使用 NumPy:基础、随机、ufunc 和练习测试

NumPy NumPy 是一个用于处理数组的 Python 库。它代表“Numerical Python”。 基本 随机 ufunc 通过测验测试学习 检验您对 NumPy 的掌握程度。 通过练习学习 NumPy 练习 练习: 请插入创建 NumPy 数组的正确方法。 arr = np. ([1,

NumPy 随机数据分布与 Seaborn 可视化详解

本文介绍了数据分布的概念,它是统计学和数据科学的基础,描述了数据可能出现的频率。NumPy的`random`模块支持生成不同分布的随机数,如`choice`用于离散分布,`randn`和`rand`等用于连续分布。此外,还介绍了数组的随机洗牌和排列。通过Seaborn库,可以创建统计图表,如`dis...

【matplotlib基础】--图例

Matplotlib 中的图例是帮助观察者理解图像数据的重要工具。图例通常包含在图像中,用于解释不同的颜色、形状、标签和其他元素。 1. 主要参数 当不设置图例的参数时,默认的图例是这样的。 import numpy as np import matplotlib.pyplot as plt x =

【numpy基础】--数组简介

`NumPy`(Numerical Python)是一个`Python`库,主要用于高效地处理多维数组和矩阵计算。它是科学计算领域中使用最广泛的一个库。 在`NumPy`中,**数组**是最核心的概念,用于存储和操作数据。 `NumPy`数组是一种多维数组对象,可以存储相同类型的元素,它支持高效的数

【numpy基础】--基础操作

`numpy`作为一个强大的数值计算库,提供了对多维数组的很多便捷操作。 承接上一篇数组的创建,本篇主要介绍一些数组的基本操作。 # 1. 子数组 首先介绍获取子数组的方法,提取已有数据的一部分来参与计算是比较常用的功能。 对于一维数组,提取子数组:`arr[start:stop:step]` 1.

【numpy基础】--广播计算

`numpy`的广播计算是指在多维数组上进行的一种高效计算方式。 它可以将计算任务分配到每个维度上,并且可以在计算过程中进行数据共享和同步,从而提高计算效率和精度。 广播计算在数值计算、科学计算、机器学习等领域都有广泛的应用。 例如,在数值计算中,广播计算可以用于求解大规模的非线性方程组;在科学计算