python - 根据不同维度的条件屏蔽ndarray
问题描述
我有形状为(3,794,1255)的ndarray。我想根据 ndarray 的前 2 个波段创建掩码,因此我的输出将是一个具有 xy 坐标的数组,其中 0 表示未满足 2 个条件的像素,1 表示满足条件的像素。
例如,条件可以是:
array.shape
>>>(3,794,1255)
array[0]>0.65
0.2<array[1]<0.4
mask = (array[0] > 0.65) & (0.2<array[1]<0.4)
array[mask]
但这会返回错误:
IndexError:布尔索引与维度 0 上的索引数组不匹配;维度为 3,但对应的布尔维度为 794
我的问题是如何根据 ndarray 的两个第一维度创建一个遮罩层?有没有更好的方法来做到这一点?
解决方案
这就是我倾向于做的事情:
mask = np.array(condition 1) * np.array(condition 2) + np.array(condition n)
使用 * 表示“和”,使用 + 表示“或”
例子:
r = np.random.random((3,5,5))
mask = np.array(0.2<r[1]) * np.array(r[1]<0.4) * np.array(r[0] < .65)
r 是:
array([[[0.2373137 , 0.75311162, 0.00749418, 0.62770494, 0.6802736 ],
[0.99861914, 0.98375702, 0.48055185, 0.76576586, 0.57430756],
[0.56211162, 0.29463516, 0.96651997, 0.17392071, 0.85070297],
[0.39914012, 0.20810329, 0.18085806, 0.02747008, 0.54901285],
[0.66871882, 0.37093185, 0.14755093, 0.17983568, 0.75469553]],
[[0.81590629, 0.61742905, 0.34190211, 0.73226403, 0.88913768],
[0.74056323, 0.13472895, 0.3629095 , 0.44750391, 0.37093239],
[0.93072263, 0.55193092, 0.93684829, 0.17397018, 0.54124493],
[0.29852027, 0.93821551, 0.46921668, 0.61645803, 0.4749333 ],
[0.94431342, 0.13278848, 0.71384213, 0.33611594, 0.81344182]],
[[0.41933789, 0.654538 , 0.37429377, 0.57694553, 0.43628154],
[0.87547837, 0.45714451, 0.84946798, 0.46364122, 0.0405608 ],
[0.19172952, 0.96078271, 0.78402289, 0.34496085, 0.01560104],
[0.1903755 , 0.66774343, 0.79225036, 0.41254314, 0.79447361],
[0.32102159, 0.55022489, 0.77361031, 0.73757623, 0.73835877]]])
面具是:
array([[False, False, True, False, False],
[False, False, True, False, True],
[False, False, False, False, False],
[ True, False, False, False, False],
[False, False, False, True, False]])
推荐阅读
- excel - 如何仅计算一部分行的两列数之和?
- python-requests - Python 响应模块在 Linux 中使用多线程时不稳定
- vue.js - Vuex 模拟存储在 Jest 单元测试中未定义
- r - 如何在 R 中将向量拆分为具有指定子向量长度的子向量
- sql-server - 从 id 不在 id 列表中的表中选择
- angular - 我将如何从另一个列表中生成一个列表?
- php - 如何将哈希密码验证更改为普通密码?
- c# - 打开一个动态创建的按钮时,所有按钮都打开
- java - 我应该使用 try/catch 吗?
- c# - 如何在使用 MS Access 和 OleDb 连接的 Insert Into 命令期间返回主键值?