溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python怎么實現(xiàn)標記數(shù)組的連通域

發(fā)布時間:2023-04-20 11:25:57 來源:億速云 閱讀:104 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“Python怎么實現(xiàn)標記數(shù)組的連通域”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

連通域標記

通過label函數(shù),可以對數(shù)組中的連通區(qū)域進行標注,效果如下

from scipy.ndimage import label
import numpy as np
a = np.array([[0,0,1,1,0,0],
              [0,0,0,1,0,0],
              [1,1,0,0,1,0],
              [0,0,0,1,0,0]])
labels, N = label(a)
print(labels)
'''
[[0 0 1 1 0 0]
 [0 0 0 1 0 0]
 [2 2 0 0 3 0]
 [0 0 0 4 0 0]]
'''
print(N)    4

其中,a是一個二值矩陣,經(jīng)過label標記后,其相連通的部分分別被標上了序號??梢愿庇^地用圖像顯示一下

import matplotlib.pyplot as plt
fig = plt.figure()
ax = fig.add_subplot(121)
plt.imshow(a)
ax = fig.add_subplot(122)
plt.imshow(labels)
plt.show()

Python怎么實現(xiàn)標記數(shù)組的連通域

structure參數(shù)

在label函數(shù)中,還有一個用于規(guī)范何為“連通”的參數(shù),即structure,其數(shù)據(jù)類型為二值數(shù)組,其維度與輸入的input相同。

在上面的示例中,連通域1,3,4盡管沒有上下左右的聯(lián)系,但在對角線上是有交集的,通過調(diào)整structure參數(shù),可以提供一種將這三個區(qū)域連在一起的連通域方案。

stru = np.ones([3,3])
bLab, bN = label(a, stru)
print(bLab)
‘'‘
[[0 0 1 1 0 0]
 [0 0 0 1 0 0]
 [2 2 0 0 1 0]
 [0 0 0 1 0 0]]
'‘'

可見,這次只選出了兩組連通域。

操作連通域

scipy.ndimage提供了labeled_comprehension函數(shù),其功能大致相當(dāng)于[func(input[labels == i]) for i in index],即從已經(jīng)做好連。通域標記的數(shù)組中,取出序號為index所在區(qū)域的值,參數(shù)如下

labeled_comprehension(input, labels, index, func, out_dtype, default, pass_positions=False)

其中input為輸入數(shù)組;labels是已經(jīng)做好的連通域標記;index為將要挑選進行操作的連通域序號;func為具體的操作函數(shù);out_dtype為輸出數(shù)據(jù)類型;default表示,當(dāng)index不存在于連通域標記中時的輸出值,下面做一個示例

from scipy.ndimage import labeled_comprehension
labeled_comprehension(a, labels, [1,2,3,4], sum, int, 0)
# array([3, 2, 1, 1])

連通域序號為1,2,3,4的區(qū)域,分別有3,2,1,1個元素,而且所有元素都是1,所以求和之后的值為[3, 2, 1, 1]。

定位連通域

scipy.ndimage中的find_objects函數(shù)可以返回連通域的切片范圍。

from scipy.ndimage import find_objects
axis = find_objects(labels)
for x,y in axis:
    print(x, y)

'''
slice(0, 2, None) slice(2, 4, None)
slice(2, 3, None) slice(0, 2, None)
slice(2, 3, None) slice(4, 5, None)
slice(3, 4, None) slice(3, 4, None)
''''

如果根據(jù)這個對原數(shù)組進行切片,就可以得到其對應(yīng)的標記區(qū)域

for x,y in axis:
    print(labels[x,y])
    print("--------")
'''
[[1 1]
 [0 1]]
--------
[[2 2]]
--------
[[3]]
--------
[[4]]
--------
'''

“Python怎么實現(xiàn)標記數(shù)組的連通域”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI