spsanderson / TidyDensity

Create tidy probability/density tibbles and plots of randomly generated and empirical data.
https://www.spsanderson.com/TidyDensity
Other
34 stars 1 forks source link

gamma #136

Closed spsanderson closed 2 years ago

spsanderson commented 2 years ago

https://www.itl.nist.gov/div898/handbook/eda/section3/eda366b.htm

spsanderson commented 2 years ago

Function:

#' Distribution Statistics
#' 
#' @family Gamma
#' @fmaily Distribution Statistics
#' 
#' @author Steven P. Sanderson II, MPH
#' 
#' @details This function will take in a tibble and returns the statistics
#' of the given type of `tidy_` distribution. It is required that data be
#' passed from a `tidy_` distribution function.
#' 
#' @description Returns distribution statistics in a tibble.
#' 
#' @param .data The data being passed from a `tidy_` distribution function.
#' 
#' @examples 
#' tidy_gammal() %>%
#'   util_gamma_stats_tbl()
#' 
#' @return 
#' A tibble
#' 
#' @export
#' 

util_gamma_stats_tbl <- function(.data){

  # Immediate check for tidy_ distribution function
  if (!"tibble_type" %in% names(attributes(.data))){
    rlang::abort(
      message = "You must pass data from the 'tidy_dist' function.",
      use_cli_format = TRUE
    )
  }

  if (attributes(.data)$tibble_type != "tidy_gamma"){
    rlang::abort(
      message = "You must use 'tidy_gamma()'",
      use_cli_format = TRUE
    )
  }

  # Data
  data_tbl <- tibble::as_tibble(.data)

  atb <- attributes(data_tbl)

  stat_mean   <- atb$.shape # location
  stat_mode   <- ifelse(stat_mean >= 1, stat_mean - 1, "undefined")
  stat_sd     <- sqrt(stat_mean)
  stat_skewness <- 2/sqrt(stat_mean)
  stat_kurtosis <- 3 + (6/stat_mean)
  stat_coef_var <- 1/sqrt(stat_mean)

  # Data Tibble
  ret <- tibble::tibble(
    tidy_function = atb$tibble_type,
    function_call = atb$dist_with_params,
    distribution = atb$tibble_type %>% 
      stringr::str_remove("tidy_") %>% 
      stringr::str_to_title(),
    distribution_type = atb$distribution_family_type,
    points = atb$.n,
    simulations = atb$.num_sims,
    mean = stat_mean,
    mode = stat_mode,
    range = paste0("0 to Inf"),
    std_dv = stat_sd,
    coeff_var = stat_coef_var,
    skewness = stat_skewness,
    kurtosis = stat_kurtosis,
    computed_std_skew = tidy_skewness_vec(data_tbl$y),
    computed_std_kurt = tidy_kurtosis_vec(data_tbl$y)
  )

  # Return
  return(ret)

}

Examples:

tidy_gamma() %>%
  util_gamma_stats_tbl() %>%
  glimpse()

Rows: 1
Columns: 15
$ tidy_function     <chr> "tidy_gamma"
$ function_call     <chr> "Gamma c(2, 5)"
$ distribution      <chr> "Gamma"
$ distribution_type <chr> "continuous"
$ points            <dbl> 50
$ simulations       <dbl> 1
$ mean              <dbl> 2
$ mode              <dbl> 1
$ range             <chr> "0 to Inf"
$ std_dv            <dbl> 1.414214
$ coeff_var         <dbl> 0.7071068
$ skewness          <dbl> 1.414214
$ kurtosis          <dbl> 6
$ computed_std_skew <dbl> 1.470282
$ computed_std_kurt <dbl> 4.532772