annotate toolboxes/FullBNT-1.0.7/graph/assignEdgeNums.m @ 0:cc4b1211e677 tip

initial commit to HG from Changeset: 646 (e263d8a21543) added further path and more save "camirversion.m"
author Daniel Wolff
date Fri, 19 Aug 2016 13:07:06 +0200
parents
children
rev   line source
Daniel@0 1 function [edge_id, nedges] = assignEdgeNums(adj_mat)
Daniel@0 2 % give each edge a unique number
Daniel@0 3 % we number (i,j) for j>i first, in row, column order.
Daniel@0 4 % Then we number the reverse links
Daniel@0 5
Daniel@0 6 nnodes = length(adj_mat);
Daniel@0 7 edge_id = zeros(nnodes);
Daniel@0 8 e = 1;
Daniel@0 9 for i=1:nnodes
Daniel@0 10 for j=i+1:nnodes
Daniel@0 11 if adj_mat(i,j)
Daniel@0 12 edge_id(i,j) = e;
Daniel@0 13 e = e+1;
Daniel@0 14 end
Daniel@0 15 end
Daniel@0 16 end
Daniel@0 17
Daniel@0 18 nedges = e-1;
Daniel@0 19 tmp = edge_id;
Daniel@0 20 ndx = find(tmp);
Daniel@0 21 tmp(ndx) = tmp(ndx)+nedges;
Daniel@0 22 edge_id = edge_id + triu(tmp)';
Daniel@0 23
Daniel@0 24
Daniel@0 25 if 0
Daniel@0 26 ndx = find(adj_mat);
Daniel@0 27 nedges = length(ndx);
Daniel@0 28 nnodes = length(adj_mat);
Daniel@0 29 edge_id = zeros(1, nnodes*nnodes);
Daniel@0 30 edge_id(ndx) = 1:nedges;
Daniel@0 31 edge_id = reshape(edge_id, nnodes, nnodes);
Daniel@0 32 end