Conduct usefulness simulations of ML models embedded in workflows
Project description
APLUS ML
⚙ Documentation • 🐍 PyPi • 📝 Paper
pip install aplusml
Installation
- Run the following commands to install APLUS ML:
pip install aplusml
- Install graphviz by downloading it here. If you're on Mac with
homebrew, simply run:
brew install graphviz
Usage
Please see the documentation for usage examples.
Run tutorials/synthetic_pad.ipynb to try an example notebook which works out-of-the-box.
This simulates a utility analysis of PAD referral pathways for synthetic PAD patients.
Motivation
APLUS ML is a simulation framework for conducting usefulness assessments of machine learning models in workflows.
It aims to quantitatively answer the question: If I use this ML model within this workflow, will the benefits outweigh the costs, and by how much?
APLUS was originally developed for clinical workflows in healthcare settings, thus all of our examples are healthcare workflows. However, APLUS ML is a broadly applicable library to any workflow that involves a machine learning model making decisions on a stream of datapoints, and we encourage contributors from any domain to use and extend APLUS ML.
Tutorials
We showcase APLUS on two clinical workflows:
- Early detection of peripheral artery disease (PAD)
- Triaging patients for advanced care planning (ACP) consults
Jupyter notebooks for these use cases can be found in the tutorials/ folder.
Early Detection of PAD
The code used to generate the figures in our paper is located in the tutorials/ directory in pad.ipynb. This notebook loads de-identified patient data from Stanford Hospital, which can be provided upon request.
The workflows analyzed can be found in the workflows/ folder. The doctor-driven workflow is in pad_doctor.yaml while the nurse-driven workflow is in pad_nurse.yaml
This tutorials/pad.ipynb was used to generate the following figures from the APLUS paper:
Triaging Patients for ACP Consults
The code used to replicate the findings of Jung et al. 2021 can be found in the tutorials/ directory in acp_jung_replication.ipynb. This notebook loads de-identified patient data from Stanford Hospital, which can be provided upon request.
The workflows analyzed can be found in the workflows/ folder in acp_jung_replication.yaml
Plot Gallery
Some additional example plots that can be generated by APLUS are included below:
Development
Installation
# Download repo
git clone https://github.com/som-shahlab/aplus.git
cd aplus
# Create environment
conda create -n aplus python=3.10 -y
conda activate aplus
pip install poetry && poetry install
Tests
The file tests/run_tests.py runs all of the test[d].py files in the tests/ directory. Each test[d].py file has a corresponding test[d].yaml file that serves as its input.
To run tests:
cd tests
python3 run_tests.py
Documentation
We use Sphinx to build the documentation, and host it on Read the Docs.
To build the docs, run:
# View server
sphinx-autobuild docs/source docs/build/html
# Build for dist
make html
Deploy to PyPi
poetry build
poetry publish
Citation
@article{wornow2023aplus,
title={APLUS: A Python Library for Usefulness Simulations of Machine Learning Models in Healthcare},
author={Wornow, Michael and Ross, Elsie Gyang and Callahan, Alison and Shah, Nigam H},
journal={Journal of Biomedical Informatics},
pages={104319},
year={2023},
publisher={Elsevier}
}
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aplusml-0.3.1.tar.gz.
File metadata
- Download URL: aplusml-0.3.1.tar.gz
- Upload date:
- Size: 44.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.1 CPython/3.10.10 Darwin/24.4.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f1360f06752d1e01fe7af3e2efe4fb9d46298d80287bb1793c13d67f797509dc
|
|
| MD5 |
ed9fc9f4bf53c7c2cf9d3574f5479cde
|
|
| BLAKE2b-256 |
027822a4e9840e7ef78b60937c2e63293e10c1466fd303d84aa8839c8f59364c
|
File details
Details for the file aplusml-0.3.1-py3-none-any.whl.
File metadata
- Download URL: aplusml-0.3.1-py3-none-any.whl
- Upload date:
- Size: 45.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.1 CPython/3.10.10 Darwin/24.4.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3b21414362626607fe8df772630ec6df826f158439f30bbb3bfdfa473be251d2
|
|
| MD5 |
24eefff7bfeaa1f7389d859076d83427
|
|
| BLAKE2b-256 |
6daa1050cee16477a23a0c5c767ca2a9dcf95af57d81a55542f52c31711bb3ec
|