URStat218.Rcheck/00_pkg_src/URStat218/R/218OddsRatio.R

#' Odds Ratio
#'
#' Calculates the odds ratios for an inputted 2 x 2 table
#'
#' @param tab A 2 x 2 contingency table passed through \code{table()}.
#' @param conf.level The confidence level you are testing at. Defaults to 95\%
#' @return Returns the odds ratio test statistic, theta, the confidence level
#'     of the interval, and the confidence interval itself.
#' @export
#' @examples


odds <- function(tab, conf.level=0.95){
  n11 <- tab[1,1]
  n12 <- tab[1,2]
  n21 <- tab[2,1]
  n22 <- tab[2,2]

  theta <- (n11*n22)/(n12*n21)

  alpha <- 1-conf.level
  z <- abs(qnorm(alpha/2))

  lower <- exp(log(theta)-z*sqrt(1/n11+1/n12+1/n21+1/n22))
  upper <- exp(log(theta)+z*sqrt(1/n11+1/n12+1/n21+1/n22))

  return(cat("Odds Ratio: ",round(theta,5), "\n",conf.level*100,
             "% Confidence Interval:", "(",round(lower,5),",", round(upper,5),")", sep=""))
}
ESunRoc/STT218 documentation built on Jan. 14, 2020, 2:39 a.m.