FlexVarJM
Estimate Joint Models with subject-specific variance
Science Score: 23.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
○.zenodo.json file
-
○DOI references
-
✓Academic publication links
Links to: arxiv.org -
○Academic email domains
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (12.6%) to scientific vocabulary
Last synced: 10 months ago
·
JSON representation
Repository
Estimate Joint Models with subject-specific variance
Basic Info
- Host: GitHub
- Owner: LeonieCourcoul
- Language: R
- Default Branch: master
- Size: 355 KB
Statistics
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
- Releases: 0
Created almost 4 years ago
· Last pushed almost 2 years ago
Metadata Files
Readme
Changelog
README.Rmd
---
output: github_document
editor_options:
markdown:
wrap: 72
---
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# FlexVarJM
[](https://github.com/LeonieCourcoul/FlexVarJM/actions/workflows/R-CMD-check.yaml)
The goal of FlexVarJM is to estimate joint model with subject-specific
time-dependent variability.
The global function is 'lsjm'. It handles to estimate joint model with a
marker which has a subject-specific time-dependent variability and
competing events with the possibility to take into account the left
truncation. For more information you can read the corresponding article
:
## Installation
You can install the development version of FlexVarJM from
[GitHub](https://github.com/) with:
``` r
# install.packages("devtools")
devtools::install_github("LeonieCourcoul/FlexVarJM")
```
## Example
# Estimation
This is an example in a simulated dataset where \code{binary} is a
binary variable.
$$y_i(t_{ij}) = \color{blue}\tilde{y}_i(t_{ij}) \color{black} + \epsilon_{ij} = \beta_0 + b_{0i} + (\beta_1 + b_{1i})t_{ij} + \beta_2 * binary_i + \epsilon_{ij} $$
For the first risk, k = 1, we estimate the following risk function :
$$ \lambda_{i1}(t) = \lambda_{01}(t)\exp(\gamma_{11}*binary_i + \color{blue}\alpha_{11}\tilde{y}_i(t) + \color{red}\alpha_{\sigma 1} \sigma_i(t) \color{black}) $$
And for the second risk, k = 2 :
$$ \lambda_{i2}(t) = \lambda_{02}(t)\exp(\color{blue}\alpha_{21}\tilde{y_i}(t) + \color{blue}\alpha_{22}\tilde{y}'_i(t) + \color{red}\alpha_{\sigma 2} \sigma_i(t) \color{black}) $$
where :
- $\epsilon_{i}(t_{ij}) \sim \mathcal{N}(0, \color{red}\sigma_i^2\color{black})$
with
$\color{red}\log(\sigma_i(t_{ij})) = \mu_0 + \tau_{0i} + (\mu_1 + \tau_{1i})\times t_{ij} + \mu_2 * binary_i$
- with $b_i=\left(b_{0i},b_{1i}\right)^{\top}$ and
$\tau_i=\left(\tau_{0i},\tau_{1i}\right)^{\top}$ assuming that the
two sets of random effects $b_i$ and $\tau_i$ are not independent:
$$(b_i, \tau_i)^\top \sim N(0, \Sigma)$$
- $\lambda_{0k}(t) = \kappa_k^2 t^{\kappa_k^2-1}e^{\zeta_{0k}}$ :
Weibull function
- $\tilde{y}'_i(t)$ is the current slope of the marker $y$
``` r
example <- lsjm(formFixed = y~visit+binary,
formRandom = ~ visit,
formGroup = ~ID,
formSurv = Surv(time, event ==1 ) ~ binary,
timeVar = "visit",
data.long = Data_toy,
variability_hetero = TRUE,
formFixedVar =~visit+binary,
formRandomVar =~visit,
correlated_re = TRUE,
sharedtype = c("current value", "variability"),
hazard_baseline = "Weibull",
competing_risk = TRUE,
formSurv_CR = Surv(time, event ==2 ) ~ 1,
hazard_baseline_CR = "Weibull",
sharedtype_CR = c("slope", "variability"),
formSlopeFixed =~1,
formSlopeRandom = ~1,
indices_beta_slope = c(2),
S1 = 500,
S2 = 1000,
nproc = 5,
Comp.Rcpp = TRUE
)
summary(example)
```
You can access to the table of estimations and standard deviation with :
``` r
example$table.res
```
The computing time is given by :
``` r
example$time.compute
```
The output of the marqLevAlg algorithm is in :
``` r
example$result
```
Finally, some elements of control are in :
``` r
example$control
```
# Goodness-of-fit
You can check the goodness-of-fit of the longitudinal submodel and of
the survival submodel by computing the predicted random effects :
``` r
goodness <- goodness_of_fit(example, graph = T)
```
# Predictions
You can compute the probability for (new) individual(s) to have event 1
or 2 between time s and time s+t years given that he did not experience
any event before time s, its trajectory of marker until time s ans the
set of estimated parameters. To have a 'IC%' confidence interval, the
predictions are computed 'nb.draws' time and the percentiles of the
predictions are computed. For example, for individuals 1 and 3 to
experiment the event 1 at time 1.5, 2, and 3, given their measurements until time 1 :
``` r
newdata <- Data_toy[which(Data_toy$ID %in% c(1,3)),]
predyn(newdata,example,1, c(1.5,2,3), event = 1, IC = 95, nb.draws = 500, graph = TRUE)
```
Owner
- Login: LeonieCourcoul
- Kind: user
- Repositories: 1
- Profile: https://github.com/LeonieCourcoul
GitHub Events
Total
- Watch event: 1
Last Year
- Watch event: 1
Packages
- Total packages: 1
-
Total downloads:
- cran 177 last-month
- Total dependent packages: 0
- Total dependent repositories: 0
- Total versions: 1
- Total maintainers: 1
cran.r-project.org: FlexVarJM
Estimate Joint Models with Subject-Specific Variance
- Homepage: https://github.com/LeonieCourcoul/FlexVarJM
- Documentation: http://cran.r-project.org/web/packages/FlexVarJM/FlexVarJM.pdf
- License: GPL (≥ 3)
-
Latest release: 0.1.0
published over 2 years ago
Rankings
Dependent packages count: 28.7%
Dependent repos count: 36.8%
Average: 50.5%
Downloads: 86.0%
Maintainers (1)
Last synced:
11 months ago
Dependencies
DESCRIPTION
cran
- R >= 3.5.0 depends
- foreach * depends
- splines * depends
- survival * depends
- Rcpp * imports
- doParallel * imports
- dplyr * imports
- ggplot2 * imports
- lcmm * imports
- marqLevAlg * imports
- mvtnorm * imports
- parallel * imports
- randtoolbox * imports
- snow * imports
- splines * imports
- stats * imports
- survminer * imports
- utils * imports
- knitr * suggests
- rmarkdown * suggests
.github/workflows/R-CMD-check.yaml
actions
- actions/checkout v3 composite
- r-lib/actions/check-r-package v2 composite
- r-lib/actions/setup-pandoc v2 composite
- r-lib/actions/setup-r v2 composite
- r-lib/actions/setup-r-dependencies v2 composite