source('R/experiments/alzheimers/prepare_data.R')

# Create file with trivial background knowledge for APOE41 and APOE42
background_knowledge_apoe4142 <- "/knowledge

addtemporal
1 AGE EDU SEX
2 APOE41 APOE42 ABETA FDG PTAU

forbiddirect
AGE EDU
EDU AGE
AGE SEX
SEX AGE
EDU SEX
SEX EDU
APOE41 APOE42
APOE42 APOE41
"

# write to file
if (!file.exists("R/experiments/alzheimers/background_knowledge_apoe4142.txt")) {
  file.create("R/experiments/alzheimers/background_knowledge_apoe4142.txt")
}
file_conn <- file("R/experiments/alzheimers/background_knowledge_apoe4142.txt", open = "w")
writeLines(background_knowledge_apoe4142, "R/experiments/alzheimers/background_knowledge_apoe4142.txt")
close(file_conn)


# Run Tetrad using command line
# java -jar causal-cmd-1.12.0-jar-with-dependencies.jar --data-type discrete --dataset tibble_discretized_apoe4142.csv --delimiter semicolon --knowledge background_knowledge_apoe4142.txt --algorithm fges  --score disc-bic-score --prefix fges_apoe4142
# java -jar causal-cmd-1.12.0-jar-with-dependencies.jar --data-type discrete --dataset tibble_discretized_apoe4142.csv --delimiter semicolon  --knowledge background_knowledge_apoe4142.txt --algorithm pc  --test g-square-test --prefix pc_g_apoe4142 --alpha 0.05

# Convert output to mecs
source('R/experiments/alzheimers/prepare_data.R')
source('R/experiments/alzheimers/tetrad_parser.R')

# Get vertex names
data <- read_delim('R/experiments/alzheimers/tibble_discretized_apoe4142.csv', delim = ';')
vertex_names_apoe4142 <- colnames(data)


base_dir <- 'R/experiments/alzheimers/'

mec_fges_apoe4142 <- parse_to_mec(paste0(base_dir, 'fges_apoe4142_out.txt'), vertex_names_apoe4142)
mec_pc_g_apoe4142 <- parse_to_mec(paste0(base_dir, 'pc_g_apoe4142_out.txt'), vertex_names_apoe4142)

# Save MECs
saveRDS(mec_fges_apoe4142, 'R/experiments/alzheimers/mec_fges_apoe4142.rds')
saveRDS(mec_pc_g_apoe4142, 'R/experiments/alzheimers/mec_pc_g_apoe4142.rds')

