Recurrent Event Data Analysis

Introduction
Recurrent Event Data Analysis (RDA) is used in various applied fields such as reliability, medicine, social sciences, economics, business and criminology.

Whereas in life data analysis (LDA) it was assumed that events (failures) were independent and identically distributed (iid), there are many cases where events are dependent and not identically distributed (such as repairable system data) or where the analyst is interested in modeling the number of occurrences of events over time rather than the length of time prior to the first event, as in LDA.

Weibull++ provides both parametric and non-parametric approaches to analyze such data.


 * The non-parametric approach is based on the well-known Mean Cumulative Function (MCF). The Weibull++ module for this type of analysis builds upon the work of Dr. Wayne Nelson, who has written extensively on the calculation and applications of MCF [31].


 * The parametric approach is based on the General Renewal Process (GRP) model, which is particularly useful in understanding the effects of the repairs on the age of a system. Traditionally, the commonly used models for analyzing repairable systems data are the perfect renewal processes (PRP), which corresponds to perfect repairs, and the nonhomogeneous Poisson processes (NHPP), which corresponds to minimal repairs. However, most repair activities may realistically not result in such extreme situations but in a complicated intermediate one (general repair or imperfect repair/maintenance), which are well treated with the GRP model.

Non-Parametric Recurrent Event Data Analysis
Non-parametric RDA provides a non-parametric graphical estimate of the mean cumulative number or cost of recurrence per unit versus age. In the reliability field, the Mean Cumulative Function (MCF) can be used to: [31]


 * Evaluate whether the population repair (or cost) rate increases or decreases with age (this is useful for product retirement and burn-in decisions).
 * Estimate the average number or cost of repairs per unit during warranty or some time period.
 * Compare two or more sets of data from different designs, production periods, maintenance policies, environments, operating conditions, etc.
 * Predict future numbers and costs of repairs, such as the expected number of failures next month, quarter, or year.
 * Reveal unexpected information and insight.

The Mean Cumulative Function (MCF)
In a non-parametric analysis of recurrent event data, each population unit can be described by a cumulative history function for the cumulative number of recurrences. It is a staircase function that depicts the cumulative number of recurrences of a particular event, such as repairs over time. The figure below depicts a unit's cumulative history function.



The non-parametric model for a population of units is described as the population of cumulative history functions (curves). It is the population of all staircase functions of every unit in the population. At age t, the units have a distribution of their cumulative number of events. That is, a fraction of the population has accumulated 0 recurrences, another fraction has accumulated 1 recurrence, another fraction has accumulated 2 recurrences, etc. This distribution differs at different ages t, and has a mean M(t) called the mean cumulative function (MCF). The M(t) is the point-wise average of all population cumulative history functions (see figure below).



For the case of uncensored data, the mean cumulative function $$M{{(t)}_{i}}\ $$ values at different recurrence ages ti are estimated by calculating the average of the cumulative number of recurrences of events for each unit in the population at ti. When the histories are censored, the following steps are applied.

1st Step - Order all ages:

Order all recurrence and censoring ages from smallest to largest. If a recurrence age for a unit is the same as its censoring (suspension) age, then the recurrence age goes first. If multiple units have a common recurrence or censoring age, then these units could be put in a certain order or be sorted randomly.

2nd Step - Calculate the number, ri, of units that passed through age ti :


 * $$\begin{align}

& {{r}_{i}}= & {{r}_{i-1}}\quad \quad \text{if }{{t}_{i}}\text{ is a recurrence age} \\ & {{r}_{i}}= & {{r}_{i-1}}-1\text{  if }{{t}_{i}}\text{ is a censoring age} \end{align}$$

N is the total number of units and r1 = N at the first observed age which could be a recurrence or suspension.

3rd Step - Calculate the MCF estimate, M*(t):

For each sample recurrence age ti, calculate the mean cumulative function estimate as follows


 * $${{M}^{*}}({{t}_{i}})=\frac{1}+{{M}^{*}}({{t}_{i-1}})$$

where $${{M}^{*}}(t)=\tfrac{1}$$ at the earliest observed recurrence age, t1.

Example 1:

Confidence Limits for the MCF
Upper and lower confidence limits for $$M({{t}_{i}})$$  are:


 * $$\begin{align}

& {{M}_{U}}({{t}_{i}})= {{M}^{*}}({{t}_{i}}).{{e}^{\tfrac{{{K}_{\alpha }}.\sqrt{Var[{{M}^{*}}({{t}_{i}})]}}{{{M}^{*}}({{t}_{i}})}}} \\ & {{M}_{L}}({{t}_{i}})= \frac{{{M}^{*}}({{t}_{i}})} \end{align}$$

where $$\alpha $$  ( $$50%<\alpha <100%$$ ) is  confidence level,  $${{K}_{\alpha }}$$  is the  $$\alpha $$  standard normal percentile and  $$Var[{{M}^{*}}({{t}_{i}})]$$  is the variance of the MCF estimate at recurrence age  $${{t}_{i}}$$. The variance is calculated as follows:


 * $$Var[{{M}^{*}}({{t}_{i}})]=Var[{{M}^{*}}({{t}_{i-1}})]+\frac{1}{r_{i}^{2}}\left[ \underset{j\in {{R}_{i}}}{\overset{}{\mathop \sum }}\,{{\left( {{d}_{ji}}-\frac{1}{{{r}_{i}}} \right)}^{2}} \right]$$

where $${r}_{i}$$  is defined in the equation of the survivals,  $${{R}_{i}}$$   is the set of the units that have not been suspended by  $$i$$  and  $${{d}_{ji}}$$  is defined as follows:


 * $$\begin{align}

& {{d}_{ji}}= 1\text{ if the }{{j}^{\text{th }}}\text{unit had an event recurrence at age }{{t}_{i}} \\ & {{d}_{ji}}= 0\text{  if the }{{j}^{\text{th }}}\text{unit did not have an event reoccur at age }{{t}_{i}} \end{align}$$

Example 2:

Example 3:

Parametric Recurrent Event Data Analysis
Weibull++'s parametric RDA folio is a tool for modeling recurrent event data. It can capture the trend, estimate the rate and predict the total number of recurrences. The failure and repair data of a repairable system can be treated as one type of recurrence data. Past and current repairs may affect the future failure process. For most recurrent events, time (distance, cycles, etc.) is a key factor. With time, the recurrence rate may remain constant, increase or decrease. For other recurrent events, not only the time, but also the number of events can affect the recurrence process (e.g., the debugging process in software development). The parametric analysis approach utilizes the General Renewal Process (GRP) model [28]. In this model, the repair time is assumed to be negligible so that the processes can be viewed as point processes. This model provides a way to describe the rate of occurrence of events over time, such as in the case of data obtained from a repairable system. This model is particularly useful in modeling the failure behavior of a specific system and understanding the effects of the repairs on the age of that system. For example, consider a system that is repaired after a failure, where the repair does not bring the system to an as-good-as-new or an as-bad-as-old condition. In other words, the system is partially rejuvenated after the repair. Traditionally, in as-bad-as-old repairs, also known as minimal repairs, the failure data from such a system would have been modeled using a homogeneous or non-homogeneous Poisson process (NHPP). On rare occasions, a Weibull distribution has been used as well in cases where the system is almost as-good-as-new after the repair, also known as a perfect renewal process (PRP). However, for the intermediate states after the repair, there has not been a commercially available model, even though many models have been proposed in literature. In Weibull++, the GRP model provides the capability to model systems with partial renewal (general repair or imperfect repair/maintenance) and allows for a variety of predictions such as reliability, expected failures, etc.

The GRP Model
In this model, the concept of virtual age is introduced. Let $${{t}_{1}},{{t}_{2}},\cdots ,{{t}_{n}}$$ represent the successive failure times and let $${{x}_{1}},{{x}_{2}},\cdots ,{{x}_{n}}$$ represent the time between failures ( $${{t}_{i}}=\sum_{j=1}^{i}{{x}_{j}})$$. Assume that after each event, actions are taken to improve the system performance. Let q be the action effectiveness factor. There are two GRP models:

Type I:


 * vi = vi − 1 + q'x'undefined = qti

Type II:


 * $${{v}_{i}}=q({{v}_{i-1}}+{{x}_{i}})={{q}^{i}}{{x}_{1}}+{{q}^{i-1}}{{x}_{2}}+\cdots +{{x}_{i}}$$

