library(argparse)
library(ggplot2)
library(dplyr)
library(tidyr)
library(gridExtra)
library(grid)
library(ggthemes)
library(scales)

# Create data frame with means and standard deviations
# Replace these values with your actual data
data <- data.frame(
  signal = rep(c("ρ(b,S)", "ρ(b,A)", "ρ(b,Y)"), each = 2),
  setup = rep(c("Setup1", "Setup2"), times = 3),
  # selection: 0.1 0.1 0.1 0.9
  # mean = c(
  #   # S values
  #   -0.07, 0.02,  # Replace with your means
  #   # A values
  #   0.11, 0.02,
  #   # Y values
  #   0.22, 0.27
  # ),
  # sd = c(
  #   # S values
  #   0.04, 0.01,  # Replace with your standard deviations
  #   # A values
  #   0.07, 0.02,
  #   # Y values
  #   0.06, 0.06
  # )
  
  mean = c(
    # S values
    0.04, 0.02,  # Replace with your means
    # A values
    -0.06, 0.03,
    # Y values
    0.17, 0.18
  ),
  sd = c(
    # S values
    0.03, 0.02,  # Replace with your standard deviations
    # A values
    0.04, 0.02,
    # Y values
    0.06, 0.08
  )
  
  # selection: 0.9 0.9 0.5 0.1
  # mean = c(
  #   # S values
  #   0.07, 0.02,  # Replace with your means
  #   # A values
  #   -0.044, 0.02,
  #   # Y values
  #   0.25, 0.27
  # ),
  # sd = c(
  #   # S values
  #   0.04, 0.01,  # Replace with your standard deviations
  #   # A values
  #   0.028, 0.02,
  #   # Y values
  #   0.07, 0.06
  # )
  # mean = c(
  #   # S values
  #   0.06, 0.02,  # Replace with your means
  #   # A values
  #   -0.05, 0.02,
  #   # Y values
  #   0.24, 0.27
  # ),
  # sd = c(
  #   # S values
  #   0.04, 0.01,  # Replace with your standard deviations
  #   # A values
  #   0.03, 0.02,
  #   # Y values
  #   0.07, 0.06
  # )
)

# signal for SE_S_r: 0.056390503243205874 +/- 0.023685766844960467
# signal for SE_A_r: -0.05979717403911048 +/- 0.05148676446003414
# signal for SE_Y1_r: 0.20865908047304593 +/- 0.08470972302934027

# Calculate confidence intervals (1.96 * sd for 95% CI)
data$lower <- data$mean - data$sd
data$upper <- data$mean + data$sd

# Define the custom theme and scale functions
theme_Publication <- function(base_size=14, base_family="sans") {
  (theme_foundation(base_size=base_size, base_family=base_family)
   + theme(plot.title = element_text(face = "bold",
                                     size = rel(1.2), hjust = 0.5),
           text = element_text(),
           panel.background = element_rect(colour = NA),
           plot.background = element_rect(colour = NA),
           panel.border = element_rect(colour = NA),
           axis.title = element_text(face = "bold",size = rel(1)),
           axis.title.y = element_text(angle=90,vjust =2),
           axis.title.x = element_text(vjust = -0.2),
           axis.text = element_text(), 
           axis.line = element_line(colour="black"),
           axis.ticks = element_line(),
           panel.grid.major = element_line(colour="#f0f0f0"),
           panel.grid.minor = element_blank(),
           legend.key = element_rect(colour = NA),
           legend.position = "bottom",
           legend.direction = "horizontal",
           legend.key.size= unit(0.2, "cm"),
           legend.spacing = unit(0, "cm"),
           legend.title = element_text(face="italic"),
           plot.margin=unit(c(10,5,5,5),"mm"),
           strip.background=element_rect(colour="#f0f0f0",fill="#f0f0f0"),
           strip.text = element_text(face="bold")
   ))
}

scale_fill_Publication <- function(...){
  discrete_scale("fill","Publication",manual_pal(values = c("#0f7ba2","#7fc97f","#dd5129")), ...)
  
}

data$signal <- factor(data$signal, 
                      levels = c("ρ(b,S)", "ρ(b,A)", "ρ(b,Y)"))

# Create the plot
p <- ggplot(data, aes(x = signal, y = mean, fill = setup)) +
  geom_bar(stat = "identity", position = position_dodge(width = 0.8), width = 0.7) +
  geom_errorbar(aes(ymin = lower, ymax = upper),
                position = position_dodge(width = 0.8),
                width = 0.25,
                size = 1.) +
  labs(x = "",
       y = "",
       fill = "Setup") +
  scale_y_continuous(limits = c(-0.15, 0.4)) +
  theme_Publication() +
  scale_fill_Publication() +
  theme(
    plot.title = element_text(size = 25, face = "bold"),
    axis.text = element_text(size = 22),
    axis.title = element_text(size = 24, face = "bold"),
    legend.title = element_text(size = 22),
    legend.text = element_text(size = 21),
    legend.key.size = unit(1, "cm")
  )

# Display the plot
print(p)

# Save the plot if needed
# ggsave("barplot.png", p, width = 12, height = 8, dpi = 300)