summaryrefslogtreecommitdiffstats
path: root/R Scripts/analyze-cascades.R
diff options
context:
space:
mode:
Diffstat (limited to 'R Scripts/analyze-cascades.R')
-rwxr-xr-xR Scripts/analyze-cascades.R32
1 files changed, 22 insertions, 10 deletions
diff --git a/R Scripts/analyze-cascades.R b/R Scripts/analyze-cascades.R
index 60c59fb..04cb0e3 100755
--- a/R Scripts/analyze-cascades.R
+++ b/R Scripts/analyze-cascades.R
@@ -1,15 +1,25 @@
library(igraph)
+library(RColorBrewer)
+library(poweRlaw)
setwd("~/Documents/Violence Cascades/")
start_date = as.Date("2005-12-31")
# plot cascade sizes
data = read.csv('Results/components_dist-91515.csv',header=F)
data = data[order(data$V1),]
-sizes = data$V1
-counts = data$V2
-plot(sizes,counts,log='xy',type='o',lwd=3,
- xlab='Size of Cascade', ylab='Number of Cascades', main='Distribution of Cascade Sizes')
+sizes = 1:max(data$V1)
+counts = rep(0,max(sizes))
+counts[data$V1] = data$V2
+pl = power.law.fit(counts)
+plot(sizes,counts,log='xy',pch=20,col='#377EB8',
+ xlab='Size of Cascade', ylab='Number of Cascades', main='')
+lines(c(1,1))
+sizes_pl = displ$new(counts[counts>1])
+est = estimate_xmin(sizes_pl)
+sizes_pl$setXmin(est)
+plot(sizes_pl)
+lines(sizes_pl, col=2)
# plot cascades
edges = read.csv('Results/edges-91515.csv',header=F,
@@ -24,18 +34,20 @@ membership = clusters$membership
csize = clusters$csize
order = rev(order(csize))
-i = 95
+i = 25
V = which(clusters(dag)$membership==order[i]) # get all nodes in cluster
cc = induced.subgraph(dag,V)
times = as.numeric(V(cc)$name) %% 10000
start_date + range(times)
### plot cascade ###
-cols = rep('lightblue',vcount(cc))
+cb = brewer.pal(3,'Paired')
+cols = rep('#1f78b4',vcount(cc))
seed = which(degree(cc,mode='in')==0)
-cols[seed] = 'red'
-plot(cc,vertex.size=5,edge.arrow.size=0.2,vertex.color=cols,vertex.label=NA,
- layout=layout.reingold.tilford(cc,root=seed))
+cols[seed] = '#d95f02'
+plot(cc,vertex.size=8,edge.arrow.size=0.2,vertex.color=cols,vertex.label=NA,
+ layout=layout.reingold.tilford(cc,root=seed),
+ edge.color='black',vertex.frame.color=NA)
-par(mfrow = c(2,3))
+par(mfrow = c(1,3))