How to create random graph?
    42 views (last 30 days)
  
       Show older comments
    
    Deepthi B
 on 10 May 2021
  
    
    
    
    
    Commented: Christine Tobler
    
 on 20 Dec 2021
            Hi ,
I want to check whether the network that I have obtained is a small world network or not. For that I have to find out the clustering coefficient and shortest path length of a random network with the same number of nodes and links in my network. Is it possible to find out?
0 Comments
Accepted Answer
  Christine Tobler
    
 on 10 May 2021
        You can use
s = randi(n, e, 1);
t = randi(n, e, 1);
G = graph(s, t, [], n);
which will give you a graph with n nodes and e edges. Note that G may have multiple edges connecting the same two nodes, and may also have self-loops (edges connecting a node to itself). If you don't want repeating edges, use the following instead:
G = graph(true(n)); % Self-loops are possible
%G = graph(true(n), 'omitselfloops'); % Alternative without self-loops
p = randperm(numedges(G), e);
G = graph(G.Edges(p, :));
5 Comments
  Norbert Cyran
 on 19 Dec 2021
				Why are you generating true matrix for nodes and random values for edges??
  Christine Tobler
    
 on 20 Dec 2021
				Hi Norbert,
The true(n) matrix is an adjacency matrix that contains all possible edges in the graph (omitting self-loops or not depending if that option is used or not). Then, I'm choosing a random subset of those edges using the randperm function.
More Answers (1)
See Also
Categories
				Find more on Graph and Network Algorithms in Help Center and File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


