簡體   English   中英

如何有效地計算numpy中面具中距離最近1的距離?

[英]How to efficiently calculate distance to nearest 1 in mask in numpy?

在numpy我有一個1和0的2d數組。 我需要計算一個新的數組(相同的維度),其中每個元素包含距離掩碼數組中相應點最近的1的距離。

例如

a=np.array(
[[1,1,0],
[1,0,0],
[1,0,0]])

我需要b看起來像這樣:

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

PS。 我將在非常大的陣列上執行此操作,因此效率越高越好! 謝謝!

你正在尋找相當於MATLAB的bwdist ; 查看此SO問題了解更多詳情。 簡短的回答是使用scipy.ndimage.morphology.distance_transform_edt

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM