Python library for the calculation of BenchMark Dose Response Curves (bmdrc)
The bmdrc library was built to calculate benchmark dose (BMD) response curves for dichotomous (morphological) and light photomotor response datasets, where continuous variables are transformed to dichotomous as described in Thomas et al 2019. Potential outputted files include a csv file of all final BMDs and their estimation errors, a csv file of model fits (AIC) for each endpoint, and an html report containing information on how much data was filtered and why, as well as interactive response curve plots. Users may specify their outputs of interest.
-
Input Data Module: Import data into the python library
-
Pre-Processing Module: Combine and remove endpoints as needed
-
Filtering Modules: Apply the EPA recommendations for filtering
-
Model Fitting Modules: Fit EPA-recommended models to data
-
Output Modules: Select tables to output as csvs. View plots in a HTML report.
First, install the package from pip using:
pip install bmdrc
Or from github using:
pip install git+https://github.com/PNNL-CompBio/bmdrc
An example vignette for the dichotomous (binary) data (when plate and well information is available) is located here and an example vignette for when only chemical, endpoint, concentration, and response (ranging from 0-1) information is available is located here. For the light photomotor response data (continuous converted to dichotomous), a vignette is located here.
Example data for dichotomous and light photomotor response data can be found here.
A sample for the generated report for dichotomous (binary) data can be found here
A sample for the generated report for light photomotor response data can be found here
Name | Stmts | Miss | Cover |
---|---|---|---|
bmdrc/BinaryClass.py | 138 | 0 | 100% |
bmdrc/LPRClass.py | 211 | 0 | 100% |
bmdrc/filtering.py | 146 | 0 | 100% |
bmdrc/model_fitting.py | 687 | 5 | 99% |
bmdrc/output_modules.py | 125 | 2 | 98% |
bmdrc/preprocessing.py | 59 | 0 | 100% |
TOTAL | 1366 | 7 | 99% |
For datasets with plates and wells, use the BinaryClass
object as it contains specific pre-processing and filtering functions that pertain to plates and well. Each value should be 0, 1, or NA, and bmdrc
will calculate the response column. If your data does not contain plates and wells, use the SimplifiedClass
object which only requires chemical, endpoint, concentration, and response information. The response must be between 0 and 1. If your data is light photomotor response use the LPRClass
object. The continuous data will be transformed to dichotomous.