Framework for Electronic Medical Records. A python package for building models using EHR data.
Project description
FEMR
Framework for Electronic Medical Records
FEMR is a Python package for manipulating longitudinal EHR data for machine learning, with a focus on supporting the creation of foundation models and verifying their presumed benefits in healthcare. Such a framework is needed given the current state of large language models in healthcare and the need for better evaluation frameworks.
The currently supported foundation models are CLMBR and MOTOR.
FEMR by default supports the OMOP Common Data Model developed by the OHDSI community, but can also be used with other forms of EHR / claims data with minimal processing. FEMR has been used to process data from a variety of sources, including MIMIC-IV, Optum, Truven, STARR-OMOP, and SickKids-OMOP.
FEMR helps users:
- Manipulate events in the EHR data comprising a patient's timeline
- Algorithmically label patient records based on structured data
- Generate tabular features from patient timelines for use with traditional gradient boosted tree models
- Train and finetune CLMBR-derived models for binary classification and prediction tasks.
- Train and finetune MOTOR-derived models for making time-to-event predictions.
We recommend users start with our tutorial folder
Installation
There are two variants of the FEMR package, a CPU only version and a CUDA enabled version.
How to install FEMR without CUDA
pip install femr
If you have a particularly old CPU, we offer a variant of femr without CPU optimations.
pip install femr_oldcpu
How to install FEMR with CUDA support
Note that CUDA-enabled FEMR requires jax in order to function.
pip install --upgrade "jax[cuda11_pip]==0.4.8" -f https://storage.googleapis.com/jax-releases/jax_cuda_releases.html
pip install "femr_cuda[models]"
Getting Started
The first step of using FEMR is to convert your patient data into a femr.datasets.PatientDatabase, the standard file format used by the FEMR codebase to hold and query patient timelines.
There are two recommended paths for doing this, each with a corresponding tutorial:
- Convert your data to OMOP format, and then run the OMOP converter
- Convert your data to FEMR's simple csv format, and then run the simple FEMR converter
The simple csv route has an advantage of being an easier ETL, but does come with some downsides. See the below table for what features we support with what ETLs.
Capability | OMOP -> FEMR | Simple CSV -> FEMR |
---|---|---|
Core Labeling Tools | :white_check_mark: | :white_check_mark: |
OMOP Specific Labeling | :white_check_mark: | :x: |
Tabular Feature Generation | :white_check_mark: | :white_check_mark: |
Foundation Model Training | :white_check_mark: | :white_check_mark: |
Shared Vocabulary Enabling Cross-Site Foundation Model Transfer | :white_check_mark: | :x: |
Development
The following guides are for developers who want to contribute to FEMR.
Building from source
In some scenarios (such as contributing to FEMR), you might want to compile the package from source.
In order to do so, follow the following instructions.
conda create -n FEMR_ENV python=3.10 bazel=6 -c conda-forge -y
conda activate FEMR_ENV
export BAZEL_USE_CPP_ONLY_TOOLCHAIN=1
git clone https://github.com/som-shahlab/femr.git
cd femr
pip install -e .
Special note for NERO users
As Nero does not have internet access, you must run the following before running the code above.
export DISTDIR=/local-scratch/nigam/distdir
(Optional) Installing CUDA on Nero / Carina
As a side note for Nero/Carina users, do not use your home directory to save the femr repo and installation files due to limited storage. We recommend using the shared project folder, e.g., on nero, use '/local-scratch/nigam/project/...'
If you are using Nero, you will need to install CUDA manually until the CUDA version on Nero is updated. To do so, follow these steps:
-
Download version 11.8 of CUDA onto your local machine from here
-
Copy your CUDA download from your local machine onto Nero, into whatever folder you'd like. We'll refer to the path to this folder as
<PATH_TO_CUDA_INSTALLER>
from now on.- Note: Nero doesn't work with
scp
. You can use an alternative likepscp
, which functions basically identically toscp
. You can installpscp
on a Mac by usingbrew install putty
.
- Note: Nero doesn't work with
-
ssh
into Nero usingssh <username>@nero-nigam.compute.stanford.edu
-
On Nero, run the CUDA installer as a bash command as follows:
bash <PATH_TO_CUDA_INSTALLER> --installpath=<INSTALL_PATH>
, where<PATH_TO_CUDA_INSTALLER>
is the path to the file you downloaded/transferred in Step #2, and<INSTALL_PATH>
is where you'd like to save your CUDA installation files. We recommend using~
or something similar. -
The CUDA installer will pop-up a window during installation. Uncheck all of the boxes it presents except for the box labeled "cuda toolkit".
-
After the installation completes, the installer will print out two paths to your console. Take note of these paths, and copy them into your
.bashrc
file by running the following commands. -
Install cuDNN v8.7.0 (November 28th, 2022) for CUDA. Go to this link and download the file
Download cuDNN v8.7.0 (November 28th, 2022), for CUDA 11.x
->Local Installer for Linux x86_64 (Tar)
on your local computer and transfer it over to your local folder in nero. Then follow the instruction here section 1.3. Note that you need to copy over cudnn files to your local cuda. For example,
cp cudnn-*-archive/include/cudnn*.h <path_to_your_cuda>/include
cp -P cudnn-*-archive/lib/libcudnn* <path_to_your_cuda>/lib64
chmod a+r <path_to_your_cuda>/include/cudnn*.h <path_to_your_cuda>/lib64/libcudnn*
- Add the following to your .bashrc file. You may need to restart your terminal for the changes to be reflected.
export PATH="<INSTALL_PATH>/bin:$PATH"
export LD_LIBRARY_PATH="<INSTALL_PATH>/lib64:$LD_LIBRARY_PATH"
To write in a .bashrc file, use
nano ~/.bashrc
- Run
rm /tmp/cuda-installer.log
to remove the installer log (if you don't do this, it will cause a segmentation fault for other users when they try to install CUDA).
Precommit checks
Before committing, please run the following commands to ensure that your code is formatted correctly and passes all tests.
Installation
conda install pre-commit pytest -y
pre-commit install
Running
Test Functions
pytest tests
Formatting Checks
pre-commit run --all-files
Miscellaneous
GZIP decompression commands
export OMOP_SOURCE=/share/pi/nigam...
gunzip $OMOP_SOURCE/**/*.csv.gz
Zstandard compression commands
export OMOP_SOURCE=/share/pi/nigam...
zstd -1 --rm $OMOP_SOURCE/**/*.csv
Generating extract
# Set up environment variables
# Path to a folder containing your raw STARR-OMOP download, generated via `tools.stanford.download_bigquery.py`
export OMOP_SOURCE=/path/to/omop/folder...
# Path to any arbitrary folder where you want to store your FEMR extract
export EXTRACT_DESTINATION=/path/to/femr/extract/folder...
# Path to any arbitrary folder where you want to store your FEMR extract logs
export EXTRACT_LOGS=/path/to/femr/extract/logs...
# Do some data preprocessing with Stanford-specific helper scripts
# Extract data from flowsheets
python tools/stanford/flowsheet_cleaner.py --num_threads 5 $OMOP_SOURCE "${EXTRACT_DESTINATION}_flowsheets"
# Normalize visits
python tools/omop/normalize_visit_detail.py --num_threads 5 "${EXTRACT_DESTINATION}_flowsheets" "${EXTRACT_DESTINATION}_flowsheets_detail"
# Run actual FEMR extraction
etl_stanford_omop "${EXTRACT_DESTINATION}_flowsheets_detail" $EXTRACT_DESTINATION $EXTRACT_LOGS --num_threads 10
Example usage (Note: This should take ~10 minutes on a 1% extract of STARR-OMOP)
export OMOP_SOURCE=/local-scratch/nigam/projects/ethanid/som-rit-phi-starr-prod.starr_omop_cdm5_deid_1pcent_2022_11_09
export EXTRACT_DESTINATION=/local-scratch/nigam/projects/mwornow/femr_starr_omop_cdm5_deid_1pcent_2022_11_09
export EXTRACT_LOGS=/local-scratch/nigam/projects/mwornow/femr_starr_omop_cdm5_deid_1pcent_2022_11_09_logs
python tools/stanford/flowsheet_cleaner.py --num_threads 5 $OMOP_SOURCE "${EXTRACT_DESTINATION}_flowsheets"
python tools/omop/normalize_visit_detail.py --num_threads 5 "${EXTRACT_DESTINATION}_flowsheets" "${EXTRACT_DESTINATION}_flowsheets_detail"
etl_stanford_omop "${EXTRACT_DESTINATION}_flowsheets_detail" $EXTRACT_DESTINATION $EXTRACT_LOGS --num_threads 10
(Optional) Installing PyTorch
If you are on Nero, you need to install PyTorch using:
conda install numpy -y
pip install torch==1.12.0 torchvision==0.13.0 torchaudio==0.12.0 --extra-index-url https://download.pytorch.org/whl/cu111
If you are on Carina, you need to install PyTorch using:
conda install numpy pytorch torchvision torchaudio pytorch-cuda=11.7 -c pytorch -c nvidia -y
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file femr_cuda-0.1.16-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: femr_cuda-0.1.16-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.5 MB
- Tags: PyPy, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 643ac9da023461e66dcd4b07ee2c986b1ecaaf97ece37794612211ec36c61169 |
|
MD5 | 86bc605694ac253e28c5b9488677966c |
|
BLAKE2b-256 | a6da8ec8e8838deea7d3d5c984fbfdaa05ecd734b07c1cccad253f8f353c4e47 |
File details
Details for the file femr_cuda-0.1.16-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: femr_cuda-0.1.16-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.5 MB
- Tags: CPython 3.11, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0c9830becd5082faf9a4b7f2f7d8cab509aae472e93529d396314db60dcbe5b6 |
|
MD5 | f9662a090a952f610fcf7603d00f1856 |
|
BLAKE2b-256 | f133639877ce65310b90cb1050578650d41641c7377beea68e9c760b75abe537 |
File details
Details for the file femr_cuda-0.1.16-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: femr_cuda-0.1.16-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.5 MB
- Tags: CPython 3.10, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6cea0419b97624305e853979dd75fa73e13fd2b9bb37e14dfb69d544704063f8 |
|
MD5 | a9d4ee7a5a2355bd09104eadd03e37bf |
|
BLAKE2b-256 | 26cb43a68d6f01683a6052dca8927513970e161ef699b00bdbf2dccee34401a7 |
File details
Details for the file femr_cuda-0.1.16-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: femr_cuda-0.1.16-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.5 MB
- Tags: CPython 3.9, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5b6179c8162dae24d3d762ff9788d19e9b7b2838f768ca1c347161201f765604 |
|
MD5 | 9e30115a76e6bef524fe8332a38b6c01 |
|
BLAKE2b-256 | 62ada35db65dce8390e1dc11ec080fc7b009549adb6c19bcfdb6c293330b1b33 |