Get node names after a graph condensation
Afficher commentaires plus anciens
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.
Réponse acceptée
Plus de réponses (1)
Walter Roberson
le 4 Déc 2017
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 commentaires
Christine Tobler
le 4 Déc 2017
Very nice!
stam dadi
le 4 Déc 2017
Walter Roberson
le 4 Déc 2017
I wouldn't have known the calls to make without Christine's post.
stam dadi
le 5 Déc 2017
Steven Lord
le 5 Déc 2017
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
le 5 Déc 2017
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
le 5 Déc 2017
Waseem AL Aqqad
le 27 Nov 2021
Wow! Thanks.
Catégories
En savoir plus sur Graph and Network Algorithms dans Centre d'aide et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!