Skip to content
Snippets Groups Projects
README.md 3.35 KiB
Newer Older
[![Build Status](https://travis-ci.org/openvax/mhcflurry.svg?branch=master)](https://travis-ci.org/openvax/mhcflurry)
Tim O'Donnell's avatar
Tim O'Donnell committed

# mhcflurry
Tim O'Donnell's avatar
Tim O'Donnell committed
[MHC I](https://en.wikipedia.org/wiki/MHC_class_I) ligand
Tim O'Donnell's avatar
Tim O'Donnell committed
prediction package with competitive accuracy and a fast and 
Tim O'Donnell's avatar
Tim O'Donnell committed
[documented](http://openvax.github.io/mhcflurry/) implementation.
Tim O'Donnell's avatar
Tim O'Donnell committed
MHCflurry implements class I peptide/MHC binding affinity prediction. By default
Tim O'Donnell's avatar
Tim O'Donnell committed
it supports 112 MHC alleles using ensembles of allele-specific models.
Tim O'Donnell's avatar
Tim O'Donnell committed
Pan-allele predictors supporting virtually any MHC allele of known sequence
Tim O'Donnell's avatar
Tim O'Donnell committed
are available for testing (see below). MHCflurry runs on Python 2.7 and 3.4+ using the
Tim O'Donnell's avatar
Tim O'Donnell committed
[keras](https://keras.io) neural network library.
It exposes [command-line](http://openvax.github.io/mhcflurry/commandline_tutorial.html)
and [Python library](http://openvax.github.io/mhcflurry/python_tutorial.html)
interfaces.

If you find MHCflurry useful in your research please cite:

Tim O'Donnell's avatar
Tim O'Donnell committed
> T. J. O’Donnell, A. Rubinsteyn, M. Bonsack, A. B. Riemer, U. Laserson, and J. Hammerbacher, "MHCflurry: Open-Source Class I MHC Binding Affinity Prediction," *Cell Systems*, 2018. Available at: https://www.cell.com/cell-systems/fulltext/S2405-4712(18)30232-1.
Tim O'Donnell's avatar
Tim O'Donnell committed
Have a bugfix or other contribution? We would love your help. See our [contributing guidelines](CONTRIBUTING.md) for more information.

## Installation (pip)

Install the package:

```
$ pip install mhcflurry
```

Then download our datasets and trained models:

```
$ mhcflurry-downloads fetch
```

You can now generate predictions:

```
$ mhcflurry-predict \
       --alleles HLA-A0201 HLA-A0301 \
       --peptides SIINFEKL SIINFEKD SIINFEKQ \
       --out /tmp/predictions.csv
       
Wrote: /tmp/predictions.csv
```

See the [documentation](http://openvax.github.io/mhcflurry/) for more details.

Tim O'Donnell's avatar
Tim O'Donnell committed
### Pan-allele models (experimental)
Tim O'Donnell's avatar
Tim O'Donnell committed
We are testing new models that support prediction for any MHC I allele of known
Tim O'Donnell's avatar
Tim O'Donnell committed
sequence (as opposed to the 112 alleles supported by the allele-specific
predictors). These models are trained on both affinity measurements and mass spec.
Tim O'Donnell's avatar
Tim O'Donnell committed

To try the pan-allele models, first download them:

```
$ mhcflurry-downloads fetch models_class1_pan
```

then set this environment variable to use them by default:

```
$ export MHCFLURRY_DEFAULT_CLASS1_MODELS="$(mhcflurry-downloads path models_class1_pan)/models.with_mass_spec"
```

You can now generate predictions for about 14,000 MHC I alleles. For example:

```
$ mhcflurry-predict --alleles HLA-A*02:04 --peptides SIINFEKL
```

Tim O'Donnell's avatar
Tim O'Donnell committed
If you use these models please let us know how it goes.


## Other allele-specific models

The default MHCflurry models are trained on affinity measurements, one allele
per model (i.e. allele-specific). Mass spec datasets are incorporated in the
model selection step.

We also release experimental allele-specific predictors whose training data
directly includes mass spec. To download these predictors, run:

```
$ mhcflurry-downloads fetch models_class1_trained_with_mass_spec
```

and then to make them used by default:

```
$ export MHCFLURRY_DEFAULT_CLASS1_MODELS="$(mhcflurry-downloads path models_class1_trained_with_mass_spec)/models"
```

We also release predictors that do not use mass spec datasets at all. To use
these predictors, run:

```
$ mhcflurry-downloads fetch models_class1_selected_no_mass_spec
export MHCFLURRY_DEFAULT_CLASS1_MODELS="$(mhcflurry-downloads path models_class1_selected_no_mass_spec)/models"
Tim O'Donnell's avatar
Tim O'Donnell committed
```