inst/examples/test_LOQ.R

library(dMod)
library(dplyr)

setwd(tempdir())

# Define Model and error model
x <- eqnvec(A = "k*A - exp(-time)") %>% odemodel(modelname = "testBLOQ") %>% Xs()
e <- eqnvec(A = "sigma_rel * A") %>% Y(x, attach.input = FALSE, modelname = "errmodel", compile = TRUE)

innerpars <- getParameters(x, e)
times <- seq(0, 15, .1)
p <- eqnvec() %>%
  define("pars~pars", pars = innerpars) %>% 
  define("pars~exp(pars)", pars = innerpars) %>% 
  P(condition = "C1")

# Simulate data
timesD <- 1:15
parsD <- c(A = 0, k = -2, sigma_rel = 0)
data <- (x*p)(timesD, parsD) %>% 
  as.data.frame() %>% 
  mutate(sigma = pmax(0.1*value, 0.1), 
         value = rnorm(length(value), value, sigma),
         lloq = 0.3) %>% 
  as.datalist()
plot(data)

## Test for fixed sigma ----

# Test case 1: no value BLOQ
data <- data %>% as.data.frame() %>% mutate(lloq = -1) %>% as.datalist()
plotData(data)
obj <- normL2(data, x*p)
parsT <- c(A = 0, k = -5, sigma_rel = 0)
obj(parsT)$grad
numDeriv::grad(function(x) obj(x)$value, parsT)

# Test case 2: all values BLOQ
data <- data %>% as.data.frame() %>% mutate(lloq = 2) %>% as.datalist()
plotData(data)
obj <- normL2(data, x*p)
parsT <- c(A = 0, k = -5, sigma_rel = 0)
obj(parsT)$grad
numDeriv::grad(function(x) obj(x)$value, parsT)

# Test case 3: some values BLOQ
data <- data %>% as.data.frame() %>% mutate(lloq = 0.3) %>% as.datalist()
plotData(data)
obj <- normL2(data, x*p)
parsT <- c(A = 0, k = -5, sigma_rel = 0)
obj(parsT)$grad
numDeriv::grad(function(x) obj(x)$value, parsT)

## Test for variable sigma ----

# Test case 1: no value BLOQ
data <- data %>% as.data.frame() %>% mutate(lloq = -1) %>% as.datalist()
plotData(data)
obj <- normL2(data, x*p, e)
parsT <- c(A = 0, k = -5, sigma_rel = 0)
obj(parsT)$grad
numDeriv::grad(function(x) obj(x)$value, parsT)

# Test case 2: all values BLOQ
data <- data %>% as.data.frame() %>% mutate(lloq = 2) %>% as.datalist()
plotData(data)
obj <- normL2(data, x*p, e)
parsT <- c(A = 0, k = -5, sigma_rel = 0)
obj(parsT)$grad
numDeriv::grad(function(x) obj(x)$value, parsT)

# Test case 3: some values BLOQ
data <- data %>% as.data.frame() %>% mutate(lloq = 0.5) %>% as.datalist()
plotData(data)
obj <- normL2(data, x*p, e)
parsT <- c(A = 0, k = -5, sigma_rel = 0)
obj(parsT)$grad
numDeriv::grad(function(x) obj(x)$value, parsT)




## Fit and plot ----
data_cens <- data %>% 
  as.data.frame() %>%
  filter(value > lloq) %>% 
  as.datalist()

obj <- normL2(data, x*p, e)
obj_cens <- normL2(data_cens, x*p, e)

parsT <- c(A = 2, k = 2, sigma_rel = 0)
myfit <- trust(obj, parsT, rinit = .1, rmax = 10)
myfit_cens <- trust(obj_cens, parsT, rinit = .1, rmax = 10)

(x*p)(times, myfit$argument) %>% plot(data)
(x*p)(times, myfit_cens$argument) %>% plot(data_cens)

Try the dMod package in your browser

Any scripts or data that you put into this service are public.

dMod documentation built on Jan. 27, 2021, 1:07 a.m.