假设我有一个numpy数组,我需要找到条件为True的跨度/范围。例如,我有以下数组,我试图在其中查找项目大于1的跨度:
[0, 0, 0, 2, 2, 0, 2, 2, 2, 0]
我需要找到索引(开始,停止):
(3, 5)
(6, 9)
我能够实现的最快的方法是创建一个布尔数组:
truth = data > threshold
然后使用numpy.argmin和遍历数组numpy.argmax以查找开始和结束位置。
pos = 0
truth = container[RATIO,:] > threshold
while pos < len(truth):
start = numpy.argmax(truth[pos:]) + pos + offset
end = numpy.argmin(truth[start:]) + start + offset
if not truth[start]:#nothing more
break
if start == end:#goes to the end
end = len(truth)
pos = end
但这对于我数组中的数十亿个位置来说太慢了,而且我发现的跨度通常只是连续几个位置。有谁知道找到这些跨度的更快方法?
呼啦一阵风
慕仙森
相关分类