注記
完全なサンプルコードをダウンロードするには、こちらへ。または、Binderを介してブラウザでこの例を実行します。
領域境界RAGの階層的マージ#
この例では、領域境界領域隣接グラフ(RAGs)に対して階層的マージを実行する方法を示します。領域境界RAGは、skimage.graph.rag_boundary()
関数を使用して構築できます。thresh
よりも小さい重みのエッジがなくなるまで、エッジウェイトが最も低い領域が順次マージされます。階層的マージは、skimage.graph.merge_hierarchical()
関数を使用して実行されます。領域境界に基づいたRAGの構築方法の例については、領域境界に基づく領域隣接グラフ(RAGs)を参照してください。
from skimage import data, segmentation, filters, color
from skimage import graph
from matplotlib import pyplot as plt
def weight_boundary(graph, src, dst, n):
"""
Handle merging of nodes of a region boundary region adjacency graph.
This function computes the `"weight"` and the count `"count"`
attributes of the edge between `n` and the node formed after
merging `src` and `dst`.
Parameters
----------
graph : RAG
The graph under consideration.
src, dst : int
The vertices in `graph` to be merged.
n : int
A neighbor of `src` or `dst` or both.
Returns
-------
data : dict
A dictionary with the "weight" and "count" attributes to be
assigned for the merged node.
"""
default = {'weight': 0.0, 'count': 0}
count_src = graph[src].get(n, default)['count']
count_dst = graph[dst].get(n, default)['count']
weight_src = graph[src].get(n, default)['weight']
weight_dst = graph[dst].get(n, default)['weight']
count = count_src + count_dst
return {
'count': count,
'weight': (count_src * weight_src + count_dst * weight_dst) / count,
}
def merge_boundary(graph, src, dst):
"""Call back called before merging 2 nodes.
In this case we don't need to do any computation here.
"""
pass
img = data.coffee()
edges = filters.sobel(color.rgb2gray(img))
labels = segmentation.slic(img, compactness=30, n_segments=400, start_label=1)
g = graph.rag_boundary(labels, edges)
graph.show_rag(labels, g, img)
plt.title('Initial RAG')
labels2 = graph.merge_hierarchical(
labels,
g,
thresh=0.08,
rag_copy=False,
in_place_merge=True,
merge_func=merge_boundary,
weight_func=weight_boundary,
)
graph.show_rag(labels, g, img)
plt.title('RAG after hierarchical merging')
plt.figure()
out = color.label2rgb(labels2, img, kind='avg', bg_label=0)
plt.imshow(out)
plt.title('Final segmentation')
plt.show()
スクリプトの総実行時間:(0分1.963秒)