Question regarding plotting graph

1 visualización (últimos 30 días)
jana
jana el 6 de Dic. de 2013
Editada: Kelly Kearney el 19 de Dic. de 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!

Respuestas (2)

Kelly Kearney
Kelly Kearney el 6 de Dic. de 2013
  2 comentarios
John
John el 6 de Dic. de 2013
I tried gplot but it needs coordinate inputs.. I don't quite understand how to use it.
Kelly Kearney
Kelly Kearney el 6 de Dic. de 2013
Editada: Kelly Kearney el 19 de Dic. de 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).

Iniciar sesión para comentar.


Felix
Felix el 6 de Dic. de 2013
Editada: Felix el 6 de Dic. de 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....)

Categorías

Más información sobre Graph and Network Algorithms en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by