order_conditionals <- function(conditional) {
  # remove parentheses
  conditional <- gsub("\\(|\\)", "", conditional)
  marginal_and_conditional <- strsplit(conditional, "\\|")[[1]]
  marginal <- marginal_and_conditional[1]
  conditionals <- strsplit(marginal_and_conditional[2], ",")[[1]]
  # Sort conditionals
  conditionals <- sort(conditionals)
  # Concatenate conditionals
  conditional <- paste(conditionals, collapse = ",")
  return(paste0("(", marginal, "|", conditional, ")"))

}

order_formula <- function(formula) {
  split <- strsplit(formula, "P")[[1]][-1]
  new_set <- c()
  for(factor in split) {
    if (grepl("\\|", factor)) {
      new_set <- c(new_set, order_conditionals(factor))
    } else {
      new_set <- c(new_set, factor)
    }
  }
  new_set <- sort(new_set)
  return(paste0("P", paste(new_set, collapse = "P")))
}

are_equal_formulas <- function(formula1, formula2) {
  ordered_formula1 <- order_formula(formula1)
  ordered_formula2 <- order_formula(formula2)
  return(ordered_formula1 == ordered_formula2)
}