-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
d5dd66d
commit 1cd6e45
Showing
63 changed files
with
667 additions
and
295 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
#' Tidy Randomly Generated Inverse Exponential Distribution Tibble | ||
#' | ||
#' @family Continuous Distribution | ||
#' @family Exponential | ||
#' | ||
#' @author Steven P. Sanderson II, MPH | ||
#' | ||
#' @seealso \url{https://openacttexts.github.io/Loss-Data-Analytics/C-SummaryDistributions.html} | ||
#' | ||
#' @details This function uses the underlying `actuar::rinvexp()`, and its underlying | ||
#' `p`, `d`, and `q` functions. For more information please see [actuar::rinvexp()] | ||
#' | ||
#' @description This function will generate `n` random points from an inverse exponential | ||
#' distribution with a user provided, `.rate` or `.scale` and number of | ||
#' random simulations to be produced. The function returns a tibble with the | ||
#' simulation number column the x column which corresponds to the n randomly | ||
#' generated points, the `d_`, `p_` and `q_` data points as well. | ||
#' | ||
#' The data is returned un-grouped. | ||
#' | ||
#' The columns that are output are: | ||
#' | ||
#' - `sim_number` The current simulation number. | ||
#' - `x` The current value of `n` for the current simulation. | ||
#' - `y` The randomly generated data point. | ||
#' - `dx` The `x` value from the [stats::density()] function. | ||
#' - `dy` The `y` value from the [stats::density()] function. | ||
#' - `p` The values from the resulting p_ function of the distribution family. | ||
#' - `q` The values from the resulting q_ function of the distribution family. | ||
#' | ||
#' @param .n The number of randomly generated points you want. | ||
#' @param .scale Must be strictly positive. | ||
#' @param .rate An alternative way to specify the `.scale` | ||
#' @param .num_sims The number of randomly generated simulations you want. | ||
#' | ||
#' @examples | ||
#' tidy_inverse_exponential() | ||
#' | ||
#' @return | ||
#' A tibble of randomly generated data. | ||
#' | ||
#' @export | ||
#' | ||
|
||
tidy_inverse_exponential <- function(.n = 50, .rate = 1, .scale = 1/.rate, .num_sims = 1) { | ||
|
||
# Tidyeval ---- | ||
n <- as.integer(.n) | ||
num_sims <- as.integer(.num_sims) | ||
rate <- as.numeric(.rate) | ||
scale <- as.numeric(.scale) | ||
|
||
# Checks ---- | ||
if (!is.integer(n) | n < 0) { | ||
rlang::abort( | ||
"The parameters '.n' must be of class integer. Please pass a whole | ||
number like 50 or 100. It must be greater than 0." | ||
) | ||
} | ||
|
||
if (!is.integer(num_sims) | num_sims < 0) { | ||
rlang::abort( | ||
"The parameter `.num_sims' must be of class integer. Please pass a | ||
whole number like 50 or 100. It must be greater than 0." | ||
) | ||
} | ||
|
||
if (!is.numeric(rate) | !is.numeric(scale)){ | ||
rlang::abort( | ||
"The parameters of rate and scale must be of calss numeric." | ||
) | ||
} | ||
|
||
if (rate <= 0 | scale <= 0){ | ||
rlang::abort( | ||
"The parameters of rate and scale must be strictly positive." | ||
) | ||
} | ||
|
||
x <- seq(1, num_sims, 1) | ||
|
||
ps <- seq(-n, n - 1, 2) | ||
qs <- seq(0, 1, (1 / (n - 1))) | ||
|
||
df <- dplyr::tibble(sim_number = as.factor(x)) %>% | ||
dplyr::group_by(sim_number) %>% | ||
dplyr::mutate(x = list(1:n)) %>% | ||
dplyr::mutate(y = list(actuar::rinvexp(n = n, rate = rate, scale = scale))) %>% | ||
dplyr::mutate(d = list(density(unlist(y), n = n)[c("x", "y")] %>% | ||
purrr::set_names("dx", "dy") %>% | ||
dplyr::as_tibble())) %>% | ||
dplyr::mutate(p = list(actuar::pinvexp(ps, rate = rate, scale = scale))) %>% | ||
dplyr::mutate(q = list(actuar::qinvexp(qs, rate = rate, scale = scale))) %>% | ||
tidyr::unnest(cols = c(x, y, d, p, q)) %>% | ||
dplyr::ungroup() | ||
|
||
|
||
# Attach descriptive attributes to tibble | ||
attr(df, ".rate") <- .rate | ||
attr(df, ".scale") <- .scale | ||
attr(df, ".n") <- .n | ||
attr(df, ".num_sims") <- .num_sims | ||
attr(df, "tibble_type") <- "tidy_inverse_exponential" | ||
attr(df, "ps") <- ps | ||
attr(df, "qs") <- qs | ||
|
||
# Return final result as function output | ||
return(df) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Binary file modified
BIN
+3.54 KB
(100%)
docs/articles/getting-started_files/figure-html/more_than_nine_simulations-1.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
-1.76 KB
(99%)
docs/articles/getting-started_files/figure-html/more_than_nine_simulations-4.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
-10.4 KB
(93%)
docs/articles/getting-started_files/figure-html/plot_density-1.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
-8.97 KB
(93%)
docs/articles/getting-started_files/figure-html/plot_density-4.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.