Я хотел бы знать, может ли быть правильным вывод скрипта для построения графика распределения степеней.
Итак, скрипт (где вектор со степенями всех моих вершин хранится в x):
x is
x
[1] 7 9 8 5 6 2 8 9 7 5 2 4 6 9 2 6 10 8
x - степень определенной вершины сети - например, вершина 1 имеет степень 7, вершина 2 имеет степень 9 и т. д. x ‹- v2 summary(x)
library(igraph)
split.screen(c(1,2))
screen(1)
plot (tabulate(x), log = "xy", ylab = "Frequency (log scale)", xlab = "Degree (log scale)", main = "Log-log plot of degree distribution")
screen(2)
y <- (length(x) - rank(x, ties.method = "first"))/length(x)
plot(x, y, log = "xy", ylab = "Fraction with min. degree k (log scale)", xlab = "Degree (k) (log scale)", main = "Cumulative log-log plot of degree distribution")
close.screen(all = TRUE)
power.law.fit(x, xmin = 50)
Моя проблема в том, что логарифмический график кажется неверным - например, у меня есть степень «7» в целом 8 раз, поэтому не должна ли эта точка на логарифмическом графике стать 0,845 (логарифм 7)/0,903 (лог( 8) как в (х/у)?
Более того, может ли кто-нибудь сказать мне, как подогнать линию (степенной закон в логарифмической шкале) к графику на экране 2?