
library(devtools)
install_github("allenkei/CPDstergm")
library(CPDstergm)
source("EVAL.R") # FILE DIRECTORY

load("STERGM_seq10T100n100p6.RData") # DATA DIRECTORY
result_n100p6 <- matrix(0, nrow=7, ncol=4)


network_stats=c("edges", "mutual")
sim_result1 <- CPD_STERGM_list(STERGM_seq10T100n100p6, directed=TRUE, network_stats)
result_n100p6[1,] <- colMeans(sim_result1)


network_stats=c("edges", "mutual", "triangles")
sim_result2 <- CPD_STERGM_list(STERGM_seq10T100n100p6, directed=TRUE, network_stats)
result_n100p6[2,] <- colMeans(sim_result2)


sim_result3 <- Evaluation_gSeg(STERGM_seq10T100n100p6, p_threshold=0.05)
result_n100p6[3,] <- colMeans(sim_result3)


sim_result4 <- Evaluation_kerSeg(STERGM_seq10T100n100p6, p_threshold=0.001)
result_n100p6[4,] <- colMeans(sim_result4)


sim_result5 <- Evaluation_gSeg_on_stats(STERGM_seq10T100n100p6, p_threshold=0.05, num_stats=3)
result_n100p6[5,] <- colMeans(sim_result5)


sim_result6 <- Evaluation_kerSeg_on_stats(STERGM_seq10T100n100p6, p_threshold=0.001, num_stats=3)
result_n100p6[6,] <- colMeans(sim_result6)


sim_result7 <- Evaluation_RDPG(STERGM_seq10T100n100p6, M=50, d=5, delta=5)
result_n100p6[7,] <- colMeans(sim_result7)


write.csv(result_n100p6, 'result_n100p6.csv')


# print result
apply(sim_result1, 2, mean)
apply(sim_result1, 2, sd) * sqrt(9/10)

apply(sim_result2, 2, mean)
apply(sim_result2, 2, sd) * sqrt(9/10)

apply(sim_result3, 2, mean)
apply(sim_result3, 2, sd) * sqrt(9/10)

apply(sim_result4, 2, mean)
apply(sim_result4, 2, sd) * sqrt(9/10)

apply(sim_result5, 2, mean)
apply(sim_result5, 2, sd) * sqrt(9/10)

apply(sim_result6, 2, mean)
apply(sim_result6, 2, sd) * sqrt(9/10)

apply(sim_result7, 2, mean)
apply(sim_result7, 2, sd) * sqrt(9/10)


# visualization (9 by 6 inches)

par(mfrow=c(2,3))

for(i in c(25,50,75, 26,51,76)){
  par(mar = c(2.2, 2.2, 2.2, 2.2)); 
  image(STERGM_seq10T100n100p6[[1]][[i]], xaxt = "n", yaxt = "n")
  axis(side=1,at=seq(0,1,length.out = 4),labels=round(seq(1,100,length.out = 4)),xpd=NA,cex.axis=1.4)
  axis(side=2,at=seq(0,1,length.out = 4),labels=round(seq(1,100,length.out = 4)),xpd=NA,cex.axis=1.4)
}
