## Applies log-transformation as established in the Marron paper:
log_transform <- function(x) {
  
  .values <- !is.na(x)
  .sign <- sign(skewness(x[.values]))
  .min <- min(.sign * x[.values])
  .xpos <- (.sign * x[.values]) - .min
  
  ## Find the appropiate shifting:
  .shifts <- 10^(seq(-1, 4, length.out = 50))
  .shiftSkewness <- sapply(
    .shifts, 
    function(shift) {
      log(.xpos + shift) %>%
        skewness()
    })
  .minI = which.min(abs(.shiftSkewness))
  .shift = .shifts[.minI]
  
  .y <- ifelse(is.na(x), NA, .sign * log(.sign * x - .min + .shift))
  return(.y)
}

## Function that determines if there is skewness in a variable.
is_skewed <- function(x) {
  
  if(!is.numeric(x)) return(FALSE)
  
  x[!is.na(x)] %>% 
    skewness() %>%
    {abs(.) > 1} %>%
    return()
}

## Function that determines if there is skewness in a variable.
is_notskewed <- function(x) {
  
  if(!is.numeric(x)) return(TRUE)
  
  x[!is.na(x)] %>% 
    skewness() %>%
    {abs(.) <= 1} %>%
    return()
}
