Title: | Tools for Performing Pharmacokinetic-Pharmacodynamic Simulations |
---|---|
Description: | Simulate dose regimens for pharmacokinetic-pharmacodynamic (PK-PD) models described by differential equation (DE) systems. Simulation using ADVAN-style analytical equations is also supported (Abuhelwa et al. (2015) <doi:10.1016/j.vascn.2015.03.004>). |
Authors: | Ron Keizer [aut, cre], Jasmine Hughes [aut], Dominic Tong [aut], Kara Woo [aut], Jordan Brooks [aut], InsightRX [cph, fnd] |
Maintainer: | Ron Keizer <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.4.0 |
Built: | 2025-01-19 06:49:37 UTC |
Source: | https://github.com/insightrx/pkpdsim |
Put vector values in quotes
add_quotes(x, quote = "double")
add_quotes(x, quote = "double")
x |
vector of string / numeric |
quote |
what type of quotes ( |
Character vector of input with quotation marks around each value
Add residual variability to the dependent variable
add_ruv(x, ruv = list(), obs_type = 1)
add_ruv(x, ruv = list(), obs_type = 1)
x |
dependent value without residual variability |
ruv |
list specifying proportional, additive and/or exponential errors ( |
obs_type |
vector of observation types |
Input vector with residual variability added
Calculate the increase in a specific quantile for a distribution on y when residual variability is added
add_ruv_to_quantile(y, sd_y, log_scale = FALSE, q = NULL, ruv = list(), ...)
add_ruv_to_quantile(y, sd_y, log_scale = FALSE, q = NULL, ruv = list(), ...)
y |
y with |
sd_y |
standard deviation of y without residual variability added. Will add normally distributed variability (potentially on log-scale). |
log_scale |
add variability on log scale (FALSE by default, DEPRECATED!). |
q |
quantile |
ruv |
list of residual variability ( |
... |
passed arguments |
Numeric vector of y values with residual variability
Model adherence as a binomial probability at the time of each occasion.
adherence_binomial(n = 100, prob)
adherence_binomial(n = 100, prob)
n |
number of occasions |
prob |
binomial probability |
Returns a vector of length n
containing values 0 (non-adherent) or 1 (adherent).
Numeric vector of length n
Model adherence as a markov chain model, based on the probability of staying adherent and of becoming adherent once non-adherent. Assumes all patients start adherent.
adherence_markov(n = 100, p11 = 0.9, p01 = 0.7)
adherence_markov(n = 100, p11 = 0.9, p01 = 0.7)
n |
number of occasions |
p11 |
probability of staying adherent |
p01 |
probability of going from non-adherent to adherent state |
Returns a vector of length n
containing values 0 (non-adherent) or 1 (adherent).
Numeric vector of length n
ADVAN-style functions to calculate linear PK systems
advan(model, cpp = TRUE)
advan(model, cpp = TRUE)
model |
Standard linear PK model, e.g. |
cpp |
use C++-versions of model (~50x faster than R implementations) |
Model function
Create ADVAN-style dataset
advan_create_data( regimen, parameters, cmts = 5, t_obs = NULL, covariates = NULL, covariate_model = NULL )
advan_create_data( regimen, parameters, cmts = 5, t_obs = NULL, covariates = NULL, covariate_model = NULL )
regimen |
PKPDsim regimen |
parameters |
list of parameters |
cmts |
number of compartments, minimum is 1. Default is 5, which is enough for most linear PK models. It is OK to have more compartments available than are actually being used. |
t_obs |
add observation timepoints to dataset |
covariates |
covariate list |
covariate_model |
covariate model equations, written in C |
Data frame of ADVAN-style data
Internal function to parse the raw output from ADVAN-style functions
advan_parse_output(data, cmts = 1, t_obs, extra_t_obs = TRUE, regimen)
advan_parse_output(data, cmts = 1, t_obs, extra_t_obs = TRUE, regimen)
data |
simulation output data |
cmts |
number of compartments |
t_obs |
observation times |
extra_t_obs |
leave extra added dose times in dataset? |
regimen |
PKPDsim regimen |
Data frame containing parsed simulation data
Function adapted from code from Abuhelwa, Foster, Upton JPET 2015. cleaned up and somewhat optimized. Can potentially be optimized more.
advan_process_infusion_doses(data)
advan_process_infusion_doses(data)
data |
ADVAN-style dataset, e.g. created using |
Data frame containing additional RATEALL column.
Abuhelwa, A. Y., Foster, D. J. R., Upton, R. N. (2015) ADVAN-style analytical solutions for common pharmacokinetic models. J Pharmacol Toxicol Methods 73:42-8. DOI: 10.1016/j.vascn.2015.03.004
E.g. see Centanni et al. Clin Pharmacokinet 2024. An estimated scaling factor for the length of the infusion was applied there in a model for vincristine. This is likely most relevant for very short infusions.
apply_duration_scale( regimen, duration_scale = NULL, parameters = NULL, cmt_mapping = NULL )
apply_duration_scale( regimen, duration_scale = NULL, parameters = NULL, cmt_mapping = NULL )
regimen |
PKPDsim regimen |
duration_scale |
infusion length scale. |
parameters |
parameter list, required if the duration scale is specified as a parameter. |
cmt_mapping |
map of administration types to compartments, e.g.
|
Implementation is similar to handling of lagtime
, i.e. the regimen that is the
input for the simulation function is updated.
Original regimen with infusion lengths scaled by a factor
Apply lagtime to a regimen
apply_lagtime(regimen, lagtime, parameters, cmt_mapping = NULL)
apply_lagtime(regimen, lagtime, parameters, cmt_mapping = NULL)
regimen |
PKPDsim regimen |
lagtime |
lagtime object, either single value / parameter name or vector of values/parameter names for all compartments. |
parameters |
parameter list, required if parameters are specified. |
cmt_mapping |
map of administration types to compartments, e.g. |
Original regimen with lagtime added to dose times
See models from the literature available for installation
available_default_literature_models()
available_default_literature_models()
Returns a character vector of models available for installation
available_default_literature_models()
available_default_literature_models()
Convenience function to calculate the AUC based on PK model parameters at any given moment, for linear iv models.
calc_auc_analytic( f = c("1cmt_iv_infusion", "2cmt_iv_infusion", "3cmt_iv_infusion", "1cmt_iv_bolus", "2cmt_iv_bolus", "3cmt_iv_bolus"), parameters, regimen = NULL, dose = NULL, interval = NULL, t_inf = NULL, t_obs = c(0, 24, 48, 72), ... )
calc_auc_analytic( f = c("1cmt_iv_infusion", "2cmt_iv_infusion", "3cmt_iv_infusion", "1cmt_iv_bolus", "2cmt_iv_bolus", "3cmt_iv_bolus"), parameters, regimen = NULL, dose = NULL, interval = NULL, t_inf = NULL, t_obs = c(0, 24, 48, 72), ... )
f |
analytic model to use, show available models using |
parameters |
list of parameter estimates. Requires CL/V for 1-compartment models, CL/V/Q/V2 for 2-compartment models, and CL/V/Q/V2/Q2/V3 for 3-compartment models. |
regimen |
PKPDsim regimen created using |
dose |
dosing amount for regimen (single value). Only used if no
|
interval |
dosing interval for regimen (single value). Only used if no
. |
t_inf |
infusion length for regimen (single value). Only used if no
|
t_obs |
vector of observation times for AUC |
... |
optional arguments passed to |
a data.frame with t
and auc
dat <- calc_auc_analytic( f = "2cmt_iv_infusion", regimen = new_regimen( amt = 1000, n = 10, type = "infusion", t_inf = 1, interval = 24 ), parameters = list(CL = 5, V = 50, Q = 8, V2 = 150) )
dat <- calc_auc_analytic( f = "2cmt_iv_infusion", regimen = new_regimen( amt = 1000, n = 10, type = "infusion", t_inf = 1, interval = 24 ), parameters = list(CL = 5, V = 50, Q = 8, V2 = 150) )
Calculate derivative
calc_dydP(dy, y, rel_delta, log_y)
calc_dydP(dy, y, rel_delta, log_y)
dy |
dy |
y |
dependent value |
rel_delta |
relative delta |
log_y |
logical indicating if the dependent variable is log transformed |
Basically it performs a PK simulation using analytic equations instead of ODEs to steady state (n=45 days, increased if needed).
calc_ss_analytic( f = "1cmt_oral", dose, interval, t_inf = NULL, model, parameters, covariates = NULL, map = NULL, n_days = 45, n_transit_compartments = 0, auc = FALSE )
calc_ss_analytic( f = "1cmt_oral", dose, interval, t_inf = NULL, model, parameters, covariates = NULL, map = NULL, n_days = 45, n_transit_compartments = 0, auc = FALSE )
f |
analytic equation to use, must be one of |
dose |
dose |
interval |
interval |
t_inf |
infusion time |
model |
PKPDsim model |
parameters |
parameters list |
covariates |
covariates list |
map |
list for remapping parameters, ex: |
n_days |
number of days at which to assume steady state. Default is 45. |
n_transit_compartments |
number of transit compartments, will insert n compartments between the first (dose) compartment and the second (central) compartment. |
auc |
add (empty) AUC compartment at end of state vector? |
It can also be used for models with transit compartments, however, the assumption is made that at the end of the dosing interval the amount in the transit compartments is negligible (0).
State vector of a linear pharmacokinetic system at steady state
This is a convenience function for PKPDsim users, it is not used inside the
sim_ode()`` function in any way. This function is useful for converting from an estimated parameter to actual parameter, e.g. when clearance is specified as
CLi = CL * (WT/70) * (1/CR)it can be used to calculate
CLi' without
having to write that function a second time in R.
calculate_parameters( ode = NULL, parameters = NULL, covariates = NULL, include_parameters = TRUE, include_variables = TRUE, regimen = NULL, t_obs = NULL, ... )
calculate_parameters( ode = NULL, parameters = NULL, covariates = NULL, include_parameters = TRUE, include_variables = TRUE, regimen = NULL, t_obs = NULL, ... )
ode |
PKPDsim model object |
parameters |
parameter list |
covariates |
covariate list. Make sure to include covariates at the right time point, since only last observed covariate values are used. |
include_parameters |
boolean, include parameters? |
include_variables |
boolean, include variables? |
regimen |
optional, provide a |
t_obs |
optional, provide timepoint(s) at which to computate effective
parameters. This is only relevant for models with time-varying
fixed-effects. If unspecified, will evaluate parameters at |
... |
arguments to pass on to simulation function |
List of model-specific variables
Checks obs input for valid combinations of cmt, var, scale
check_obs_input(obs)
check_obs_input(obs)
obs |
specified observation object including at least a description of
which variable(s) are associated with a particular compartment, e.g.
|
Compile ODE model to c++ function
compile_sim_cpp( code, dose_code, pk_code, size, p, cpp_show_code, code_init = NULL, state_init = NULL, declare_variables = NULL, variables = NULL, covariates = NULL, obs = NULL, dose = NULL, iov = NULL, compile = TRUE, verbose = FALSE, as_is = FALSE )
compile_sim_cpp( code, dose_code, pk_code, size, p, cpp_show_code, code_init = NULL, state_init = NULL, declare_variables = NULL, variables = NULL, covariates = NULL, obs = NULL, dose = NULL, iov = NULL, compile = TRUE, verbose = FALSE, as_is = FALSE )
code |
C++ code ODE system |
dose_code |
C++ code per dose event |
pk_code |
C++ code per any event (similar to $PK) |
size |
size of ODE system |
p |
parameters (list) |
cpp_show_code |
show output c++ function? |
code_init |
code for initialization of state |
state_init |
state init vector |
declare_variables |
variable declaration for all required variables (including user-specified) |
variables |
only the user-specified variables |
covariates |
covariates specification |
obs |
observation specification |
dose |
dose specification |
iov |
iov specification |
compile |
compile or not? |
verbose |
show more output |
as_is |
use C-code as-is, don't substitute line-endings or shift indices |
List containing ODE definition in C++ code and simulation function
Use only last observed covariate values
covariate_last_obs_only(covariates)
covariate_last_obs_only(covariates)
covariates |
covariates object |
List containing same elements as input covariate object but including only the last value for each covariate
Can handle time-varying data too, if t
or time
is specified as column
covariates_table_to_list(covariates_table, covariates_implementation = list())
covariates_table_to_list(covariates_table, covariates_implementation = list())
covariates_table |
|
covariates_implementation |
|
List of covariates
Create lower-diagonal omega matrix from CV for parameter estimates
cv_to_omega(par_cv = NULL, parameters = NULL)
cv_to_omega(par_cv = NULL, parameters = NULL)
par_cv |
list of parameter CVs |
parameters |
list of parameters |
a vector describing the lower triangle of the omega (between-subject variability) matrix
Either PKPDsim or RxODE
detect_ode_syntax(code)
detect_ode_syntax(code)
code |
character string with ODE code |
List with elements from
and to
indicating the syntax for the ODE
code
covariate function builder
f_cov(...)
f_cov(...)
... |
parameters to pass to cov |
Covariate function
Get fixed parameters listed in model definition. This function is used when
parsing model specifications before the model has been compiled. Please see
[get_model_fixed_parameters]
for accessing fixed parameters from a model
that has already been built.
get_fixed_parameters(def)
get_fixed_parameters(def)
def |
Model definition as output by |
PKPDsim models encode information about using the model that can be helpful
for working with the model. This family of functions provides an easier API
for accessing useful information. See also attributes(model)
for less
commonly used model metadata. Functions will return NULL
if the requested
field is not available.
get_model_parameters(model) get_model_covariates(model) get_model_fixed_parameters(model) get_model_structure(model) get_model_linearity(model) get_model_auc_compartment(model) get_model_iov(model)
get_model_parameters(model) get_model_covariates(model) get_model_fixed_parameters(model) get_model_structure(model) get_model_linearity(model) get_model_auc_compartment(model) get_model_iov(model)
model |
PKPDsim model |
get_model_parameters: returns a vector of PK parameter names
get_model_covariates: returns a vector of covariate names
get_model_fixed_parameters: returns a vector of names of parameters that are not associated with inter-individual or inter-occasion variability.
get_model_structure: returns a single string indicating model structure. E.g.,: "1cmt_iv", "2cmt_oral".
get_model_linearity: returns a single string indicating model linearity. E.g., "linear" or "nonlinear".
get_model_auc_compartment: returns the index of the final compartment, which is conventionally the AUC compartment. Note: will not detect if the final compartment is actually encoded to describe AUC.
get_model_iov: returns information about the IOV structure. For
models without IOV, returns a single field (list(n_bins = 1)
). Models
with IOV will return additional fields: n_bins, bin durations, and CV
associated with each PK parameter.
Get the number of states in the ODE from the code code C++ code for model
get_ode_model_size(code)
get_ode_model_size(code)
code |
C++ code |
Number of states in the ODE model
Get model parameters from code
get_parameters_from_code(code, state_init, declare_variables = NULL)
get_parameters_from_code(code, state_init, declare_variables = NULL)
code |
code |
state_init |
state init vector |
declare_variables |
declared variables |
Vector of parameter names
Get expected variance/sd/ci of dependent variable based on PKPDsim model, parameters, and regimen
get_var_y( model = NULL, parameters = list(), regimen = list(), t_obs = c(1:48), obs_comp = NULL, obs_variable = NULL, omega = c(0.1, 0.05, 0.1), omega_full = NULL, n_ind = NULL, ruv = NULL, y = NULL, rel_delta = 1e-04, method = "delta", sequence = NULL, auc = FALSE, sd = TRUE, q = NULL, in_parallel = FALSE, n_cores = 3, return_all = FALSE, ... )
get_var_y( model = NULL, parameters = list(), regimen = list(), t_obs = c(1:48), obs_comp = NULL, obs_variable = NULL, omega = c(0.1, 0.05, 0.1), omega_full = NULL, n_ind = NULL, ruv = NULL, y = NULL, rel_delta = 1e-04, method = "delta", sequence = NULL, auc = FALSE, sd = TRUE, q = NULL, in_parallel = FALSE, n_cores = 3, return_all = FALSE, ... )
model |
model, created using |
parameters |
parameters list |
regimen |
regimen, as created using |
t_obs |
vector of observation times |
obs_comp |
observation compartment. If NULL will be "obs" (default) |
obs_variable |
observation variable. If NULL, will be ignored, otherwise will override |
omega |
triangle omega block |
omega_full |
full omega block |
n_ind |
number of individuals to simulate with sim method |
ruv |
residual variability, supplied as a named list, ex: |
y |
vector of observations. If NULL, then a new simulation will be performed. |
rel_delta |
rel_delta |
method |
method, |
sequence |
for simulations, if not NULL the pseudo-random sequence to use, e.g. "halton" or "sobol". See |
auc |
is AUC? |
sd |
return as standard deviation ( |
q |
return vector of quantiles instead of sd/var. Will return parametric quantiles when delta-method is used, non-parametric for simulation-based methods. |
in_parallel |
run simulations in parallel? |
n_cores |
if run in parallel, on how many cores? |
return_all |
return object with all relevant information? |
... |
passed on to |
Vector of standard deviations or variances (or quantiles thereof) for dependent value variable
ifelse function but then based on whether value is NULL or not
ifelse0(value = NULL, alternative = NULL, allow_null = FALSE)
ifelse0(value = NULL, alternative = NULL, allow_null = FALSE)
value |
metadata list object |
alternative |
alternative value |
allow_null |
can the alternative be NULL? |
value
if non-NULL; alternative
otherwise
A very lightweight wrapper for model_from_api
that installs previously
published models packaged within PKPDsim.
install_default_literature_model(model, ...)
install_default_literature_model(model, ...)
model |
Name of model, e.g., "pk_busulfan_mccune". See
|
... |
arguments passed onto |
## Not run: install_default_literature_model("pk_busulfan_mccune") ## End(Not run)
## Not run: install_default_literature_model("pk_busulfan_mccune") ## End(Not run)
Is matrix positive definite
is_positive_definite(x)
is_positive_definite(x)
x |
matrix, specified either as |
TRUE if x
is positive definite; FALSE otherwise.
Combines covariates and parameters into a single list, useful for reparametrization of the model.
join_cov_and_par(covs, pars)
join_cov_and_par(covs, pars)
covs |
covariates object |
pars |
model parameters, such as the output of the |
List containing covariates and parameters
Join two dosing regimens
join_regimen( regimen1 = NULL, regimen2 = NULL, interval = NULL, dose_update = NULL, t_dose_update = NULL, continuous = FALSE )
join_regimen( regimen1 = NULL, regimen2 = NULL, interval = NULL, dose_update = NULL, t_dose_update = NULL, continuous = FALSE )
regimen1 |
first regimen |
regimen2 |
second regimen |
interval |
interval between regimen1 and regimen2 (if dose_update not specified) |
dose_update |
dose number at which to override regimen1 with regimen 2 (if interval not specified) |
t_dose_update |
dose time from which to update regimen |
continuous |
for joining continuous infusions |
Joined regimen
Size of the lower triangle of the matrix
lower_triangle_mat_size(mat)
lower_triangle_mat_size(mat)
mat |
omega matrix as a vector |
In contrast to join_regimen
, which joins two consecutive regimens together, merge_regimen
merges two or
more regimens given at the same time. This can e.g. be used to define regimens for multi-drug models.
merge_regimen(regimens)
merge_regimen(regimens)
regimens |
List of PKPDsim regimens created with |
Merged regimens
Load model definition from API, and compile to R library
model_from_api( url, model = NULL, nonmem = NULL, verbose = TRUE, get_definition = FALSE, to_package = FALSE, force = FALSE, install_all = FALSE, ... )
model_from_api( url, model = NULL, nonmem = NULL, verbose = TRUE, get_definition = FALSE, to_package = FALSE, force = FALSE, install_all = FALSE, ... )
url |
URL or file path to JSON representation of model |
model |
model id (used in messages) |
nonmem |
URL or file path to NONMEM file |
verbose |
verbosity (T/F) |
get_definition |
return only the model definition, do not compile |
to_package |
compile to package? |
force |
force install even if same version number of model already installed. |
install_all |
force install all, even if model inactive |
... |
arguments passed to |
Model object created with new_ode_model()
Model library
model_library(name = NULL)
model_library(name = NULL)
name |
name of model in library. If none specified, will show list of available models. |
List containing information about the named model
Besides standard multivariate normal sampling (mvrnorm), allows exponential multivariate normal and quasi-random multivariate normal (using the randtoolbox) all using the same interface.
mvrnorm2(n, mu, Sigma, exponential = FALSE, sequence = NULL, ...)
mvrnorm2(n, mu, Sigma, exponential = FALSE, sequence = NULL, ...)
n |
number of samples |
mu |
mean |
Sigma |
covariance matrix |
exponential |
exponential distribution (i.e. multiply mu by exponential of sampled numbers) |
sequence |
any sequence available in the randtoolbox, e.g. |
... |
parameters passed to mvrnorm or randtoolbox sequence generator |
Multivariate normal samples
Inspired by zoo::na.locf0
na_locf(object, fromLast = FALSE)
na_locf(object, fromLast = FALSE)
object |
an object |
fromLast |
logical. Causes observations to be carried backward rather than forward. Default is FALSE. |
Original object with NAs filled in
Model the drug adherence using either a binomial probability distribution or a markov chain model based on the probability of staying adherent and of becoming adherent once non-adherent.
new_adherence( n = 100, type = c("markov", "binomial"), p_markov_remain_ad = 0.75, p_markov_become_ad = 0.75, p_binom = 0.7 )
new_adherence( n = 100, type = c("markov", "binomial"), p_markov_remain_ad = 0.75, p_markov_become_ad = 0.75, p_binom = 0.7 )
n |
number of occasions to simulate |
type |
type of adherence simulation, either "markov" or "binomial" |
p_markov_remain_ad |
markov probability of staying adherent |
p_markov_become_ad |
markov probability of going from non-adherent to adherent state |
p_binom |
binomial probability of being adherent |
Returns a vector of length n
containing values 0 (non-adherent) or 1 (adherent).
Numeric vector of length n
Describe data for a covariate, either fixed or time-variant
new_covariate( value = NULL, times = NULL, implementation = c("interpolate", "locf"), unit = NULL, interpolation_join_limit = 1, remove_negative_times = TRUE, round_times = NULL, comments = NULL, verbose = TRUE )
new_covariate( value = NULL, times = NULL, implementation = c("interpolate", "locf"), unit = NULL, interpolation_join_limit = 1, remove_negative_times = TRUE, round_times = NULL, comments = NULL, verbose = TRUE )
value |
a numeric vector |
times |
NULL for time-invariant covariate or a numeric vector specifying the update times for the covariate |
implementation |
for time-varying covariates either 'locf' (last observation carried forward) or 'interpolate' (default). Non-numeric covariate values are assumed to be locf. |
unit |
specify covariate unit (optional, for documentation purposes only) |
interpolation_join_limit |
for |
remove_negative_times |
should times before zero be discarded (with
value at time zero determined based on |
round_times |
round times to specified number of digits. If |
comments |
|
verbose |
verbosity |
Object of class "covariate"
covariate model function
new_covariate_model(model = list())
new_covariate_model(model = list())
model |
covariate model specified as list |
List containing model function(s)
Create new ODE model
new_ode_model( model = NULL, code = NULL, pk_code = NULL, dose_code = NULL, file = NULL, func = NULL, state_init = NULL, parameters = NULL, reparametrization = NULL, mixture = NULL, units = NULL, size = NULL, lagtime = NULL, obs = list(cmt = 1, scale = 1), dose = list(cmt = 1), covariates = NULL, declare_variables = NULL, iiv = NULL, iov = NULL, development = NULL, omega_matrix = NULL, ruv = NULL, ltbs = NULL, misc = NULL, cmt_mapping = NULL, int_step_size = NULL, default_parameters = NULL, fixed = NULL, cpp_show_code = FALSE, package = NULL, test_file = NULL, install = TRUE, folder = NULL, lib_location = NULL, verbose = FALSE, as_is = FALSE, nonmem = NULL, comments = NULL, version = "0.1.0", quiet = "", definition = NULL )
new_ode_model( model = NULL, code = NULL, pk_code = NULL, dose_code = NULL, file = NULL, func = NULL, state_init = NULL, parameters = NULL, reparametrization = NULL, mixture = NULL, units = NULL, size = NULL, lagtime = NULL, obs = list(cmt = 1, scale = 1), dose = list(cmt = 1), covariates = NULL, declare_variables = NULL, iiv = NULL, iov = NULL, development = NULL, omega_matrix = NULL, ruv = NULL, ltbs = NULL, misc = NULL, cmt_mapping = NULL, int_step_size = NULL, default_parameters = NULL, fixed = NULL, cpp_show_code = FALSE, package = NULL, test_file = NULL, install = TRUE, folder = NULL, lib_location = NULL, verbose = FALSE, as_is = FALSE, nonmem = NULL, comments = NULL, version = "0.1.0", quiet = "", definition = NULL )
model |
model name from model library |
code |
C++ code specifying ODE system |
pk_code |
C++ code called at any event |
dose_code |
C++ code called at dose event only |
file |
file containing C++ code |
func |
R function to be used with deSolve library |
state_init |
vector of state init |
parameters |
list or vector of parameter values |
reparametrization |
list of parameters with definitions that reparametrize the linear PK model to a 1-, 2- o4 3-compartment PK with standardized parametrization. |
mixture |
for mixture models, provide a list of the parameter associated with the mixture and it's possible values and probabilities (of the first value), e.g. |
units |
list or vector of parameter units |
size |
size of state vector for model. Size will be extracted automatically from supplied code, use this argument to override. |
lagtime |
lag time |
obs |
list with "scale": character string with definition for scale, e.g. "V" or "V*(WT/70)". If NULL, scale defaults to 1., and "cmt" the observation compartment |
dose |
specify default dose compartment, e.g. list(cmt = 1) |
covariates |
specify covariates, either as a character vector or a list. if specified as list, it allows use of timevarying covariates (see |
declare_variables |
declare variables |
iiv |
inter-individual variability, can optionally be added to library |
iov |
inter-occasion variability, can optionally be added to library |
development |
Information about the model development population, can optionally be added to library |
omega_matrix |
variance-covariance matrix for inter-individual variability, can optionally be added to library |
ruv |
residual variability, can optionally be added to library |
ltbs |
log-transform both sides. Not used in simulations, only for fitting (sets attribute |
misc |
a list of miscellaneous model metadata |
cmt_mapping |
list indicating which administration routes apply to which compartments. Example: |
int_step_size |
step size for integrator. Can be pre-specified for model, to override default for |
default_parameters |
population or specific patient values, can optionally be added to library |
fixed |
parameters that should not have iiv added. |
cpp_show_code |
show generated C++ code |
package |
package name when saving as package |
test_file |
optional test file to be included with package |
install |
install package after compilation? |
folder |
base folder name to create package in |
lib_location |
install into folder ( |
verbose |
show more output |
as_is |
use C-code as-is, don't substitute line-endings or shift indices |
nonmem |
add NONMEM code as attribute to model object |
comments |
comments for model |
version |
number of library |
quiet |
passed on to |
definition |
optional, filename for the JSON file the full definition
for the model. The definition file will be stored as |
If package name is NULL, returns the model object. Otherwise has no return value.
Create a dosing regimen for use with sim_ode
new_regimen( amt = 100, interval = NULL, n = 3, times = NULL, type = NULL, t_inf = NULL, rate = NULL, t_lag = NULL, cmt = NULL, checks = TRUE, ss = FALSE, n_ss = NULL, first_dose_time = now_utc() )
new_regimen( amt = 100, interval = NULL, n = 3, times = NULL, type = NULL, t_inf = NULL, rate = NULL, t_lag = NULL, cmt = NULL, checks = TRUE, ss = FALSE, n_ss = NULL, first_dose_time = now_utc() )
amt |
dosing amount, either a single value (which will repeated for multiple doses), or a vector with doses for each administration |
interval |
dosing interval (requires n as argument) |
n |
number of doses (requires interval as argument) |
times |
vector describing dosing times. Overrides specified times using interval and n arguments |
type |
either "infusion", "bolus", "oral", "sc" (subcutaneous), or "im" (intramuscular). |
t_inf |
infusion time (if |
rate |
infusion rate (if |
t_lag |
lag time (can be applied to any dose type, not only oral). Will just be added to |
cmt |
vector of dosing compartments (optional, if NULL will dosing compartment defined in model will be used) |
checks |
input checks. Remove to increase speed (e.g. for population-level estimation or optimal design) |
ss |
steady state? boolean value whether to simulate out to steady state first (steady state will be based on specified |
n_ss |
how many doses to simulate before assumed steady state. Default is 4 * 24 / |
first_dose_time |
datetime stamp of first dose (of class |
a list containing calculated VPC information, and a ggplot2 object
r1 <- new_regimen(amt=50, interval=12, n=20) # dose 50mg, q12hrs for 10 days r2 <- new_regimen(amt=50, times=c(0:19)*12) # same, but using explicit times r3 <- new_regimen(amt=c(rep(100,4), rep(50,16)), times=c(0:19)*12) # first 4 doses higher dose
r1 <- new_regimen(amt=50, interval=12, n=20) # dose 50mg, q12hrs for 10 days r2 <- new_regimen(amt=50, times=c(0:19)*12) # same, but using explicit times r3 <- new_regimen(amt=c(rep(100,4), rep(50,16)), times=c(0:19)*12) # first 4 doses higher dose
Function to parse parameters for a model into a structure used by nlmixr
nlmixr_parse_parameters( parameters = list(CL = 5, V = 50), omega = c(0.1, 0.05, 0.1), res_var = list(prop = 0.1, add = 1), fixed = c(), log_transform = TRUE, ... )
nlmixr_parse_parameters( parameters = list(CL = 5, V = 50), omega = c(0.1, 0.05, 0.1), res_var = list(prop = 0.1, add = 1), fixed = c(), log_transform = TRUE, ... )
parameters |
list of parameters |
omega |
vector describing the lower-diagonal of the between-subject variability matrix |
res_var |
residual variability. Expected a list with arguments |
fixed |
vector of fixed parameters |
log_transform |
log-transform estimated parameters in nlmixr? |
... |
passed on |
List of parameters that can be used by nlmixr
Create a regimen based on a NONMEM, or NONMEM-like dataset
nm_to_regimen(data, reset_time = TRUE, first_only = FALSE)
nm_to_regimen(data, reset_time = TRUE, first_only = FALSE)
data |
NONMEM-type dataset |
reset_time |
start time for each simulated patient at 0, irrespective of design in dataset |
first_only |
use only design from first individual in dataset |
Regimen object
Example PK dataset
pkdata
pkdata
A data frame with 624 rows and 12 variables in NONMEM format
Convert a model generated with PKPDsim to an object for nlmixr
pkpdsim_to_nlmixr( model = NULL, parameters = NULL, omega = NULL, res_var = NULL, fixed = c(), ini_code = NULL, model_code = NULL, model_par_code = NULL, verbose = FALSE, ... )
pkpdsim_to_nlmixr( model = NULL, parameters = NULL, omega = NULL, res_var = NULL, fixed = c(), ini_code = NULL, model_code = NULL, model_par_code = NULL, verbose = FALSE, ... )
model |
PKPDsim model |
parameters |
list of parameters |
omega |
vector describing the lower-diagonal of the between-subject variability matrix |
res_var |
residual variability. Expected a list with arguments |
fixed |
vector of fixed (not estimated) parameter names |
ini_code |
manually specify the |
model_code |
manually specify the |
model_par_code |
manually specify the parameters section inside the |
verbose |
verbose, |
... |
passed on |
nlmixr function
Opposite of shift_regimen()
pop_regimen(regimen, n = 1)
pop_regimen(regimen, n = 1)
regimen |
PKPDsim regimen created using |
n |
number of doses to pop from regimen |
Input regiment minus selected number of doses
shift_regimen
Return a list in R syntax
print_list(x, wrapper = TRUE)
print_list(x, wrapper = TRUE)
x |
list to be printed |
wrapper |
wrap in list object? |
Original list in R syntax
Does some substitution of escaped characters in strings in the JSON file,
then converts to a list with jsonlite::fromJSON()
read_model_json(path)
read_model_json(path)
path |
Path to JSON file |
List containing contents of original JSON file
Convert PKPDsim regimen to NONMEM table (doses only)
regimen_to_nm( reg = NULL, dose_cmt = 1, n_ind = 1, t_obs = NULL, obs_cmt = 1, bioav = NULL )
regimen_to_nm( reg = NULL, dose_cmt = 1, n_ind = 1, t_obs = NULL, obs_cmt = 1, bioav = NULL )
reg |
|
dose_cmt |
dosing compartment, if not specified in |
n_ind |
repeat for |
t_obs |
add observation time(s) |
obs_cmt |
observation compartment for added observation time(s) |
bioav |
bioavailability (numeric vector, can not be a parameter) |
Data frame containing doses
Mostly useful for reparametrizing models into standard parametrizations, e.g. to NONMEM TRANS or clinPK parametrizations.
reparametrize(model, parameters, covariates)
reparametrize(model, parameters, covariates)
model |
PKPDsim model, compiled using |
parameters |
list of model parameters |
covariates |
covariates list, specified as PKPDsim covariates |
Reparameterized model parameters
Find string and replace in file
search_replace_in_file(files = c(), find = NULL, replacement = NULL)
search_replace_in_file(files = c(), find = NULL, replacement = NULL)
files |
vector of files |
find |
find what string, vector of character |
replacement |
replace with what, vector of character, should be equal in length to |
Function does not return a value but edits files on disk
Opposite of pop_regimen()
shift_regimen(regimen, n = 1, reset_time = TRUE)
shift_regimen(regimen, n = 1, reset_time = TRUE)
regimen |
PKPDsim regimen created using |
n |
number of doses to shift regimen |
reset_time |
reset the remaining doses to start at t=0? |
Regimen with selected number of doses removed from start
pop_regimen
Simulates a specified regimen using ODE system or analytical equation
sim( ode = NULL, analytical = NULL, parameters = NULL, parameters_table = NULL, mixture_group = NULL, omega = NULL, omega_type = "exponential", res_var = NULL, iov_bins = NULL, seed = NULL, sequence = NULL, n_ind = 1, event_table = NULL, regimen = NULL, lagtime = NULL, covariates = NULL, covariates_table = NULL, covariates_implementation = list(), covariate_model = NULL, A_init = NULL, only_obs = FALSE, obs_step_size = NULL, int_step_size = 0.01, t_max = NULL, t_obs = NULL, t_tte = NULL, t_init = 0, obs_type = NULL, duplicate_t_obs = FALSE, extra_t_obs = TRUE, rtte = FALSE, checks = TRUE, verbose = FALSE, return_event_table = FALSE, return_design = FALSE, output_include = list(parameters = FALSE, covariates = FALSE), ... )
sim( ode = NULL, analytical = NULL, parameters = NULL, parameters_table = NULL, mixture_group = NULL, omega = NULL, omega_type = "exponential", res_var = NULL, iov_bins = NULL, seed = NULL, sequence = NULL, n_ind = 1, event_table = NULL, regimen = NULL, lagtime = NULL, covariates = NULL, covariates_table = NULL, covariates_implementation = list(), covariate_model = NULL, A_init = NULL, only_obs = FALSE, obs_step_size = NULL, int_step_size = 0.01, t_max = NULL, t_obs = NULL, t_tte = NULL, t_init = 0, obs_type = NULL, duplicate_t_obs = FALSE, extra_t_obs = TRUE, rtte = FALSE, checks = TRUE, verbose = FALSE, return_event_table = FALSE, return_design = FALSE, output_include = list(parameters = FALSE, covariates = FALSE), ... )
ode |
function describing the ODE system |
analytical |
string specifying analytical equation model to use (similar to ADVAN1-5 in NONMEM). If specified, will not use ODEs. |
parameters |
model parameters |
parameters_table |
dataframe of parameters (with parameters as columns) containing parameter estimates for individuals to simulate. Formats accepted: data.frame, data.table, or list of lists. |
mixture_group |
mixture group for models containing mixtures. Should be either |
omega |
vector describing the lower-diagonal of the between-subject variability matrix |
omega_type |
exponential or normal, specified as vector |
res_var |
residual variability. Expected a list with arguments |
iov_bins |
allow override of the default IOV bins for a model. Specified
as a vector of timepoints specifying the bin separators, e.g.
|
seed |
set seed for reproducible results |
sequence |
if not NULL specifies the pseudo-random sequence to use, e.g. "halton" or "sobol". See |
n_ind |
number of individuals to simulate |
event_table |
use a previously created |
regimen |
a regimen object created using the regimen() function |
lagtime |
either a value (numeric) or a parameter (character) or NULL. |
covariates |
list of covariates (for single individual) created using |
covariates_table |
data.frame (or unnamed list of named lists per individual) with covariate values |
covariates_implementation |
used only for |
covariate_model |
R code used to pre-calculate effective parameters for use in ADVAN-style analytical equations. Not used in ODE simulations. |
A_init |
vector with the initial state of the ODE system |
only_obs |
only return the observations |
obs_step_size |
the step size between the observations |
int_step_size |
the step size for the numerical integrator |
t_max |
maximum simulation time, if not specified will pick the end of the regimen as maximum |
t_obs |
vector of observation times, only output these values (only used when t_obs==NULL) |
t_tte |
vector of observation times for time-to-event simulation |
t_init |
initialization time before first dose, default 0. |
obs_type |
vector of observation types. Only valid in combination with equal length vector |
duplicate_t_obs |
allow duplicate t_obs in output? E.g. for optimal design calculations when t_obs = c(0,1,2,2,3). Default is FALSE. |
extra_t_obs |
include extra t_obs in output for bolus doses? This is only activated when |
rtte |
should repeated events be allowed (FALSE by default) |
checks |
perform input checks? Default is TRUE. For calculations where sim_ode is invoked many times (e.g. population estimation, optimal design) it makes sense to switch this to FALSE (after confirming the input is correct) to improve speed. |
verbose |
show more output |
return_event_table |
return the event table for the simulation only, does not run the actual simulation. Useful for iterative use of sim(). |
return_design |
returns the design (event table and several other details) for the simulation, does not run the actual simulation. Useful for iterative functions like estimation in combination with |
output_include |
list specifying what to include in output table, with keys |
... |
extra parameters |
a data frame of compartments with associated concentrations at requested times
Simulated regimen
p <- list( CL = 38.48, V = 7.4, Q = 7.844, V2 = 5.19, Q2 = 9.324, V3 = 111 ) omega <- c(0.3, # IIV CL 0.1, 0.3) # IIV V r1 <- new_regimen( amt = 100, times = c(0, 24, 36), type = "infusion" ) mod <- new_ode_model("pk_3cmt_iv") dat <- sim( ode = mod, parameters = p, omega = omega, n_ind = 20, regimen = r1 )
p <- list( CL = 38.48, V = 7.4, Q = 7.844, V2 = 5.19, Q2 = 9.324, V3 = 111 ) omega <- c(0.3, # IIV CL 0.1, 0.3) # IIV V r1 <- new_regimen( amt = 100, times = c(0, 24, 36), type = "infusion" ) mod <- new_ode_model("pk_3cmt_iv") dat <- sim( ode = mod, parameters = p, omega = omega, n_ind = 20, regimen = r1 )
Only core function of the simulation function, always just returns observations. Mostly useful for estimations / optimal design. Has no checks (for speed)!
sim_core(sim_object = NULL, ode, duplicate_t_obs = FALSE, t_init = 0)
sim_core(sim_object = NULL, ode, duplicate_t_obs = FALSE, t_init = 0)
sim_object |
list with design and simulation parameters |
ode |
ode |
duplicate_t_obs |
allow duplicate t_obs in output? E.g. for optimal design calculations when t_obs = c(0,1,2,2,3). Default is FALSE. |
t_init |
time of initialization of the ODE system. Usually 0. |
Data frame with simulation results
sim()
Deprecated function, renamed to sim()
sim_ode(...)
sim_ode(...)
... |
parameters passed to |
Output from sim()
sim
This function has been deprecated and moved to a separate package at https://github.com/ronkeizer/PKPDsimshiny.
sim_ode_shiny(...)
sim_ode_shiny(...)
... |
arguments passed to PKPDsimShiny::sim_ode_shiny() |
No return value
Convert a table to a list
table_to_list(table)
table_to_list(table)
table |
data.frame |
List containing original table contents
Test a model
test_model(url, test_file, package, force = FALSE)
test_model(url, test_file, package, force = FALSE)
url |
URL or file path to JSON representation of model |
test_file |
Path to a .R file containing tests to run |
package |
Package name |
force |
Run tests even if model is not flagged for building? Defaults to FALSE |
Runs test file for a model but does not return a value
Test if model still in memory
test_pointer(model)
test_pointer(model)
model |
pointer to model |
No return value
Currently only supports PKDPsim <–> RxODE
translate_ode(code, auto = TRUE, from = NULL, to = NULL, verbose = TRUE)
translate_ode(code, auto = TRUE, from = NULL, to = NULL, verbose = TRUE)
code |
character string with ODE code |
auto |
is auto-detect syntax ( |
from |
from syntax |
to |
to syntax |
verbose |
verbose, |
Translated PKPDsim or RxODE model
Convert triangle omega matrix to full omega matrix
triangle_to_full(vect)
triangle_to_full(vect)
vect |
vector specifying triangle omega matrix |
Omega matrix