Skip to content

sivaavala/BloomCalculator

Repository files navigation

Interactive maps of mutations to the SARS-CoV-2 RBD that reduce antibody binding

The citation for this repository is this paper.

Most data come from Cao et al (2022).

Briefly, the Bloom lab and the group of Yunlong Cao, Sunney Xie, and coworkers at Peking University have used deep mutational scanning to map how all mutations to the SARS-CoV-2 receptor binding domain (RBD) affect binding by antibodies or sera. These "escape maps" are useful for understanding the antigenic impact of viral mutations.

The escape maps for individual antibodies and sera samples have all been published across a wide variety of studies. The goal this repository is to aggregate those data, and enable it to be easily and interactively interrogated.

Specifically, this repository hosts the code for two ways to interact with the data:

Note in the above files, an IC50 of 10 should be taken as corresponding to non-neutralizing.

Command-line escape calculator for batch calculations

If you are performing batch analyses of SARS-CoV-2 variants or mutations, you may want to calculate the extent of escape as implemented in the "escape calculator" at https://jbloomlab.github.io/SARS2_RBD_Ab_escape_maps/escape-calc/ in batch. You can do this by downloading the Python module bindingcalculator.py, which provides a Python interface that implements the escape calculator. Here is the documentation for that module (built with pdoc) with pdoc bindingcalculator.py -o docs/_layouts/.

New method of building escape calculator

Note that as of Sept-19-2022, we have changed how we get data for the escape calculator. Now all those data come from Cao et al (2022) and we no longer update the antibody-specific visualizations. There are two reasons: first, the data was now too large to display in the old non-calculator format, and second we just want data from that single study.

To build the calculator, first build the conda environment in environment.yml. Then activate that conda environment with:

conda activate SARS2_RBD_Ab_escape_maps

Next open the Jupyter notebooks plot_calculator.ipynb and run it. It creates an interactive Altair chart:

The interactive chart will be rendered via GitHub pages. Specifically, when updates are pushed to the main branch of the repo on GitHub, it will be rendered at https://jbloomlab.github.io/SARS2_RBD_Ab_escape_maps/escape-calc. See docs/README.md for more information on how the webpage is served via GitHub Pages The notebook also creates the following file, which has the input data for the escape calculator:

Less processed forms of the same data (not collapsed at site level or only for neutralizing antibodies) are here: mutation-level and site-level

Obsolete method of adding data to these maps

The input data on how mutations affect antibody binding or neutralization are in ./data/, and is collated from Bloom lab deep mutational scanning experiments. See ./data/README.md for details on how to add new data.

To process the data to build the interactive visualizations, first build the conda environment in environment.yml. Then activate that conda environment with:

conda activate SARS2_RBD_Ab_escape_maps

Next, process the raw data by running process_data.py:

python process_data.py

This command will process the input data in ./data/ to create the processed data in ./processed_data/. Specifically, the processed data includes the following two files:

The process_data.py script also adds information about citations to the bottom of docs/index.md for rendering on the webpage.

Finally, open the Jupyter notebooks plot_calculator.ipynb and plot_escape_maps.ipynb and run them. They create two interactive Altair charts:

The interactive charts will be rendered via GitHub pages. Specifically, when updates are pushed to the main branch of the repo on GitHub, they will be rendered at https://jbloomlab.github.io/SARS2_RBD_Ab_escape_maps/escape-calc and https://jbloomlab.github.io/SARS2_RBD_Ab_escape_maps. See docs/README.md for more information on how the webpage is served via GitHub Pages

The plot_escape_maps.ipynb notebook also creates the following file, which has the input data for the escape calculator:

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •