-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathREADME.Rmd
135 lines (109 loc) · 4.7 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
---
output: github_document
editor_options:
chunk_output_type: console
---
<!-- markdownlint-disable-file -->
<!-- README.md needs to be generated from README.Rmd. Please edit that file -->
# jmpost <a href="https://genentech.github.io/jmpost/"><img src="man/figures/logo.png" align="right" height="139" /></a>
```{r, echo = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "README-"
)
```
<!-- badges: start -->
[![Project Status: Active – The project has reached a stable, usable state and is being actively developed.](https://www.repostatus.org/badges/latest/wip.svg)](https://www.repostatus.org/#wip)
[![Code Coverage](https://raw.githubusercontent.com/genentech/jmpost/_xml_coverage_reports/data/main/badge.svg)](https://raw.githubusercontent.com/genentech/jmpost/_xml_coverage_reports/data/main/coverage.xml)
<!-- badges: end -->
\
The goal of the `jmpost` package is to fit joint models involving:
1. a parametric time-to-event sub-model,
1. a nonlinear (or linear) mixed-effect sub-model, describing individual time profiles (_i.e._ trajectories) for a continuous marker,
1. a link function (_a.k.a._ association term).
More specifically, the model implemented in this package utilizes a modelling framework described previously **[1-3]** to link overall survival to tumour size data in oncology clinical trials.
**[1]** [Tardivon _et al._ Association between tumour size kinetics and survival in patients with urothelial carcinoma treated with atezolizumab: Implications for patient follow-up. _Clin Pharm Ther_, 2019](https://doi.org/10.1002/cpt.1450).
**[2]** [Kerioui _et al._ Bayesian inference using Hamiltonian Monte-Carlo algorithm for nonlinear joint modelling in the context of cancer immunotherapy. _Stat in Med_, 2020](https://doi.org/10.1002/sim.8756).
**[3]** [Kerioui _et al._ Modelling the association between biomarkers and clinical outcome: An introduction to nonlinear joint models. _Br J Clin Pharm_, 2022](https://doi.org/10.1111/bcp.15200).
The models are implemented in [STAN](https://mc-stan.org/), and the package provides a flexible user interface.
Please reach out to us via issues or email (see the `DESCRIPTION` file) if you have comments or questions or would like to get involved in the ongoing development, thank you!
## Installation
**GitHub**
You can install the current development version from GitHub with:
```{r gh-installation, eval = FALSE}
if (!require("remotes")) {
install.packages("remotes")
}
remotes::install_github("genentech/jmpost")
```
Please note that this package requires [`cmdstanr`](https://mc-stan.org/cmdstanr/).
**CRAN**
This package has not been published to CRAN yet.
## Getting Started
See also the [model fitting](https://genentech.github.io/jmpost/main/articles/model_fitting.html)
vignette for more details. Here we present a very basic example here.
First we simulate a data set. In practice you want to follow a similar structure
of the input data and use `DataJoint()` to bring it into the right format.
```{r sim_data}
library(jmpost)
set.seed(321)
sim_data <- SimJointData(
design = list(
SimGroup(50, "Arm-A", "Study-X"),
SimGroup(50, "Arm-B", "Study-X")
),
longitudinal = SimLongitudinalRandomSlope(
times = c(1, 50, 100, 150, 200, 250, 300),
),
survival = SimSurvivalWeibullPH(
lambda = 1 / 300,
gamma = 0.97
)
)
joint_data <- DataJoint(
subject = DataSubject(
data = sim_data@survival,
subject = "subject",
arm = "arm",
study = "study"
),
survival = DataSurvival(
data = sim_data@survival,
formula = Surv(time, event) ~ cov_cat + cov_cont
),
longitudinal = DataLongitudinal(
data = sim_data@longitudinal,
formula = sld ~ time,
threshold = 5
)
)
```
Then we specify the joint model, here we use a Generalized Stein-Fojo model
for the longitudinal part, and a Weibull proportional hazards model for the
survival part. The longitudinal model impacts the hazard via a term for the
derivative and another term for the time-to-growth.
```{r model_spec}
joint_model <- JointModel(
longitudinal = LongitudinalGSF(),
survival = SurvivalWeibullPH(),
link = Link(
linkDSLD(),
linkTTG()
)
)
```
Finally we can sample the parameters via MCMC from the underlying Stan model.
Note that in a real application you will choose more warm up and sampling iterations.
```{r sample_model, eval = FALSE}
mcmc_results <- sampleStanModel(
joint_model,
data = joint_data,
iter_sampling = 100,
iter_warmup = 100,
chains = 1,
parallel_chains = 1
)
```
## Citing `jmpost`
To cite `jmpost` please see [here](https://genentech.github.io/jmpost/main/authors.html#citation).