python比较数组中数的大小_比较两个不同长度的numpy数组

这篇博客介绍了如何使用numpy的digitize和searchsorted函数来比较和处理不同长度的数组。通过示例展示了这两个函数的用法,并进行了性能测试,结果显示在特定情况下,digitize和searchsorted的性能各有优势。
摘要由CSDN通过智能技术生成

这可能是一种特殊情况,但您应该能够使用numpydigitize。这里需要注意的是,垃圾箱必须是单调递减或递增的。>>> import numpy

>>> a = numpy.array([10,7,2,0])

>>> b = numpy.array([10,9,8,7,6,5,4,3,2,1])

>>> indices = [numpy.where(a<=x)[0][0] for x in b]

[0, 1, 1, 1, 2, 2, 2, 2, 2, 3]

>>> numpy.digitize(b,a)

array([0, 1, 1, 1, 2, 2, 2, 2, 2, 3])

定时测试的设置:a = np.arange(50)[::-1]

b = np.random.randint(0,50,1E3)

np.allclose([np.where(a<=x)[0][0] for x in b],np.digitize(b,a))

Out[55]: True

一些时间安排:%timeit [np.where(a<=x)[0][0] for x in b]

100 loops, best of 3: 4.97 ms per loop

%timeit np.digitize(b,a)

10000 loops, best of 3: 48.1 µs per loop

看起来速度提高了两个数量级,但这在很大程度上取决于垃圾箱的数量。你的时间会有所不同。

为了与杰米的答案相比较,我已经计时了下面两段代码。由于我主要想关注的是searchsorted与digitize的速度&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值