Title: | Inference for Phase-Type Distributions |
---|---|
Description: | Functions to perform Bayesian inference on absorption time data for Phase-type distributions. The methods of Bladt et al (2003) <doi:10.1080/03461230110106435> and Aslett (2012) <https://www.louisaslett.com/PhD_Thesis.pdf> are provided. |
Authors: | Louis Aslett [aut, cre], Wally Gilks [ctb] |
Maintainer: | Louis Aslett <[email protected]> |
License: | GPL-2 | GPL-3 |
Version: | 0.3.0 |
Built: | 2025-01-17 06:08:29 UTC |
Source: | https://github.com/louisaslett/PhaseType |
A collection of tools for working with Phase-type Distributions, including sampling methods and both frequentist and Bayesian inference.
Package: | PhaseType |
Type: | Package |
Version: | 0.2.1 |
Date: | 2011-10-12 |
License: | GPL-2 | GPL-3 |
LazyLoad: | yes |
Louis J. M. Aslett, [email protected] (https://www.louisaslett.com)
Aslett, L. J. M. (2012), MCMC for Inference on Phase-type and Masked System Lifetime Models. Ph.D. thesis, Trinity College Dublin..
Bladt, M., Gonzalez, A. & Lauritzen, S. L. (2003), ‘The estimation of phase-type related functionals using Markov chain Monte Carlo methods’, Scandinavian Journal of Statistics 2003(4), 280-300.
library(actuar) # Define the S matrix (columnwise) S <- matrix(c(-3.6, 9.5, 9.5, 1.8, -11.3, 0, 1.8, 0, -11.3), 3) # Define starting state distribution pi <- c(1, 0, 0) # Generate 50 random absorption times from the Phase-type with subgenerator S # and starting distribution pi, which we will try to infer next x <- rphtype(50, pi, S) library(PhaseType) # FIRST: descriptive model fit (Bladt et al. 2003) # Prior on starting state dirpi <- c(1, 0, 0) # Gamma prior: shape hyperparameters (one per matrix element, columnwise) nu <- c(24, 24, 1, 180, 1, 24, 180, 1, 24) # Gamma prior: reciprocal scale hyperparameters (one per matrix row) zeta <- c(16, 16, 16) # Define dimension of model to fit n <- 3 # Perform 20 MCMC iterations (fix inner Metropolis-Hastings to one iteration # since starts in stationarity here). Do more in practise!! res1 <- phtMCMC(x, n, dirpi, nu, zeta, 20, mhit=1) print(res1) plot(res1) # SECOND: mechanistic model fit (Aslett and Wilson 2011) # Prior on starting state dirpi <- c(1, 0, 0) # Define the structure of the Phase-type generator TT <- matrix(c(0,"R","R",0,"F",0,0,0,"F",0,0,0,0,"F","F",0), 4) # Gamma prior: shape hyperparameters (one per model parameter) nu <- list("R"=180, "F"=24) # Gamma prior: reciprocal scale hyperparameters (one per model parameter) zeta <- c("R"=16,"F"=16) # Perform 20 MCMC iterations. Do more in practise!! res2 <- phtMCMC2(x, TT, dirpi, nu, zeta, 20) print(res2) plot(res2)
library(actuar) # Define the S matrix (columnwise) S <- matrix(c(-3.6, 9.5, 9.5, 1.8, -11.3, 0, 1.8, 0, -11.3), 3) # Define starting state distribution pi <- c(1, 0, 0) # Generate 50 random absorption times from the Phase-type with subgenerator S # and starting distribution pi, which we will try to infer next x <- rphtype(50, pi, S) library(PhaseType) # FIRST: descriptive model fit (Bladt et al. 2003) # Prior on starting state dirpi <- c(1, 0, 0) # Gamma prior: shape hyperparameters (one per matrix element, columnwise) nu <- c(24, 24, 1, 180, 1, 24, 180, 1, 24) # Gamma prior: reciprocal scale hyperparameters (one per matrix row) zeta <- c(16, 16, 16) # Define dimension of model to fit n <- 3 # Perform 20 MCMC iterations (fix inner Metropolis-Hastings to one iteration # since starts in stationarity here). Do more in practise!! res1 <- phtMCMC(x, n, dirpi, nu, zeta, 20, mhit=1) print(res1) plot(res1) # SECOND: mechanistic model fit (Aslett and Wilson 2011) # Prior on starting state dirpi <- c(1, 0, 0) # Define the structure of the Phase-type generator TT <- matrix(c(0,"R","R",0,"F",0,0,0,"F",0,0,0,0,"F","F",0), 4) # Gamma prior: shape hyperparameters (one per model parameter) nu <- list("R"=180, "F"=24) # Gamma prior: reciprocal scale hyperparameters (one per model parameter) zeta <- c("R"=16,"F"=16) # Perform 20 MCMC iterations. Do more in practise!! res2 <- phtMCMC2(x, TT, dirpi, nu, zeta, 20) print(res2) plot(res2)
Markov-chain Monte Carlo (MCMC) sampler for Bayesian inference on Phase-type models where data consist solely of time to entering the absorbing state (Bladt et al., 2003).
Consider an m+1 state continuous-time Markov chain (CTMC) where the final (m+1 st) state is absorbing. Then, given data consisting of first passage times to the last state, this function performs Bayesian inference on the rate parameters of the latent continuous-time Markov chain where the generator is assumed to be dense and all rates independent.
phtMCMC(x, states, beta, nu, zeta, n, mhit=1, resume=NULL, silent=FALSE)
phtMCMC(x, states, beta, nu, zeta, n, mhit=1, resume=NULL, silent=FALSE)
x |
a vector of absorption times (or times at which censoring occurs). |
states |
an integer describing how many states (ie what dimension) the fitted Phase-type's generator should be. |
beta |
a vector of length m representing the Dirichlet prior on the starting state of the latent continuous-time Markov chain. Entries should sum to 1. |
nu |
a list of the Gamma shape hyper-parameters for the prior of each parameter in the continuous-time Markov chain. These should match the dense generator matrix filled column-wise. |
zeta |
a list of the Gamma reciprocal scale hyper-parameters for the prior of each parameter in the continuous-time Markov chain. These should match the dense generator matrix, with one zeta value per row. |
n |
the total number of MCMC iterations to compute. |
mhit |
the number of Metropolis-Hastings iterations to perform when sampling the latent process. |
resume |
|
silent |
setting to |
Usage of this function effectively involves specification of the number of states for the CTMC generator matrix, the parameter priors in Gamma form and providing absorption time data.
If you want to specify structure on your generator (for example, to model a stochastic process about which some underlying mechanism is known), then consider using phtMCMC2
instead. This function is best illustrated by the example below which is more fully discussed on this webpage.
phtMCMC
returns an object of class "phtMCMC"
.
An object of class "phtMCMC"
is a list containing at least the following components:
samples |
an object of class |
data |
a vector containing the original data used in the inference. |
vars |
a list of the distinct variable names in the CTMC generator. |
TT |
the naming scheme for the generator which was fitted. |
beta |
the Dirichlet prior probability mass function on the starting states. |
nu |
a list of the prior nu hyper-parameters used when phtMCMC2 was called. |
zeta |
a list of the prior zeta hyper-parameters used when phtMCMC2 was called. |
iterations |
the number of MCMC iterations contained in the object. |
MHit |
the number of iterations used if |
Please feel free to email [email protected] with any queries or if you encounter errors when running this function.
Louis J.M. Aslett [email protected] (https://www.louisaslett.com/)
Bladt, M., Gonzalez, A. and Lauritzen, S. L. (2003), ‘The estimation of Phase-type related functionals using Markov chain Monte Carlo methods’, Scandinavian Actuarial Journal 2003(4), 280-300.
# Some pre-simulated absorption times x <- c(1.45353415045187, 1.85349532001349, 2.01084961814576, 0.505725921290172, 1.56252630012213, 3.41158665930278, 1.52674487509487, 4.3428662377235, 8.03208018151311, 2.41746547476986, 0.38828086509283, 2.61513815012196, 3.39148865480856, 1.82705817807965, 1.42090953713845, 0.851438991331866, 0.0178808867191894, 0.632198596390046, 0.959910259815998, 1.83344199966323) # Prior on starting state dirpi <- c(1, 0, 0) # Gamma prior: shape hyperparameters (one per matrix element, columnwise) nu <- c(24, 24, 1, 180, 1, 24, 180, 1, 24) # Gamma prior: reciprocal scale hyperparameters (one per matrix row) zeta <- c(16, 16, 16) # Define dimension of model to fit n <- 3 # Perform 20 MCMC iterations (fix inner Metropolis-Hastings to one iteration # since starts in stationarity here). Do more in practice! res <- phtMCMC(x, n, dirpi, nu, zeta, 6, mhit=1) print(res) plot(res)
# Some pre-simulated absorption times x <- c(1.45353415045187, 1.85349532001349, 2.01084961814576, 0.505725921290172, 1.56252630012213, 3.41158665930278, 1.52674487509487, 4.3428662377235, 8.03208018151311, 2.41746547476986, 0.38828086509283, 2.61513815012196, 3.39148865480856, 1.82705817807965, 1.42090953713845, 0.851438991331866, 0.0178808867191894, 0.632198596390046, 0.959910259815998, 1.83344199966323) # Prior on starting state dirpi <- c(1, 0, 0) # Gamma prior: shape hyperparameters (one per matrix element, columnwise) nu <- c(24, 24, 1, 180, 1, 24, 180, 1, 24) # Gamma prior: reciprocal scale hyperparameters (one per matrix row) zeta <- c(16, 16, 16) # Define dimension of model to fit n <- 3 # Perform 20 MCMC iterations (fix inner Metropolis-Hastings to one iteration # since starts in stationarity here). Do more in practice! res <- phtMCMC(x, n, dirpi, nu, zeta, 6, mhit=1) print(res) plot(res)
Markov-chain Monte Carlo (MCMC) sampler for Bayesian inference on Phase-type models where data consist solely of time to entering the absorbing state (Aslett and Wilson, 2011, and Aslett, 2012).
Consider an m+1 state continuous-time Markov chain (CTMC) where the final (m+1 st) state is absorbing. Then, given data consisting of first passage times to the last state, this function performs Bayesian inference on the rate parameters of the latent continuous-time Markov chain where the generator has some fixed structure.
phtMCMC2(x, TT, beta, nu, zeta, n, censored=rep(FALSE, length(x)), C=matrix(1.0, nrow=dim(TT)[1], ncol=dim(TT)[2]), method="ECS", mhit=1, resume=NULL, silent=FALSE)
phtMCMC2(x, TT, beta, nu, zeta, n, censored=rep(FALSE, length(x)), C=matrix(1.0, nrow=dim(TT)[1], ncol=dim(TT)[2]), method="ECS", mhit=1, resume=NULL, silent=FALSE)
x |
a vector of absorption times (or times at which censoring occurs). |
TT |
a matrix describing the structure of the Phase-type distribution to be used in the inference. Each element of the matrix should either be a string for the variable name, or zero to indicate the transition there is prohibited. See Details and Examples sections below. |
beta |
a vector of length m representing the Dirichlet prior on the starting state of the latent continuous-time Markov chain. Entries should sum to 1. |
nu |
a list of the Gamma shape hyper-parameters for the prior of each parameter in the continuous-time Markov chain. The |
zeta |
a list of the Gamma reciprocal scale hyper-parameters for the prior of each parameter in the continuous-time Markov chain. The |
n |
the total number of MCMC iterations to compute. |
censored |
a vector of |
C |
a numeric matrix of the same dimensions as |
method |
the sampling method to use for the latent stochastic process:
|
mhit |
the number of Metropolis-Hastings iterations to perform when sampling the latent process. Ignored unless |
resume |
|
silent |
setting to |
Usage of this function effectively involves specification of the structure of an absorbing CTMC generator matrix, the parameter priors in Gamma form and providing absorption time data.
The generator matrix TT
is specified as a matrix containing strings (ie text) naming the parameters in each element of the matrix. This allows constraints to be imposed (see Aslett & Wilson, 2011) and is best illustrated by the example below which is more fully discussed on this webpage.
phtMCMC2
returns an object of class "phtMCMC"
.
An object of class "phtMCMC"
is a list containing at least the following components:
samples |
an object of class |
data |
a vector containing the original data used in the inference. |
vars |
a list of the distinct variable names detected in the CTMC generator. |
TT |
the original CTMC generator passed in when phtMCMC2 was called. |
beta |
the Dirichlet prior probability mass function on the starting states. |
nu |
a list of the prior nu hyper-parameters used when phtMCMC2 was called. |
zeta |
a list of the prior zeta hyper-parameters used when phtMCMC2 was called. |
iterations |
the number of MCMC iterations contained in the object. |
censored |
the original vector of |
method |
a string indicating the method used for sampling of the latent process |
MHit |
the number of iterations used if |
Please feel free to email [email protected] with any queries or if you encounter errors when running this function.
Louis J.M. Aslett [email protected] (https://www.louisaslett.com/)
Aslett, L. J. M. and Wilson, S. P. (2011), ‘Markov chain Monte Carlo for inference on Phase-type models’, ISI 2011 Proceedings, (https://www.louisaslett.com/Proceedings/ISI_2011.html).
Aslett, L. J. M. (2012), ‘MCMC for Inference on Phase-type and Masked System Lifetime Models’, PhD Thesis, Trinity College Dublin (https://www.louisaslett.com/PhD_Thesis.html).
Bladt, M., Gonzalez, A. and Lauritzen, S. L. (2003), ‘The estimation of Phase-type related functionals using Markov chain Monte Carlo methods’, Scandinavian Actuarial Journal 2003(4), 280-300.
# Some pre-simulated absorption times x <- c(1.45353415045187, 1.85349532001349, 2.01084961814576, 0.505725921290172, 1.56252630012213, 3.41158665930278, 1.52674487509487, 4.3428662377235, 8.03208018151311, 2.41746547476986, 0.38828086509283, 2.61513815012196, 3.39148865480856, 1.82705817807965, 1.42090953713845, 0.851438991331866, 0.0178808867191894, 0.632198596390046, 0.959910259815998, 1.83344199966323) # Prior on starting state dirpi <- c(1, 0, 0) # Define the structure of the Phase-type generator TT <- matrix(c(0,"R","R",0,"F",0,0,0,"F",0,0,0,0,"F","F",0), 4) # Gamma prior: shape hyperparameters (one per model parameter) nu <- list("R"=180, "F"=24) # Gamma prior: reciprocal scale hyperparameters (one per model parameter) zeta <- c("R"=16,"F"=16) # Perform 20 MCMC iterations. Do more in practice!! res <- phtMCMC2(x, TT, dirpi, nu, zeta, 20) print(res) plot(res)
# Some pre-simulated absorption times x <- c(1.45353415045187, 1.85349532001349, 2.01084961814576, 0.505725921290172, 1.56252630012213, 3.41158665930278, 1.52674487509487, 4.3428662377235, 8.03208018151311, 2.41746547476986, 0.38828086509283, 2.61513815012196, 3.39148865480856, 1.82705817807965, 1.42090953713845, 0.851438991331866, 0.0178808867191894, 0.632198596390046, 0.959910259815998, 1.83344199966323) # Prior on starting state dirpi <- c(1, 0, 0) # Define the structure of the Phase-type generator TT <- matrix(c(0,"R","R",0,"F",0,0,0,"F",0,0,0,0,"F","F",0), 4) # Gamma prior: shape hyperparameters (one per model parameter) nu <- list("R"=180, "F"=24) # Gamma prior: reciprocal scale hyperparameters (one per model parameter) zeta <- c("R"=16,"F"=16) # Perform 20 MCMC iterations. Do more in practice!! res <- phtMCMC2(x, TT, dirpi, nu, zeta, 20) print(res) plot(res)