I am trying to implement a very simple preferential binding algorithm for creating networks without scale. They have power distributions that follow a power law, that is, P (k) ~ k ^ -g, where g is an exponent. The algorithm below should provide a degree distribution with an indicator equal to 3 +/- 0.1, my implementation does not show indicators closer to 2.5 +/- 0.1. I clearly donโt understand something somewhere and continue to make mistakes.
Sorry if this is in the wrong place, I could not decide if it should be in stackoverflow or maths.stackexchange.com.
The Algorithm: Input: Number of Nodes N; Minimum degree d >= 1. Output: scale-free multigraph G = ({0,....,N-1}, E) M: array of length 2Nd for (v=0,...,n-1) for (i=0,...,d-1) M[2(vd+i)] = v; r = random number selected uniformly at random from {0,.....,2(vd+i)}; M[2(vd+i)+1] = M[r]; end end E = {}; for (i=0,...,nd-1) E[i] = {M[2i], M[2i+1]} end
My implementation in C / C ++:
void SF_LCD(std::vector< std::vector<int> >& graph, int N, int d) { if(d < 1 || d > N - 1) { std::cerr << "Error: SF_LCD: k_min is out of bounds: " << d; } std::vector<int> M; M.resize(2 * N * d); int r = -1;
Here is an example of a degree distribution i for N = 10000 and d = 1:
1 6674 2 1657 3 623 4 350 5 199 6 131 7 79 8 53 9 57 10 27 11 17 12 20 13 15 14 12 15 5 16 8 17 5 18 10 19 7 20 6 21 5 22 6 23 4 25 4 26 2 27 1 28 6 30 2 31 1 33 1 36 2 37 2 43 1 47 1 56 1 60 1 63 1 64 1 67 1 70 1 273 1
source share