library(tidyverse)
bike <- read_csv("R/experiments/bikerental/day.csv")
# Difference in days, which takes DST into account
bike$trend <- as.numeric(difftime(bike$dteday, bike$dteday[1], units = "days"))
# bike$trend <- as.integer(difftime(bike$dteday, min(as.Date(bike$dteday)))+1)/24
bike$cosyear <- cospi(bike$trend/365*2)
bike$sinyear <- sinpi(bike$trend/365*2)
# Unnormalize variables (see data set information in link above)
bike$temp <- bike$temp * (39 - (-8)) + (-8)
bike$atemp <- bike$atemp * (50 - (-16)) + (-16)
bike$windspeed <- 67 * bike$windspeed
bike$hum <- 100 * bike$hum

# Remove other columns
bike <- bike %>%
  select(trend, cosyear, sinyear, temp, atemp, windspeed, hum, cnt)

# Write preprocessed data to file
bike <- bike %>%
  select(trend, cosyear, sinyear, temp, atemp, windspeed, hum)

train_index <- readRDS("R/experiments/bikerental/train_index.rds")

# Training data
x_train <- bike[train_index, ]

write_delim(x_train, "R/experiments/bikerental/day_preprocessed.csv", delim = ";")

# Background knowledge for tetrad
bg_knowledge <- "
/knowledge

addtemporal
1 trend
2 cosyear sinyear
3 temp windspeed hum atemp

forbiddirect


requiredirect
"


# Write bg knowledge to files
file_conn <- file("R/experiments/bikerental/background_knowledge.txt", open = "w")
writeLines(bg_knowledge, "R/experiments/bikerental/background_knowledge.txt")
close(file_conn)

# Tetrad calls
# java -jar causal-cmd-1.12.0-jar-with-dependencies.jar --data-type continuous --dataset day_preprocessed.csv --delimiter semicolon --knowledge background_knowledge.txt --algorithm fges --score sem-bic-score --prefix fges_sem_bic
# java -jar causal-cmd-1.12.0-jar-with-dependencies.jar --data-type continuous --dataset day_preprocessed.csv --delimiter semicolon --knowledge background_knowledge.txt --algorithm pc --test fisher-z-test --prefix pc_z


source('R/experiments/alzheimers/tetrad_parser.R')
node_names <- c("trend", "cosyear", "sinyear", "temp", "atemp", "windspeed", "hum")
cpdag_fges <- parse_tetrad_output("R/experiments/bikerental/fges_sem_bic_out.txt", node_names)
mec_fges <- parse_to_mec("R/experiments/bikerental/fges_sem_bic_out.txt", node_names)
saveRDS(mec_fges, "R/experiments/bikerental/mec_fges.rds")

cpdag_pc <- parse_tetrad_output("R/experiments/bikerental/pc_z_out.txt", node_names)
mec_pc <- parse_to_mec("R/experiments/bikerental/pc_z_out.txt", node_names)
saveRDS(mec_pc, "R/experiments/bikerental/mec_pc.rds")