Learn R Programming

⚠️There's a newer version (0.5.5) of this package.Take me there.

Health economic simulation modeling

Overview

hesim is a modular and computationally efficient R package for health economic simulation modeling and decision analysis that provides a general framework for integrating statistical analyses with economic evaluation. The package supports cohort discrete time state transition models (DTSTMs), N-state partitioned survival models (PSMs), and individual-level continuous time state transition models (CTSTMs), encompassing both Markov (time-homogeneous and time-inhomogeneous) and semi-Markov processes. It heavily utilizes Rcpp and data.table, making individual-level simulation, probabilistic sensitivity analysis (PSA), and incorporation of patient heterogeneity fast.

Features of the current version can be summarized as follows:

  • Cohort DTSTMs, individual-level CTSTMs, and N-state PSMs that encompass Markov and semi-Markov processes
  • Options to build models directly from fitted statistical models or by defining them in terms of expressions
  • Parameter estimates from either an R based model or from an external source
  • Convenience functions for sampling model parameters from parametric distributions or via bootstrapping
  • Parameter uncertainty propagated with PSA
  • Modeling patient heterogeneity
  • Performing cost-effectiveness analyses and representing decision uncertainty from PSAs
  • Simulation code written in C++ to boost performance

Installation

You can install the current release from CRAN or the most up to date development version from GitHub.

# Install from CRAN:
install.packages("hesim")

# Install the development version from GitHub:
# install.packages("devtools")
devtools::install_github("hesim-dev/hesim")

Getting started

There are two good places to start:

  1. The Introduction to hesim article provides a quick introduction.

  2. Our preprint describes the package (including mathematical details) more thoroughly.

You might also want to explore our example analyses which can be found in the preprint and web articles. They are summarized in the table below, with some drawn from the Decision Modeling for Health Economic Evaluation textbook. Key areas of focus are the (i) statistical models of disease progression (in terms of the baseline risk and relative treatment effects) and (ii) the available data (either individual patient data (IPD) or aggregate-level data).

Baseline risk

Treatment effect

Citing hesim

If you use hesim, please cite as follows:

  Devin Incerti and Jeroen P Jansen (2021). hesim: Health Economic
  Simulation Modeling and Decision Analysis. arXiv:2102.09437
  [stat.AP], URL https://arxiv.org/abs/2102.09437.