where vi is the virtual age of the system right after i th repair. The Type I model assumes that the i th repair cannot remove the damage incurred before the ith failure. It can only reduce the additional age xi to q'xi. The Type II model assumes that at the i th repair, the virtual age has been accumulated to vi − 1 + xi. The i th repair will remove the cumulative damage from both current and previous failures by reducing the virtual age to q(vi − 1 + xi).

The power law function is used to model the rate of recurrence, which is:


 * λ(t) = λβtβ − 1

The conditional pdf is:


 * $$f({{t}_{i}}|{{t}_{i-1}})=\lambda \beta {{({{x}_{i}}+{{v}_{i-1}})}^{\beta -1}}{{e}^{-\lambda \left[ {{\left( {{x}_{i}}+{{v}_{i-1}} \right)}^{\beta }}-v_{i-1}^{\beta } \right]}}$$

MLE method is used to estimate the model parameters. The log likelihood function is [28]:


 * $$\begin{align}

& \ln (L)= n(\ln \lambda +\ln \beta )-\lambda \left[ {{\left( T-{{t}_{n}}+{{v}_{n}} \right)}^{\beta }}-v_{n}^{\beta } \right] \\ & -\lambda \underset{i=1}{\overset{n}{\mathop \sum }}\,\left[ {{\left( {{x}_{i}}+{{v}_{i-1}} \right)}^{\beta }}-v_{i}^{\beta } \right]+(\beta -1)\underset{i=1}{\overset{n}{\mathop \sum }}\,\ln ({{x}_{i}}+{{v}_{i-1}}) \end{align}$$

where n is the total number of events during the entire observation period. T is the stop time of the observation. T = tn if the observation stops right after the last event.

Confidence Bounds
In general, in order to obtain the virtual age, the exact occurrence time of each event (failure) should be available (see equations for Type I and Type II models). However, the times are unknown until the corresponding events occur. For this reason, there are no closed-form expressions for total failure number and failure intensity, which are functions of failure times and virtual age. Therefore, in Weibull++, a Monte Carlo simulation is used to predict values of virtual time, failure number, MTBF and failure rate. The approximate confidence bounds obtained from simulation are provided. The uncertainty of model parameters is also considered in the bounds.

Bounds on Cumulative Failure (Event) Numbers
The variance of the cumulative failure number N(t) is:


 * $$Var[N(t)]=Var\left[ E(N(t)|\lambda ,\beta ,q) \right]+E\left[ Var(N(t)|\lambda ,\beta ,q) \right]$$

The first term accounts for the uncertainty of the parameter estimation. The second term considers the uncertainty caused by the renewal process even when model parameters are fixed. However, unless q = 1, $$Var\left[ E(N(t)|\lambda ,\beta ,q) \right]$$ cannot be calculated because E(N(t)) cannot be expressed as a closed-form function of λ,β, and q. In order to consider the uncertainty of the parameter estimation, $$Var\left[ E(N(t)|\lambda ,\beta ,q) \right]$$ is approximated by:


 * $$Var\left[ E(N(t)|\lambda ,\beta ,q) \right]=Var[E(N({{v}_{t}})|\lambda ,\beta )]=Var[\lambda v_{t}^{\beta }]$$

where vt is the expected virtual age at time t and $$Var[\lambda v_{t}^{\beta }]$$ is::


 * $$\begin{align}

& Var[\lambda v_{t}^{\beta }]= & {{\left( \frac{\partial (\lambda v_{t}^{\beta })}{\partial \beta } \right)}^{2}}Var(\hat{\beta })+{{\left( \frac{\partial (\lambda v_{t}^{\beta })}{\partial \lambda } \right)}^{2}}Var(\hat{\lambda }) \\ & +2\frac{\partial (\lambda v_{t}^{\beta })}{\partial \beta }\frac{\partial (\lambda v_{t}^{\beta })}{\partial \lambda }Cov(\hat{\beta },\hat{\lambda }) \end{align}$$

By conducting this approximation, the uncertainty of λ and β are considered. The value of vt and the value of the second term in the equation for the variance of number of failures are obtained through the Monte Carlo simulation using parameters $$\hat{\lambda },\hat{\beta },\hat{q},$$ which are the ML estimators. The same simulation is used to estimate the cumulative number of failures $$\hat{N}(t)=E(N(t)|\hat{\lambda },\hat{\beta },\hat{q})$$.

Once the variance and the expected value of N(t) have been obtained, the bounds can be calculated by assuming that N(t) is lognormally distributed as:


 * $$\frac{\ln N(t)-\ln \hat{N}(t)}{\sqrt{Var(\ln N(t))}}\tilde{\ }N(0,1)$$

The upper and lower bounds for a given confidence level α can be calculated by:


 * $$N{{(t)}_{U,L}}=\hat{N}(t){{e}^{\pm {{z}_{a}}\sqrt{Var(N(t))}/\hat{N}(t)}}$$

where za is the standard normal distribution.

If N(t) is assumed to be normally distributed, the bounds can be calculated by:


 * $$N{{(t)}_{U}}=\hat{N}(t)+{{z}_{a}}\sqrt{Var(N(t))}$$


 * $$N{{(t)}_{L}}=\hat{N}(t)-{{z}_{a}}\sqrt{Var(N(t))}$$

In Weibull++, the N(t)U is the smaller of the upper bounds obtained from lognormal and normal distribution appoximation. The N(t)L is set to the largest of the lower bounds obtained from lognormal and normal distribution appoximation. This combined method can prevent the out-of-range values of bounds for some small t values.

Bounds of Cumulative Failure Intensity and MTBF
For a given time t, the expected value of cumulative MTBF mc(t) and cumulative failure intensity λc(t) can be calculated using the following equations:


 * $${{\hat{\lambda }}_{c}}(t)=\frac{\hat{N}(t)}{t};{{\hat{m}}_{c}}(t)=\frac{t}{\hat{N}(t)}$$

The bounds can be easily obtained from the corresponding bounds of N(t).


 * $$\begin{align}

& {{{\hat{\lambda }}}_{c}}{{(t)}_{L}}= & \frac{\hat{N}{{(t)}_{L}}}{t};\text{ }{{{\hat{\lambda }}}_{c}}{{(t)}_{L}}=\frac{\hat{N}{{(t)}_{L}}}{t};\text{  } \\ & {{{\hat{m}}}_{c}}{{(t)}_{L}}= & \frac{t}{\hat{N}{{(t)}_{U}}};\text{ }{{{\hat{m}}}_{c}}{{(t)}_{U}}=\frac{t}{\hat{N}{{(t)}_{L}}} \end{align}$$

Bounds on Instantaneous Failure Intensity and MTBF
The instantaneous failure intensity is given by:


 * $${{\lambda }_{i}}(t)=\lambda \beta v_{t}^{\beta -1}$$

where vt is the virtual age at time t. When $$q\ne 1,$$ it is obtained from simulation. When q = 1, vt = t from model Type I and Type II.

The variance of instantaneous failure intensity can be calculated by:


 * $$\begin{align}

& Var({{\lambda }_{i}}(t))= {{\left( \frac{\partial {{\lambda }_{i}}(t)}{\partial \beta } \right)}^{2}}Var(\hat{\beta })+{{\left( \frac{\partial {{\lambda }_{i}}(t)}{\partial \lambda } \right)}^{2}}Var(\hat{\lambda }) \\ & +2\frac{\partial {{\lambda }_{i}}(t)}{\partial \beta }\frac{\partial {{\lambda }_{i}}(t)}{\partial \lambda }Cov(\hat{\beta },\hat{\lambda })+{{\left( \frac{\partial {{\lambda }_{i}}(t)}{\partial v(t)} \right)}^{2}}Var({{{\hat{v}}}_{t}}) \end{align}$$

The expected value and variance of vt are obtained from the Monte Carlo simulation with parameters $$\hat{\lambda },\hat{\beta },\hat{q}.$$ Because of the simulation accuracy and the convergence problem in calculation of $$Var(\hat{\beta }),Var(\hat{\lambda })$$ and $$Cov(\hat{\beta },\hat{\lambda }),$$ V'a'r(λi(t)) can be a negative value at some time points. When this case happens, the bounds of instantaneous failure intensity are not provided.

Once the variance and the expected value of λi(t) are obtained, the bounds can be calculated by assuming that λi(t) is lognormally distributed as:


 * $$\frac{\ln {{\lambda }_{i}}(t)-\ln {_{i}}(t)}{\sqrt{Var(\ln {{\lambda }_{i}}(t))}}\tilde{\ }N(0,1)$$

The upper and lower bounds for a given confidence level α can be calculated by:


 * $${{\lambda }_{i}}(t)={{\hat{\lambda }}_{i}}(t){{e}^{\pm {{z}_{a}}\sqrt{Var({{\lambda }_{i}}(t))}/{_{i}}(t)}}$$

where za is the standard normal distribution.

If λi(t) is assumed to be normally distributed, the bounds can be calculated by:


 * $${{\lambda }_{i}}{{(t)}_{U}}={{\hat{\lambda }}_{i}}(t)+{{z}_{a}}\sqrt{Var(N(t))}$$


 * $${{\lambda }_{i}}{{(t)}_{L}}={{\hat{\lambda }}_{i}}(t)-{{z}_{a}}\sqrt{Var(N(t))}$$

In Weibull++, λi(t)U is set to the smaller of the two upper bounds obtained from the above lognormal and normal distribution appoximation. λi(t)L is set to the largest of the two lower bounds obtained from the above lognormal and normal distribution appoximation. This combination method can prevent the out of range values of bounds when t values are small.

For a given time t, the expected value of cumulative MTBF mi(t) is:


 * $${{\hat{m}}_{i}}(t)=\frac{1}{{{{\hat{\lambda }}}_{i}}(t)}\text{ }$$

The upper and lower bounds can be easily obtained from the corresponding bounds of λi(t):


 * $${{\hat{m}}_{i}}{{(t)}_{U}}=\frac{1}{{{{\hat{\lambda }}}_{i}}{{(t)}_{L}}}$$


 * $${{\hat{m}}_{i}}{{(t)}_{L}}=\frac{1}{{{{\hat{\lambda }}}_{i}}{{(t)}_{U}}}$$

Bounds on Conditional Reliability
Given mission start time t0 and mission time T, the conditional reliability can be calculated by:


 * $$R(T|{{t}_{0}})=\frac{R(T+{{v}_{0}})}{R({{v}_{0}})}={{e}^{-\lambda [{{({{v}_{0}}+T)}^{\beta }}-{{v}_{0}}]}}$$

v0 is the virtual age corresponding to time t0. The expected value and the variance of v0 are obtained from Monte Carlo simulation. The variance of the conditional reliability R(T | t0) is:


 * $$\begin{align}

& Var(R)= {{\left( \frac{\partial R}{\partial \beta } \right)}^{2}}Var(\hat{\beta })+{{\left( \frac{\partial R}{\partial \lambda } \right)}^{2}}Var(\hat{\lambda }) \\ & +2\frac{\partial R}{\partial \beta }\frac{\partial R}{\partial \lambda }Cov(\hat{\beta },\hat{\lambda })+{{\left( \frac{\partial R}{\partial {{v}_{0}}} \right)}^{2}}Var({{{\hat{v}}}_{0}}) \end{align}$$

Because of the simulation accuracy and the convergence problem in calculation of $$Var(\hat{\beta }),Var(\hat{\lambda })$$ and $$Cov(\hat{\beta },\hat{\lambda }),$$ V'a'r(R) can be a negative value at some time points. When this case happens, the bounds are not provided.

The bounds are based on:


 * $$\log \text{it}(\hat{R}(T))\tilde{\ }N(0,1)$$


 * $$\log \text{it}(\hat{R}(T))=\ln \left\{ \frac{\hat{R}(T)}{1-\hat{R}(T)} \right\}$$

The confidence bounds on reliability are given by:


 * $$R=\frac{\hat{R}+(1-\hat{R}){{e}^{\pm \sqrt{Var(R)}/[\hat{R}(1-\hat{R})]}}}$$

It will be compared with the bounds obtained from:


 * $$R=\hat{R}{{e}^{\pm {{z}_{a}}\sqrt{Var(R)}/\hat{R}}}$$

The smaller of the two upper bounds will be the final upper bound and the larger of the two lower bounds will be the final lower bound.

Example 4: Air Condition Unit Example