Performs parametric and non-parametric estimation and simulation for multi-state discrete-time semi-Markov processes.
For the parametric estimation, several discrete distributions are considered for the sojourn times:
The non-parametric estimation concerns the sojourn time distributions, where no assumptions are done on the shape of distributions. Moreover, the estimation can be done on the basis of one or several sample paths, with or without censoring at the beginning or/and at the end of the sample paths.
Reliability indicators such as reliability, maintainability, availability, BMP-failure rate, RG-failure rate, mean time to failure and mean time to repair are available as well.
The implemented methods are described in:
Barbu, V. S., & Limnios, N. (2009). Semi-Markov chains and hidden semi-Markov models toward applications: their use in reliability and DNA analysis (Vol. 191). Springer Science & Business Media. doi:10.1007/978-0-387-73173-5. (Journal version)
Barbu, V., & Limnios, N. (2006). Empirical estimation for discrete-time semi-Markov processes with applications in reliability. Nonparametric Statistics, 18(7-8), 483-498. doi:10.1080/10485250701261913. (Journal version)
Trevezas, S., & Limnios, N. (2011). Exact MLE and asymptotic properties for nonparametric semi-Markov models. Journal of Nonparametric Statistics, 23(3), 719-739. doi:10.1080/10485252.2011.555543. (Journal version)
Estimation and simulation of discrete-time k-th order Markov chains are also considered.
install.packages('smmR')
git
:if (!require("devtools")) {
install.packages("devtools")
}
devtools::install_git(
url = "https://plmlab.math.cnrs.fr/lmrs/statistique/smmR",
dependencies = TRUE,
build_vignettes = FALSE)
library(smmR)
To create an object smmparametric
, we need several pieces of information:
states
)alpha
)p
)dist
)states <- c("a", "b", "c") # state space
alpha <- c(1, 0, 0) # initial distribution
We define the transition matrix p
and the distribution matrix dist
(see here for details):
p <- matrix(data = c(0.0, 0.5, 0.5,
1.0, 0.0, 0.0,
1.0, 0.0, 0.0),
nrow = 3, ncol = 3, byrow = TRUE)
distr <- matrix(c(NA, "geom", "geom",
"geom", NA, NA,
"geom", NA, NA),
nrow = 3, ncol = 3, byrow = TRUE) # Distribution matrix
There is only one parameter for the geometrical law:
parameters <- array(c( NA, 0.8, 0.8,
0.3, NA, NA,
0.5, NA, NA,
NA, NA, NA,
NA, NA, NA,
NA, NA, NA),
c(3, 3, 2))
Finally, we create our object smmparametric
:
mysmmparam <- smmparametric(states = states, init = alpha, ptrans = p,
type.sojourn = "fij", distr = distr, param = parameters)
From this smmparametric
object, we can simulate sequences:
M <- 10000
seq <- simulate(object = mysmmparam, nsim = M)
And we can fit another model, here a smmnonparametric
object:
estimate <- fitsmm(sequences = seq, states = states, type.sojourn = "fij")
You can find an application to reliability here.
Contributions to this package are warmly welcome. Do not hesitate to open an issue to discuss new features.
The official repository is at PLMLab. But to help with issues and contributions, a mirror has been setup at Github.
If you want to contribute to the code, you can fork the repository, make some changes and create a pull request to have them integrated into the package. You can use the devtools::check()
function in order to verify that tests are still passing. See also the contributing guidelines.
If you encounter a problem, open a new issue. Try to be concise and explain what the problem is. If you have an example code that shows the error, it can be helpful.
We acknowledge the project AStERiCs Apprentissage Statistique à l'Echelle pour la Représentation et la Classification non-supervisées (RIN project funded by the Normandy Region), DAISI on Biomedical Data Classification (co-financed by the European Union with the European Regional Development Fund (ERDF) and by the Normandy Region).
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.