Question regarding plotting graph

1 view (last 30 days)
jana
jana on 6 Dec 2013
Edited: Kelly Kearney on 19 Dec 2013
I wanted to plot a graph with 300 nodes represented as a 300x300 adjacency matrix. it looks like this(it is just an example)
[0 2 5 0;0 0 1 4;0 1 0 2 ; 0 3 2 0]
if the matrix has a zero that means there is no edge between the nodes. If it is not zero, then there is an edge with distance as the number in the matrix.
Please help!

Answers (2)

Kelly Kearney
Kelly Kearney on 6 Dec 2013
  2 Comments
John
John on 6 Dec 2013
I tried gplot but it needs coordinate inputs.. I don't quite understand how to use it.
Kelly Kearney
Kelly Kearney on 6 Dec 2013
Edited: Kelly Kearney on 19 Dec 2013
Do you mean that you're looking for something that will automatically determine the best locations for your nodes? There are some functions like that in the Bioinformatics toolbox:
adj = [0 2 5 0;0 0 1 4;0 1 0 2 ; 0 3 2 0];
b = biograph(adj);
view(b);
I think that function uses Graphviz (www.graphviz.org) under its hood, so if you don't have that toolbox, you might want to go to that instead (and Graphviz includes several more layout algorithms).

Sign in to comment.


Felix
Felix on 6 Dec 2013
Edited: Felix on 6 Dec 2013
As I understand this, the adjacency matrix only tells how the nodes are connected, not where each of them is located. So your challenge is to construct this coordinate matrix. If they are e.g. in a 20x15 matrix (=300 points), it would be [1,1;...1,15;...;20,1;...;20,15]. (I assume, but I've never used gplot either....)

Categories

Find more on Graph and Network Algorithms in Help Center and File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!