#' Simulate one phase exponential decay data
#'
#' A sandbox to simulate and visualize random normal data
#' for a nonlinear decaying response. The data generating formula
#' is derived from the general model: "y = y0*e^-kx". This model
#' simulates response systems where the rate at which the response
#' decreases is proportional to the level of remaining response.
#' Failure errors can happen in the plot fitting subfunction even though random
#' data is produced. These may be more frequent with higher sd values and/or
#' lower range or replicates. Just re-simulate with modified parameter values.
#' The regression formula is: `y ~ (yhi-ylo)*exp(-1*k*x) + ylo`
#'
#' @param x a vector of non-exponential linear scale values representing time.
#' @param k the rate constant, expressed in reciprocal of the X axis time units.
#' The half-life is 0.6932/k.
#' @param ylo the lowest expected y value, or the value at infinite times,
#' expressed in the same units as Y.
#' @param yhi the highest expected y value, or the starting value,
#' expressed in the same units as Y.
#' @param sd the standard deviation in y.
#' @param reps an integer value for number of replicates
#'
#' @return ggplot, data
#' @export
#'
#' @examples
#'
#' # Note: exponential or log-transformed x scale values will not work
#' # do not use x = c(1e-9, 3e-9, ...) or c(-9, -8.523, ...)
#'
#' time <- c(1, 5, 10, 15, 20, 25) # eg, in mins
#'
#' set.seed(2345)
#'
#' decayOnedat <- simdecay1(time, k=0.15, ylo=1, yhi=100, sd = 10, reps=5)
#'
#'
#' decayOnedat$data
#'
#'
simdecay1 <- function(x, k, ylo, yhi, sd, reps) {
values <- data.frame(x=rep(x, reps))
y <- c()
values <- dplyr::mutate(values, y = (yhi-ylo)*exp(-1*k*x) + ylo +
stats::rnorm(length(x), 0, sd))
ggplot2::ggplot(values,
ggplot2::aes(x, y)) +
ggplot2::geom_point(size=2) +
ggplot2::labs(title="model: y=(yhi-ylo)*exp(-kx) + ylo") +
ggplot2::geom_smooth(
method=minpack.lm::nlsLM,
formula = "y ~(yhi-ylo)*exp(-1*k*x) + ylo",
method.args = list(start=c(yhi=yhi, ylo = ylo, k=k)), se=F, color="blue")
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.