Python替換NumPy數(shù)組中大于某個值的所有元素實例
我有一個2D(二維) NumPy數(shù)組,并希望用255.0替換大于或等于閾值T的所有值。據(jù)我所知,最基礎(chǔ)的方法是:
shape = arr.shape result = np.zeros(shape) for x in range(0, shape[0]): for y in range(0, shape[1]): if arr[x, y] >= T: result[x, y] = 255
有更簡潔和pythonic的方式來做到這一點嗎?
有沒有更快(可能不那么簡潔和/或不那么pythonic)的方式來做到這一點?
這將成為人體頭部MRI掃描窗口/等級調(diào)整子程序的一部分,2D numpy數(shù)組是圖像像素數(shù)據(jù)。

最佳解決思路
我認(rèn)為最快和最簡潔的方法是使用Numpy的內(nèi)置索引。如果您有名為arr的ndarray,則可以按如下所示將所有元素>255替換為值x:
arr[arr > 255] = x
我用500 x 500的隨機(jī)矩陣在我的機(jī)器上運行了這個函數(shù),用5替換了所有> 0.5的值,平均耗時7.59ms。
In [1]: import numpy as np In [2]: A = np.random.rand(500, 500) In [3]: timeit A[A > 0.5] = 5 100 loops, best of 3: 7.59 ms per loop
次佳解決思路
因為實際上需要一個不同的數(shù)組,arr,其中arr < 255,可以簡單地完成:
result = np.minimum(arr, 255)
更一般地,對于下限和/或上限:
result = np.clip(arr, 0, 255)
如果只是想訪問超過255的值,np.clip和np.minimum(或者np.maximum)對你的情況更好更快。
In [292]: timeit np.minimum(a, 255) 100000 loops, best of 3: 19.6 µs per loop In [293]: %%timeit .....: c = np.copy(a) .....: c[a>255] = 255 .....: 10000 loops, best of 3: 86.6 µs per loop
如果要執(zhí)行in-place(即修改arr而不是創(chuàng)建result),則可以使用np.minimum的out參數(shù):
np.minimum(arr, 255, out=arr)
或者
np.clip(arr, 0, 255, arr)
(out=名稱是可選的,因為參數(shù)的順序與函數(shù)的定義相同。)
對于in-place修改,布爾索引加速了很多(不必分別修改和拷貝),但仍然不如minimum:
In [328]: %%timeit .....: a = np.random.randint(0, 300, (100,100)) .....: np.minimum(a, 255, a) .....: 100000 loops, best of 3: 303 µs per loop In [329]: %%timeit .....: a = np.random.randint(0, 300, (100,100)) .....: a[a>255] = 255 .....: 100000 loops, best of 3: 356 µs per loop
比較來看,如果你想限制你的最大值和最小值,沒有clip將不得不像下面這樣做兩次
np.minimum(a, 255, a)
np.maximum(a, 0, a)
要么,
a[a>255] = 255
a[a<0] = 0
第三種解決思路
可以通過使用where功能來達(dá)到最快的速度:
例如,在numpy數(shù)組中查找大于0.2的項目,并用0代替它們:
import numpy as np nums = np.random.rand(4,3) print np.where(nums > 0.2, 0, nums)
第四種思路
可以考慮使用numpy.putmask:
np.putmask(arr, arr>=T, 255.0)
下面是與Numpy內(nèi)置索引的性能比較:
In [1]: import numpy as np In [2]: A = np.random.rand(500, 500) In [3]: timeit np.putmask(A, A>0.5, 5) 1000 loops, best of 3: 1.34 ms per loop In [4]: timeit A[A > 0.5] = 5 1000 loops, best of 3: 1.82 ms per loop
以上這篇Python替換NumPy數(shù)組中大于某個值的所有元素實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python壓縮模塊zipfile實現(xiàn)原理及用法解析
這篇文章主要介紹了Python壓縮模塊zipfile實現(xiàn)原理及用法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08
Python中g(shù)etpass模塊無回顯輸入源碼解析
這篇文章主要介紹了Python中g(shù)etpass模塊無回顯輸入源碼解析,具有一定借鑒價值,需要的朋友可以參考下2018-01-01
在多種情況/開發(fā)環(huán)境中運行python腳本和代碼的技巧分享
Python腳本或程序是包含可執(zhí)行Python代碼的文件,能夠運行Python腳本和代碼可能是您作為Python開發(fā)人員所需的最重要的技能,在本教程中,您將學(xué)習(xí)一些運行Python腳本和代碼的技術(shù),在每種情況下使用的技術(shù)將取決于您的環(huán)境、平臺、需求和技能2023-11-11
python實現(xiàn)nao機(jī)器人手臂動作控制
這篇文章主要為大家詳細(xì)介紹了python實現(xiàn)nao機(jī)器人手臂動作控制,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-04-04
Python高級排序sort()函數(shù)使用技巧實例探索
本文詳細(xì)介紹sort()函數(shù)的使用,包括基本排序、自定義排序、逆序排序等多種情況,并提供大量示例代碼,以幫助你充分理解和掌握這一函數(shù)的用法,探索更多sort()排序函數(shù)的作用2024-01-01
python中redis查看剩余過期時間及用正則通配符批量刪除key的方法
這篇文章主要介紹了python中redis查看剩余過期時間及用正則通配符批量刪除key的方法,需要的朋友可以參考下2018-07-07

