Numpy Tricks


这篇文章不定期更新,主要是记录在使用numpy过程中一些有效的tricks(或者重要的API)

import numpy as np

numpy.where()


numpy.where(condition, [,x,y])

参数:

- condition: 一个 bool array 或者 在源数组(original array)基础上由条件运算产生的 bool array

- x,y(optional, 或者两者都被传入函数,或者都不被传入): 两个和condition 产生的 bool array 具有相同的shape 的 array

因此numpy.where中或者有一个参数,或者有三个参数,而不会只有两个参数

返回值

- 如果x 与 y 均被传入, 那么它基于bool array 从 x 和 y 中选取元素 组成一个新的数组。原理: 遍历bool array, 如果bool array 某一位置的元素为True,那么从 x(array1) 中选取对应位置的元素作为新数组对应位置的元素, 如果为 False,从 y(array2) 中选择, 最终由 x的元素和 y 的元素组成一个新的数组

- 如果 x  与 y 均不被传入,那么它返回一个元组,每一个元组元素对应 original 数组 的某一维度 满足 condition元素的索引

因此numpy.where主要有两个用途

  1. 返回源数组满足条件(single condition or multi-condition) 的元素的对应索引

  2. 由两个指定数组 按照指定条件 产生一个新数组 (也即是一个三元运算符, x if condition else y, 只不过这里的 x y condition 拓展到了数组版本)

接下来是两个简单的例子(直接展示二维的情况,更高维或者一维与此类似)

# 创建源数组
o_array = np.arange(0, 9).reshape((3, 3)) # 创建 x ,y
x = np.array(['high value']*9).reshape((3, 3))
y = np.array(['low value']*9).reshape((3, 3)) print(f'x=: \n{x}')
print(f'y=: \n{y}')
print(f'original=: \n{o_array}')
x=:
[['high value' 'high value' 'high value']
['high value' 'high value' 'high value']
['high value' 'high value' 'high value']]
y=:
[['low value' 'low value' 'low value']
['low value' 'low value' 'low value']
['low value' 'low value' 'low value']]
original=:
[[0 1 2]
[3 4 5]
[6 7 8]]
# 单个条件或者许多条件, 当然也可以直接使用bool array
single_condition = o_array >= 4
multi_condition = (o_array>=4) & (o_array<=6)
# 用法一  返回满足条件的元素的索引
idx_1 = np.where(single_condition)
idx_2 = np.where(multi_condition) print(f'单个条件返回的索引元祖为: {idx_1}') # 分别对应满足条件元素二维索引的横竖index
print(f'多个条件返回的索引元祖为: {idx_2}')
# 返回的元祖可以用于 索引相应满足条件的元素 elements = o_array[idx_1]
print(f"满足条件的元素: {elements}") # 也可以对于返回tuple元素进行合并 得到相应的二维索引
index = list(zip(idx_1[0], idx_1[1]))
print(index)
单个条件返回的索引元祖为:      (array([1, 1, 2, 2, 2]), array([1, 2, 0, 1, 2]))
多个条件返回的索引元祖为: (array([1, 1, 2]), array([1, 2, 0]))
满足条件的元素: [4 5 6 7 8]
[(1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]
# 用法二:作为三元表达式的一种创建一个新数组
new_array = np.where(single_condition, x, y)
print(f'新数组为: \n{new_array}')
新数组为:
[['low value' 'low value' 'low value']
['low value' 'high value' 'high value']
['high value' 'high value' 'high value']]

numpy.any()、ndarray.any() (numpy.all(), ndarray.all())


关于详细的背景知识和使用,这里有一个不错的英文教程

np.any(input_array, axis, output, keepdims, where)

参数:

input_array: 输入数组或者 array-like (如python list)

axis: 指定的运算轴, default = None, 维度可以为负数,即反向索引

output: 可以指定输出的数组,这个参数很少使用

keepdims: 决定输出是否要保留和输入一样的维度数

where: array of bol optional, 用于指定函数运算的位置

返回:

bool 值 或者一个bool array(在指定维度运算时)

功能:

检查 input_array 中在指定的位置(或者指定的维数)上是否存在 True。

一种典型的应用场景是 np.any(condition)

np.all() 的用法和np.any() 完全相同,区别在于字面意思 any vs all

input_array = np.arange(0, 9).reshape((3, 3))
condition = input_array >=4
print(f"默认缺省: {np.any(condition)}")
print(f"指定维度: {np.any(condition, axis=1)}")
print(f"指定维度的输出shape: {np.any(condition, axis=1).shape}")
print(f"keepdims 时的shape: {np.any(condition, axis=1, keepdims=True).shape}")
默认缺省:  True
指定维度: [False True True]
指定维度的输出shape: (3,)
keepdims 时的shape: (3, 1)

随机推荐

  1. 聊聊Spring Cloud Gateway

    网关概述 整体来看,网关有点类似于门面,所有的外部请求都会先经过网关这一层. 网关不仅只是做一个请求的转发及服务的整合,有了网关这个统一的入口之后,它还能提供以下功能. 针对所有请求进行统一鉴权.限流 ...

  2. Hive执行计划之什么是hiveSQL向量化模式及优化详解

    Hive开启向量化模式也是hiveSQL优化方法中的一种,可以提升hive查询速率,也叫hive矢量化. 问题1:那么什么是hive向量化模式呢? 问题2:hive向量化什么情况下可以被使用,或者说它 ...

  3. Airtest图像识别测试工具原理解读&最佳实践

    1 Airtest简介 Airtest是一个跨平台的.基于图像识别的UI自动化测试框架,适用于游戏和App,支持平台有Windows.Android和iOS.Airtest框架基于一种图形脚本语言Si ...

  4. IDEA中去除竖线

    IDEA中去除竖线 使用IDEA时突然多出了一条竖线 , 进入设置取消竖线

  5. TortoiseGit使用Cherry Pick遇到的问题及解决方案

    TortoiseGit的Cherry Pick 比如从master pick某一个commit 记录到其它分支(release) pick的操作方法:切到分支,点击 show log,然后在log d ...

  6. 计算机网络那些事之 MTU 篇 pt.2

    哈喽大家好,我是咸鱼 在<计算机网络那些事之 MTU 篇 >中,咸鱼跟大家介绍了 MTU 是指数据链路层能够传输的最大数据帧的大小 如果发送的数据大于 MTU,则就会进行分片操作(Frag ...

  7. knn和线性分类器

    一.knn算法概述 knn首选是最简单的分类算法,其是有监督学习的分类算法之一. 二.knn算法过程 knn(k nearest neighbors k个最近的邻居):knn是当预测一个新的值x的时候 ...

  8. AOA定位技术原理

    AOA定位技术是一种基于信号到达角度的定位方法,利用单一天线发射寻向讯号,而接收端的装置内建天线阵列, 当信号通过时, 会因阵列中接收到的不同距离, 产生相位差异, 进而计算出相对的信号方向:其原理如 ...

  9. 「学习笔记」KMP 算法

    前置知识 前缀 是指从串首开始到某个位置 \(i\) 结束的一个特殊子串. 真前缀 指除了 \(S\) 本身的 \(S\) 的前缀. 举例来说, 字符串 abcabeda 的所有前缀为 {a, ab, ...

  10. javascript中一些难以理解的专有名词 1(也不是很专有)

    变量提升 变量提升:是指js代码执行过程中,js引擎把变量的声明和函数的声明提升到代码的开头的"行为". 变量和函数在代码里的位置是不会变的,而是在编译阶段被js引擎放入内存中. ...