R/simdecay1.R

Defines functions simdecay1

Documented in simdecay1

#' 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")
  }
TJMurphy/nlfitr documentation built on March 18, 2021, 12:33 p.m.