Graph Laplacian and adjacency matrix
    12 views (last 30 days)
  
       Show older comments
    
Hi,
Does anyone know an afficient way to compute sparse adjacency matrix and Graph Laclcian directly from a data matrix ?
I saw there are function called 'adjacency'  and 'laplacian which get graph object and return the adjacency/graph laplacian matrix but i wonder if there are functions which calcute it directly over a data matrix? 
That means i have large data matrix Nxd (where N is the number of data point , let assue   50,000 and d is a sample dimention , assume d=100)
I would like that the adjacency matrix will return  NXN sparse matrix W which contain a measure of distance (euclidian/RBF or someting like that) between the data points (not all of them necesserly. lets assume that only to the 50 nearest neigbours so we get a sparse matrix). 
and the laplacian is L=D-W where D is diagonal matrix contains W cloums' sum. 
I tried to implement it by myself but i found it very  inefficient so i wondered if there id something built-in in Matlab ?
Thanks alot
1 Comment
Answers (2)
  Bruno Luong
      
      
 on 11 Jun 2021
        
      Edited: Bruno Luong
      
      
 on 11 Jun 2021
  
      Not sure what data format you have, but for graph
% TMW example
s = [1 2 2 3 3 3 4 5 5 5 8 8 9];
t = [2 3 4 1 4 5 5 3 6 7 9 10 10];
G = graph(s,t);
A = G.adjacency;
D = diag(sum(A)); % degree matrix
L = D - A; % laplacian matrix
disp(L)
0 Comments
  Christine Tobler
    
 on 11 Jun 2021
        Take a look at pdist in the Statistics and Machine Learning toolbox. If you apply this to your matrix, and then call squareform on the result, it should give you the W matrix you're looking for. There's a choice of different distance measures to choose from in pdist.  
0 Comments
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!


