Get node names after a graph condensation
古いコメントを表示
I have an adjacency matrix adj and a cellarray nodeManes that contains names that will be given to the graph G that will be constructed from adj
So I use
G = digraph(adj,nodeNames);
And I get the following graph :

Now , I want to find the strongly connected components in G and do a graph condensation so I use the following :
C = condensation(G);
p2 = plot(C);
So I get the following graph :

So I have 6 strongly connected components , but my problem is that I lost the node names , I want to get something like :

Is that any way to get the nodes names in the result of the condentation ?
Thanks.
採用された回答
その他の回答 (1 件)
Walter Roberson
2017 年 12 月 4 日
Stealing basic technique from Christine, and reworking it without a loop:
bins = conncomp(G);
temp = accumarray(bins.', (1:length(bins)).', [], @(IDX) {G.Nodes.Name(IDX)});
C.Nodes.Name = cellfun(@(CS) strjoin(CS, ', '), temp, 'uniform', 0);
10 件のコメント
Christine Tobler
2017 年 12 月 4 日
Very nice!
stam dadi
2017 年 12 月 4 日
Walter Roberson
2017 年 12 月 4 日
I wouldn't have known the calls to make without Christine's post.
stam dadi
2017 年 12 月 5 日
Steven Lord
2017 年 12 月 5 日
It shouldn't be a struct. In your original code it was the output of a call to condensation, which would return a digraph if called with a digraph. Walter and Christine's codes modified that digraph, specifically the names of the digraph's nodes.
Walter Roberson
2017 年 12 月 5 日
You would get a struct as an output if you had assigned the output
C = condensation(G);
to some other variable name than C
stam dadi
2017 年 12 月 5 日
Waseem AL Aqqad
2021 年 11 月 27 日
Wow! Thanks.
カテゴリ
ヘルプ センター および File Exchange で Directed Graphs についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!