R/implies.R

Defines functions implies

Documented in implies

#' #' Logical implies
#' @description Returns the result of \eqn{x\Longrightarrow y}.
#' @param x,y Logical vectors of the same length.
#' @return Logical implies: \code{TRUE} unless \code{x} is \code{TRUE} and \code{y} is \code{FALSE}.
#' 
#' \code{NA} in either \code{x} or \code{y} results in \code{NA} if and only if the result is unknown.
#' In particular \code{NA \%implies\% TRUE} is \code{TRUE} and \code{FALSE \%implies\% NA} is \code{TRUE}.
#' 
#' If \code{x} or \code{y} are length-one, the function proceeds as if the length-one vector were recycled
#' to the length of the other. 
#' 
#' 
#' 
#' @export %implies% implies
#' 
#' @examples  
#' library(data.table)
#' CJ(x = c(TRUE,
#'          FALSE),
#'    y = c(TRUE,
#'          FALSE))[, ` x => y` := x %implies% y][]
#'
#' #>        x     y  x => y
#' #> 1: FALSE FALSE    TRUE
#' #> 2: FALSE  TRUE    TRUE
#' #> 3:  TRUE FALSE   FALSE
#' #> 4:  TRUE  TRUE    TRUE
#' 
#' # NA results:
#' #> 5:    NA    NA      NA
#' #> 6:    NA FALSE      NA
#' #> 7:    NA  TRUE    TRUE
#' #> 8: FALSE    NA    TRUE
#' #> 9:  TRUE    NA      NA


implies <- function(x, y) {
  lx <- length(x)
  ly <- length(y)
  
  if (lx != ly) {
    if (NOR(lx == 1L, ly == 1L)) {
      dx <- deparse(substitute(x))
      dy <- deparse(substitute(y))
      stop('`', dx, "` and `", dy, "` had unequal lengths ",
           "(length(x) = ", lx, "; ",
           "length(y) = ", ly, ").",
           "\n",
           "`x` and `y` must be the same length.")
    } else {
      if (ly == 1L) {
        y <- as.logical(y)
        if (is.na(y)) {
          y <- rep_len(NA, lx)
        } else if (y) {
          return(rep_len(TRUE, lx))
        } else {
          return(!x)
        }
      } else {
        # lx must be 1L
        x <- as.logical(x)
        if (is.na(x)) {
          out <- y
          out[!y] <- NA
          return(out)
        } else  if (x) {
          return(y)
        } else {
          return(rep_len(TRUE, ly)) 
        }
      }
    }
  }
  
  x <- as.logical(x)
  y <- as.logical(y)
  
  out <- y
  out[!coalesce(x, y)] <- TRUE
  if (anyNA(y)) {
    out[is.na(x) & coalesce(!y, TRUE)] <- NA
  }
  out
}

#' @rdname implies
`%implies%` <- implies

Try the hutils package in your browser

Any scripts or data that you put into this service are public.

hutils documentation built on April 13, 2022, 5:23 p.m.