Title: | Fitting a CoxSEI Model |
---|---|
Description: | Fit a CoxSEI (Cox type Self-Exciting Intensity) model to right-censored counting process data. |
Authors: | Feng Chen <[email protected]> |
Maintainer: | Feng Chen <[email protected]> |
License: | GPL (>= 2) |
Version: | 0.3 |
Built: | 2025-01-10 05:18:37 UTC |
Source: | https://github.com/cran/coxsei |
Fit the CoxSEI model using the partial likelihood method.
To use the package, the data needs to be prepared into a data frame
containing a column named Y
for observed event times in ascending
order of each individual process, a column named delta
indicating
if the event is 'death' (1) or 'censoring' (0), a column named
id
indicating the process id of each event time, and one or more
columns giving the value of any covariate variable at the observed event
times of each process. Then call the coxseiest
function or the
identical but much faster coxseiest2
function to estimate the
parametric part of the model and then the coxseiInt
function to
estimate the cumulative baseline intensity function.
Feng Chen <[email protected]>
Maintainer: Feng Chen <[email protected]>
Feng Chen and Kani Chen. (2014). Modeling Event Clustering Using the m-Memory Cox-Type Self-Exciting Intensity Model. International Journal of Statistics and Probability. 3(3): 126-137. doi:10.5539/ijsp.v3n3p126 URL: http://dx.doi.org/10.5539/ijsp.v3n3p126
Feng Chen and Kani Chen. (2014). Case-cohort analysis of clusters of recurrent events. 20(1): 1-15. doi: 10.1007/s10985-013-9275-3
Fit a CoxSEI model to counting process data
coxsei(x,...) ## Default S3 method: coxsei(x,y,delta,id,par.init,m=2,mit=1000,tr=TRUE, method="L-BFGS-B",lower=c(rep(-Inf,ncol(x)),-Inf,0), upper=rep(Inf,ncol(x) + 2),...) ## S3 method for class 'coxsei' print(x,...) ## S3 method for class 'coxsei' plot(x,...) ## S3 method for class 'coxsei' summary(object,...)
coxsei(x,...) ## Default S3 method: coxsei(x,y,delta,id,par.init,m=2,mit=1000,tr=TRUE, method="L-BFGS-B",lower=c(rep(-Inf,ncol(x)),-Inf,0), upper=rep(Inf,ncol(x) + 2),...) ## S3 method for class 'coxsei' print(x,...) ## S3 method for class 'coxsei' plot(x,...) ## S3 method for class 'coxsei' summary(object,...)
x |
a covariate matrix, or an object of class |
y |
a vector of observed times |
delta |
a vector of event indicators: 1=event, 0=censoring |
id |
the individual/group id to which the event/censoring time correspond |
par.init |
initial parameter guess to start the iteration |
m |
lag parameter as in m-dependence |
mit |
max number of iteration |
tr |
whether to trace the optimization or not |
method |
method used in optimization |
lower |
the lower bound of the parameter space if the L-BFGS-B method of optimization is used. |
upper |
the upper bound of the paramter space if the L-BFGS-B methodof optimaization is used. |
... |
further arguments to plot.stepfun |
object |
an object of the class coxsei |
an object of class coxsei
, basically a list of the following
components
coefficients |
a numeric vector of coefficients |
vcov |
the variance-covariance matrix |
zval |
the vector of z-value of the Wald test statistic |
pval |
the vector of p-values |
details.par |
a list returned by the |
cintfn |
a step function as the estimated cumulative baseline intensity function |
cintvar |
a step function as the variance of the cumulative baseline intensity function estimator |
details.cint |
a list containing more details about the |
Feng Chen <[email protected]>
Feng Chen and Kani Chen. (2014). Modeling Event Clustering Using the m-Memory Cox-Type Self-Exciting Intensity Model. International Journal of Statistics and Probability. 3(3): 126-137. doi:10.5539/ijsp.v3n3p126 URL: http://dx.doi.org/10.5539/ijsp.v3n3p126
Feng Chen and Kani Chen. (2014). Case-cohort analysis of clusters of recurrent events. 20(1): 1-15. doi: 10.1007/s10985-013-9275-3
data(dat,package="coxsei") acoxsei <- coxsei(dat[,3:5],dat[,1],dat[,2],dat[,6], c(0.2*1:3,log(0.07),log(10))) summary(acoxsei) plot(acoxsei,do.points=FALSE)
data(dat,package="coxsei") acoxsei <- coxsei(dat[,3:5],dat[,1],dat[,2],dat[,6], c(0.2*1:3,log(0.07),log(10))) summary(acoxsei) plot(acoxsei,do.points=FALSE)
Estimate the parametric part of the CoxSEI model using (conditionally) right-censored counting process data.
coxseiest(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B", lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2), gfun = function(x, pa) { ifelse(x <= 0, rep(0, length(x)), pa[1] * exp(-pa[2] * x)) }) coxseiest2(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B", lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2), gfun = function(x, pa) { ifelse(x <= 0, rep(0, length(x)), pa[1] * exp(-pa[2] * x)) }) coxseiest3(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B", lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2))
coxseiest(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B", lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2), gfun = function(x, pa) { ifelse(x <= 0, rep(0, length(x)), pa[1] * exp(-pa[2] * x)) }) coxseiest2(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B", lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2), gfun = function(x, pa) { ifelse(x <= 0, rep(0, length(x)), pa[1] * exp(-pa[2] * x)) }) coxseiest3(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B", lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2))
dat |
a data frame with columns |
par.init |
init guess of the value of the parameters to start the optimization iteration with. |
m |
order of "autoregression" of the excitation term. |
mit |
maximum number of iteration in the optimization routine |
tr |
if set to |
method |
method of optimization |
lower |
vector of lower boundary values of the parameter space |
upper |
vector of upper boundary of the parameter space |
gfun |
the excitation function. Defaults to the exponential decay function
|
coxseiest
uses only R code; coxseiest2
uses external C
code, and is expected to be 3~4 times fasters than the former;
coxseiest3
assumes the excitation function is the exponential
function as defaulted by the former two, and hardwares it in the C
side of the code, and therefore is much faster than the former two
when the exponential excitation function is desired.
A list as that returned by the call to the optimizer routine. For instance,
par |
gives the estimate of the parameters |
hessian |
gives the inverse of the estimate of the variance-covariance matrix |
the excitation function has to contain exactly two parameters; a feature that does not seem desiable and might change later.
Feng Chen <[email protected]>
Feng Chen and Kani Chen. (2014). Modeling Event Clustering Using the m-Memory Cox-Type Self-Exciting Intensity Model. International Journal of Statistics and Probability. 3(3): 126-137. doi:10.5539/ijsp.v3n3p126 URL: http://dx.doi.org/10.5539/ijsp.v3n3p126
Feng Chen and Kani Chen. (2014). Case-cohort analysis of clusters of recurrent events. 20(1): 1-15. doi: 10.1007/s10985-013-9275-3
See optim
for the components of the returned value
data("dat") ## this takes over 15 minutes ##est0 <- coxseiest(dat,par.init=c(0.2,0.4,0.6,0.6,5)) ## this one takes about 4 minutes ##est1 <- coxseiest2(dat,par.init=c(0.2,0.4,0.6,0.6,5)) ## this one takes about 10 seconds est2 <- coxseiest3(dat,par.init=c(0.2,0.4,0.6,0.6,5))
data("dat") ## this takes over 15 minutes ##est0 <- coxseiest(dat,par.init=c(0.2,0.4,0.6,0.6,5)) ## this one takes about 4 minutes ##est1 <- coxseiest2(dat,par.init=c(0.2,0.4,0.6,0.6,5)) ## this one takes about 10 seconds est2 <- coxseiest3(dat,par.init=c(0.2,0.4,0.6,0.6,5))
fit CoxSEI model using an exponential excitation function
coxseiexp(Y, delta, id, Z, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B",lower=c(rep(-Inf,ncol(Z)),-Inf,0), upper=rep(Inf,ncol(Z) + 2),...)
coxseiexp(Y, delta, id, Z, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B",lower=c(rep(-Inf,ncol(Z)),-Inf,0), upper=rep(Inf,ncol(Z) + 2),...)
Y |
the observed times (including censoring times) |
delta |
indicator of event: 1=event, 0=censoring |
id |
the id of the individual/group the event/censoring corresponds to |
Z |
covariate matrix |
par.init |
initial parameter value to start the iteration |
m |
the lag parameter as in M-dependence |
mit |
maximum number of iteration allowed in maximizing the loag partial likelihood |
tr |
should the optimization process be 'tr'aced |
method |
method of optimization; defaults to "L-BFGS-B" |
lower |
vector of lower boundary values of the parameter space |
upper |
vector of upper boundary of the parameter space |
... |
other arguments to be passed to the optimization routine |
an object of class "coxsei", basically a list with components
coefficients |
a named vector of coefficients |
vcov |
a symmetric matrix which is supposed to be positive definite when m>0, or with the (np-2)x(np-2) major submatrix positive definite when m=0 |
Feng Chen <[email protected]>
Fit a CoxSEI model with exponential function to right censored counting process data
coxseifit.ex(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B",lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2),...)
coxseifit.ex(dat, par.init, m = 2, mit = 1000, tr = TRUE, method = "L-BFGS-B",lower=c(rep(-Inf,ncol(dat)-3),-Inf,0), upper=rep(Inf,ncol(dat)-3 + 2),...)
dat |
The data |
par.init |
initial value of the regression coefficients and coefficients in the excitation function |
m |
the lag parameter (the m-dependence parameter) |
mit |
maximum number of iterations allowed in the optimizer |
tr |
whether to trace the optimization or not |
method |
the method of optimization used by the |
lower |
vector of lower boundary values of the parameter space |
upper |
vector of upper boundary of the parameter space |
... |
other arguments to be passed to the optimization routine |
A list of some components with kind of self-evident meanings by their name
Feng Chen <[email protected]>
data("dat") csfit <- coxseifit.ex(dat,c(1:3*0.2,0.7,10)) coef(csfit) plot(csfit$cintfn,do.points=FALSE)
data("dat") csfit <- coxseifit.ex(dat,c(1:3*0.2,0.7,10)) coef(csfit) plot(csfit$cintfn,do.points=FALSE)
It takes the paramter of the parametric part (or its theorized value) and calculate the values of the estimator at the jump times; it also gives the values of the estimator for the variance of the intensity estimator.
coxseiInt(dat, parest, hessian=NULL, vcovmat=solve(hessian), m = 2, gfun = function(x, pa) { ifelse(x <= 0, 0, pa[1] * pa[2] * exp(-pa[2] * x)) }, gfungrd = function(x, pa){ if(length(x)==0)return(matrix(0,2,0)); rbind(pa[2]*exp(-pa[2]*x), pa[1]*exp(-pa[2]*x)*(1-pa[2]*x) ) })
coxseiInt(dat, parest, hessian=NULL, vcovmat=solve(hessian), m = 2, gfun = function(x, pa) { ifelse(x <= 0, 0, pa[1] * pa[2] * exp(-pa[2] * x)) }, gfungrd = function(x, pa){ if(length(x)==0)return(matrix(0,2,0)); rbind(pa[2]*exp(-pa[2]*x), pa[1]*exp(-pa[2]*x)*(1-pa[2]*x) ) })
dat |
a data frame containing the right-censored counting process data |
parest |
the estimate of parameter of the parametric part of the CoxSEI model |
hessian |
the hessian matrix returned by the optimization procedure in the estimation of the parametric part based on partial likelihood |
vcovmat |
the variance-covariance matrix of the estimator of the the parametric components; defaulted to the inverse of the hessian matrix |
m |
autoregressive order in the excitation part of the intensity |
gfun |
the excitation function; defaults to the exponential decay function |
gfungrd |
derivative/gradient function of the excitation function |
a list giving the jump times and values at these of the estimator of the cumulative baseline intensity function.
x |
the ordered death/event times |
y |
the value of the estimator of the intensity function at the observed death/event times |
varest |
the value of the estimator of the variance of the estimator of the intensity function, at the jump times |
The step function can be obtained using stepfun
, and plotted by setting
type="s"
in the plot
function.
Currently doesn't compute the standard error or variance estimator of the baseline cumulative intensity estimator.
Feng Chen <[email protected]>
data("dat") est <- coxseiest3(dat,c(0.2,0.4,0.6,log(0.06),log(5))) pe <- est$par; pe[4:5] <- exp(pe[4:5]); ve <- diag(pe) %*% solve(est$hessian, diag(pe)); cintest <- coxseiInt(dat,pe,vcovmat=ve) plot(cintest,type="s")
data("dat") est <- coxseiest3(dat,c(0.2,0.4,0.6,log(0.06),log(5))) pe <- est$par; pe[4:5] <- exp(pe[4:5]); ve <- diag(pe) %*% solve(est$hessian, diag(pe)); cintest <- coxseiInt(dat,pe,vcovmat=ve) plot(cintest,type="s")
simulate the sample path of the CoxSEI model with given covariate process values, and excitation function and order of autodependence in the excitation term.
coxseisim(parreg, parg, lmd0 = function(tt) (1 + 0.5 * cos(2 * pi * tt)), g = function(x, parg) { ifelse(x <= 0, 0, parg[1] * parg[2] * exp(-parg[2] * x)) }, censor = 1, m = 2, trace=TRUE, Z = function(x) matrix(0, length(x), length(parreg)) )
coxseisim(parreg, parg, lmd0 = function(tt) (1 + 0.5 * cos(2 * pi * tt)), g = function(x, parg) { ifelse(x <= 0, 0, parg[1] * parg[2] * exp(-parg[2] * x)) }, censor = 1, m = 2, trace=TRUE, Z = function(x) matrix(0, length(x), length(parreg)) )
parreg |
the regression parameter |
parg |
parameters of the excitation function |
lmd0 |
the baseline intensity function |
g |
the excitation function |
censor |
the censoring time |
m |
order of autoregression in the excitation component of the intensity process |
trace |
whether to trace the data generation process; defaults to |
Z |
a function to calculate the covariate values at a specified event time |
A data frame with provided covariate values and the censoring time, and the generated event times.
Feng Chen <[email protected]>
n.smp <- 100; z <- matrix(NA,n.smp,3) for(i in 1:n.smp) z[i,] <- round(c(runif(1,0.5,1.5),runif(1,1.5,2.5),rbinom(1,1,0.5)),2) dat <- coxseisim(1:3*0.2,c(0.07,10),censor=rlnorm(1,0,0.1),m=2, Z=function(x)matrix(z[1,],length(x),3,byrow=TRUE)) dat$id <- 1; for(i in 2:n.smp){ dattmp <- coxseisim(1:3*0.2,c(0.07,10),censor=rlnorm(1,0,0.1),m=2, Z=function(x)matrix(z[i,],length(x),3,byrow=TRUE)) dattmp$id <- i; dat <- rbind(dat,dattmp) }
n.smp <- 100; z <- matrix(NA,n.smp,3) for(i in 1:n.smp) z[i,] <- round(c(runif(1,0.5,1.5),runif(1,1.5,2.5),rbinom(1,1,0.5)),2) dat <- coxseisim(1:3*0.2,c(0.07,10),censor=rlnorm(1,0,0.1),m=2, Z=function(x)matrix(z[1,],length(x),3,byrow=TRUE)) dat$id <- 1; for(i in 2:n.smp){ dattmp <- coxseisim(1:3*0.2,c(0.07,10),censor=rlnorm(1,0,0.1),m=2, Z=function(x)matrix(z[i,],length(x),3,byrow=TRUE)) dattmp$id <- i; dat <- rbind(dat,dattmp) }
Calculate the cumulative/integrated hazard/intensity function
CumInt(x, int, ...)
CumInt(x, int, ...)
x |
the value at which to calculate the cumulative function value |
int |
the intensity/hazard rate function. Has to be vectorized. |
... |
the arguments to be passed in to control the behavior of the
underlying |
Relies on the numerical integration routine of R.
The value(s) of the cumulative hazard function at the specified
x
value(s).
The validity of the user supplied intensity function is not checked.
Not intended to be called by the user directly.
Feng Chen <[email protected]>
curve(CumInt(x,int=function(y)1*( y>=0 & y<2)+3*(y>=2 & y<3)+1*(y>=3)), 0,5,xlab="t",ylab="H(t) of a piece-wise constant hazard fun h(t)")
curve(CumInt(x,int=function(y)1*( y>=0 & y<2)+3*(y>=2 & y<3)+1*(y>=3)), 0,5,xlab="t",ylab="H(t) of a piece-wise constant hazard fun h(t)")
Simulated from a CoxSEI model with an exponential excitation function
and an AR order 2 for the self-excitation effects. Generated using the
following code:
set.seed(1);
n.smp <- 50;
z <- matrix(NA,n.smp,3);
for(i in 1:n.smp)
z[i,] <- round(c(runif(1,0.5,1.5),runif(1,1.5,2.5),rbinom(1,1,0.5)),2);
dat <- coxseisim(1:3*0.2,c(0.07,10),censor=rlnorm(1,0,0.1),m=2,
Z=function(x)matrix(z[1,],length(x),3,byrow=T));
dat$id <- 1;
for(i in 2:n.smp){
dattmp <- coxseisim(1:3*0.2,c(0.07,10),censor=rlnorm(1,0,0.1),m=2,
Z=function(x)matrix(z[i,],length(x),3,byrow=T))
dattmp$id <- i;
dat <- rbind(dat,dattmp)
}
data(dat)
data(dat)
A data frame with 307 observations on the following 6 variables.
Y
a numeric vector
delta
a numeric vector
Z.1
a numeric vector
Z.2
a numeric vector
Z.3
a numeric vector
id
a numeric vector
data(dat) ## maybe str(dat) ; plot(dat) ...
data(dat) ## maybe str(dat) ; plot(dat) ...
Evaluate the density function corresponding to the specified
intensity/hazard function int
.
Dens(x, int, ...)
Dens(x, int, ...)
x |
the value at which to evaluate the density function |
int |
the intensity/hazard function. Has to be vectorized. |
... |
other arguments to be passed to the underlying integrator |
A numerical value or vector giving the value(s) of the density function
Relies on R's integrate
function
Feng Chen <[email protected]>
set.seed(1); dat <- RND(1000,int=function(x)3*x^2) hist(dat,freq=FALSE); curve(Dens(x,int=function(x)3*x^2),add=TRUE)
set.seed(1); dat <- RND(1000,int=function(x)3*x^2) hist(dat,freq=FALSE); curve(Dens(x,int=function(x)3*x^2),add=TRUE)
Calculate the value at x
of the distribution function associated with
the intensity/hazard function probived through int
.
Dist(x, int, ...)
Dist(x, int, ...)
x |
the value to evaluate the distribution function at. |
int |
vectorized function specifying the intensity/hazard function |
... |
arguments to be passed to the |
A number between 0 and 1 inclusive, that gives the value of the
distribution function at the specified x
value.
Feng Chen <[email protected]>
curve(Dist(x,int=function(x)3*x^2),0,5) curve(pweibull(x,shape=3),0,5,add=TRUE,col=3,lty=3)
curve(Dist(x,int=function(x)3*x^2),0,5) curve(pweibull(x,shape=3),0,5,add=TRUE,col=3,lty=3)
calculates the value of the quantile function (inverse of the distribution function) of the survival variable with given intensity/hazard function.
Quant(p, int, tolerance = .Machine$double.eps, ...)
Quant(p, int, tolerance = .Machine$double.eps, ...)
p |
the (probability) values to calculate the quantiles at |
int |
the intensity/hazard function. Has to be vectorized. |
tolerance |
tolerated numerical error in inverting the distribution function. |
... |
arguments to be passed to |
a numerical value or vector giving the values of the quantile function
at x
Feng Chen <[email protected]>
curve(Quant(x,int=function(x)3*x^2),from=1e-3,to=1 - 1e-3) curve(qweibull(x,shape=3),col=3,lty=3,add=TRUE)
curve(Quant(x,int=function(x)3*x^2),from=1e-3,to=1 - 1e-3) curve(qweibull(x,shape=3),col=3,lty=3,add=TRUE)
RND takes a vectorized positive R function defined on positive reals
and returns a vector of n
values of the random variable
(survival time) with the specifed function as its hazard/intensity
rate function.
RND(n, int, tol = .Machine$double.eps^0.5, epsabs = 1e-10, epsrel = 1e-10, limit = 1000)
RND(n, int, tol = .Machine$double.eps^0.5, epsabs = 1e-10, epsrel = 1e-10, limit = 1000)
n |
number of observations. |
int |
hazard rate function of the survival variable, or the intensity function of the one-event point process counting the number (0 or 1) of deaths by following a sample of the surviving suject. |
tol |
tolerance of the numerical error in calculating the inverse of the cumulative distribution function of the survival variable. Defaults to the square root of the machine epsilon. |
epsabs |
maximum absolute error to be tolerated by the integrator. |
epsrel |
maximum relative error to be tolerated by the integrator. |
limit |
maximum number of iterations permitted by the integrator. |
a vector of n
observations of the survival variable with the
supplied intensity/hazard function.
Feng Chen <[email protected]>
set.seed(1) dat <- RND(100,int=function(x)x^2) ks.test(dat,pweibull,shape=3) # p-value = 0.6058 qqplot(dat,rweibull(100,shape=3))
set.seed(1) dat <- RND(100,int=function(x)x^2) ks.test(dat,pweibull,shape=3) # p-value = 0.6058 qqplot(dat,rweibull(100,shape=3))
Evaluate the survival function corresponding to the given intensity/hazard function.
Surv(x, int, ...)
Surv(x, int, ...)
x |
value to calculate the value of the survival function for |
int |
the intensity/hazard function |
... |
further arguments to be passed to |
a numerical value or vector giving the value(s) of the survival
function at x
Feng Chen <[email protected]>
curve(Surv(x, int=function(x)3*x^2), from=0, to=5) curve(pweibull(x,shape=3,lower=FALSE), add=TRUE, col=2, lty=3)
curve(Surv(x, int=function(x)3*x^2), from=0, to=5) curve(pweibull(x,shape=3,lower=FALSE), add=TRUE, col=2, lty=3)