theTimes: The time points at which derivative estimation are requested
norder: Order of Bsplines - usually 2 higher than roughPenaltyMax
roughPenaltyMax: Penalization order. Usually set to 2 higher than the highest-order derivatives desired
lambda: A positive smoothing parameter: larger --> more smoothing
dataMatrix: Data of size total number of time points x total number of subjects
derivOrder: The order of the desired derivative estimates
Returns
A list containing: 1. out (a matrix containing the derivative estimates at the specified order that matches the dimension of dataMatrix); 2. basisCoef (estimated basis coefficients); 3. basis2 (basis functions)
Examples
data("LinearOsc")# Number of subjects is 10numP <- length(unique(LinearOsc$ID))# Number of time points is 100numT <- max(table(LinearOsc$ID))out2 <- matrix(LinearOsc$x, ncol=numP, byrow=FALSE)theTimes <- LinearOsc$theTimes[1:numT]# Order of Bsplines - usually 2 higher than roughPenaltyMaxnorder <-6# Penalization orderroughPenaltyMax <-4# Pick lambda value that gives the low GCV# Could/should use plotGCV insteadsp <-1/2# Smoothed levelx <- getdx(theTimes, norder, roughPenaltyMax, sp, out2,0)[[1]]# Smoothed 1st derivsdx <- getdx(theTimes, norder, roughPenaltyMax, sp, out2,1)[[1]]# Smoothed 2nd derivsd2x = getdx(theTimes, norder, roughPenaltyMax, sp, out2,2)[[1]]
Chow, S-M., *Bendezu, J. J., Cole, P. M., & Ram, N. (2016). A Comparison of Two- Stage Approaches for Fitting Nonlinear Ordinary Differential Equation (ODE) Models with Mixed Effects. Multivariate Behavioral Research, 51, 154-184. Doi: 10.1080/00273171.2015.1123138.