A BibTeX entry for LaTeX users is

  @Misc{incerti2021hesim,
    author = {Devin Incerti and Jeroen P. Jansen},
    title = {hesim: Health Economic Simulation Modeling and Decision Analysis},
    year = {2021},
    eprint = {2102.09437},
    archiveprefix = {arXiv},
    primaryclass = {stat.AP},
    url = {https://arxiv.org/abs/2102.09437},
  }

Copy Link

Version

Install

install.packages('hesim')

Monthly Downloads

511

Version

0.5.3

License

GPL-3

Issues

Pull Requests

Stars

Forks

Maintainer

Devin Incerti

Last Published

September 3rd, 2022

Functions in hesim (0.5.3)

Psm

N-state partitioned survival model
absorbing

Absorbing states
IndivCtstm

Individual-level continuous time state transition model
apply_rr

Apply relative risks to transition probability matrices
StateVals

Model for state values
PsmCurves

Partitioned survival curves
CohortDtstmTrans

Transitions for a cohort discrete time state transition model
IndivCtstmTrans

Transitions for an individual-level continuous time state transition model
CohortDtstm

Cohort discrete time state transition model
CtstmTrans

An R6 base class for continuous time state transition models
cea

Cost-effectiveness analysis
ce

A cost-effectiveness object
check_input_data

Check input data argument for create_input_mats
autoplot.survival

Plot survival curves
as_array3

Convert between 2D tabular objects and 3D arrays
as_pfs_os

Convert multi-state data to PFS and OS data
autoplot.stateprobs

Plot state probabilities
as.data.table.tparams_transprobs

Coerce to data.table
bootstrap

Bootstrap a statistical model
check.id_attributes

Input validation for class objects
create_CohortDtstmTrans

Create CohortDtstmTrans object
create_lines_dt

Create a data table of treatment lines
costs

Costs object
create_object_list

Form a list from ...
create_IndivCtstmTrans

Create IndivCtstmTrans object
create_PsmCurves

Create PsmCurves object
create_StateVals

Create a StateVals object
create_input_mats.formula_list

Create input matrices from formula
create_input_mats

Create input matrices
create_CohortDtstm

Create CohortDtstm object
define_rng

Define and evaluate random number generation expressions
define_model

Define and evaluate model expression
define_tparams

Define and evaluate transformed parameter expressions
disprog

Disease progression object
expmat

Matrix exponential
fast_rgengamma

Random generation for generalized gamma distribution
expand.hesim_data

Expand hesim_data
expand

Expand object
hesim

hesim: Health Economic Simulation Modeling and Decision Analysis
get_labels

Get value labels
icer

Incremental cost-effectiveness ratio
icea

Individualized cost-effectiveness analysis
id_attributes

Attributes for ID variables
create_trans_dt

Create a data table of health state transitions
create_params

Create a parameter object from a fitted model
input_mats

Input matrices for a statistical model
incr_effect

Incremental treatment effect
icer_tbl

ICER table
hesim_survdists

List of survival distributions
lm_list

List of lm objects
normboot

Draw parameters of statistical model from multivariate normal distribution
hesim_data

Data for health economic simulation modeling
onc3

Multi-state oncology data for 3-state model
mom_beta

Method of moments for beta distribution
params_surv

Parameters of a survival model
params_mlogit_list

Parameters of a list of multinomial logit models
mom_gamma

Method of moments for gamma distribution
mstate3_exdata

Example data for a reversible 3-state multi-state model
onc3p

Multi-state panel oncology data for 3-state model
params

Parameter object
qmatrix.msm

Transition intensity matrix from msm object
qmatrix.matrix

Transition intensity matrix from tabular object
qmatrix

Transition intensity matrix
rcat

Random generation for categorical distribution
plot_ceaf

Plot cost-effectiveness acceptability frontier
plot_ceac

Plot cost-effectiveness acceptability curve
qalys

Quality-adjusted life-years object
psm4_exdata

Example data for a 4-state partitioned survival model
rdirichlet_mat

Random generation for multiple Dirichlet distributions
params_surv_list

Parameters of a list of survival models
flexsurvreg_list

List of flexsurvreg objects
formula_list

List of formula objects
reexports

Objects exported from other packages
partsurvfit

Partitioned survival regression object
params_mlogit

Parameters of a multinomial logit model
params_lm

Parameters of a linear model
sim_stateprobs.survival

Simulate state probabilities from survival curves
sim_stateprobs

Simulated state probabilities
summarize_ce

Summarize costs and effectiveness
summary.ce

Summary method for cost-effectiveness object
plot_ceplane

Plot cost-effectiveness plane
set_labels

Set value labels
sim_ev

Expected values from state probabilities
multinom3_exdata

Example data for a 3-state multinomial model
multinom_list

List of multinom objects
tparams_mean

Predicted means
plot_evpi

Plot expected value of perfect information
tparams

Transformed parameter object
summary.tparams_transprobs

Summarize tparams_transprobs object
summary.tparams_mean

Summarize tparams_mean object
rpwexp

Random generation for piecewise exponential distribution
summary.tpmatrix

Summarize transition probability matrix
rng_distributions

Random number generation distributions
stateprobs

State probability object
tparams_transprobs

Transition probabilities
surv_quantile

Survival quantiles
tpmatrix_names

Names for elements of a transition probability matrix
tpmatrix

Transition probability matrix
tpmatrix_id

Transition probability matrix IDs
survival

Survival object
weibullNMA

Parameterization of the Weibull distribution for network meta-analysis
uv_rng

Generate variates for univariate distributions
time_intervals

Time intervals
summary.params

Summarize parameter objects
stateval_tbl

Table to store state value parameters
summary.eval_rng

Summarize eval_rng object