Skip to content

Plugin for folding sequences directly in PyMOL

License

Notifications You must be signed in to change notification settings

ullahsamee/PyMOLfold

 
 

Repository files navigation

PyMOLfold

Plugin for folding sequences directly in PyMOL using various models (ESM3, Boltz-1, and Chai-1).

Colby T. Ford, Ph.D.

Plugin Demo

Plugin Installation

From Local Download

  1. Download the pymolfold.zip file from this repository.
  2. Open PyMOL and in the menu bar, go to Plugin > Plugin Manager.
  3. On the Install New Plugin tab, click the Choose file... button under "Install from local file".
  4. Locate the .zip file and open it.

From the Web

  1. Open PyMOL and in the menu bar, go to Plugin > Plugin Manager.

  2. On the Install New Plugin tab, under the Install from PyuMOLWiki or any URL section, paste in the URL of the release .zip file from GitHub.

    • https://github.com/colbyford/PyMOLfold/releases/download/v0.2.0/pymolfold_v0.2.0.zip Installation
  3. Click the Fetch button and follow the prompts to install the package.

Once installed, navigate to Plugin > PyMOLfold in the menu bar. Then, in the dialog box, simply paste in your API key and amino acid sequence you wish to fold.

Note

Note: This plugin does not include any of the model package(s) or weights. You'll need to install them into the PyMOL Conda environment.

Package Installation

You can install PyPI libraries from the PyMOL command line. You can also run the pip install commands from your normal terminal if you know the path to PyMOL's Python executable. Running from the terminal is a bit easier to troubleshoot any installation issues. To find the PyMOL Python executable, use the sys library as follows. Simply copy and paste these commands in the pymol command line interface terminal:

import sys
print(sys.executable)

The output should be something like /home/<username>/biotools/pymol/bin/python on Linux or /Applications/PyMOL.app/Contents/bin/python on macOS. Then, to run a command in your normal terminal, simply point to the PyMOL Python executable. For example:

/home/<username>/biotools/pymol/bin/python -m pip install <package_name>

Here are the example install commands for the supported models:

  • ESM3: pip install esm
  • Boltz-1: pip install boltz
  • Chai-1: pip install chai_lab==0.5.0
  • Protenix: pip install --extra-index-url=https://pypi.nvidia.com --trusted-host pypi.nvidia.com nvidia-cublas-cu12 deepspeed==0.14.4 protenix

Note

Note: To use an ESM3 model, you'll need an API key from Evolutionary Scale Forge. Otherwise, the plugin can't download the folding model.

Using Conda

The version of PyMOL that can be downloaded from the Schrödinger website is currently compiled with Python 3.10. On some operating systems, you may have some difficulties installing the various model packages with this Python version.

To get around this, we can use conda to get PyMOL with a different version of Python that will hopefully work with your desired folding library. You can modify the provided environment.yml file to install the desired Python version + model package. (Note: You likely cannot install all of the model libraries at the same time as they have dependency conflicts.)

conda env create --file environment.yml
## Go get a ☕️ as this will take a while.

conda activate pymolfold
pymol ## This will open the GUI

# conda deactivate
# conda env update --file environment.yml
# conda remove -n pymolfold --all

Feature Roadmap

  • UI updates for model-specific controls
  • Support for multiple protein chains.
  • Model support for Protenix model (in beta)
    • In v0.3.0 release (Credit @colbyford)
  • Model support for Chai-1 (proteins and protein-ligand complexes)
    • In v0.2.5 release (Credit: @ullahsamee)
  • UI controls for temperature, steps, etc.
    • In v0.2.0 release (Credit @colbyford)
  • Model support for Boltz-1 (+ ligands)
    • In v0.2.0 release (Credit: @ullahsamee)
  • UI to select different models.
    • In v0.1.0 release (Credit: @colbyford)
  • Support for the latest ESM3 models.
    • In v0.1.0 release. (Credit: @colbyford)
  • Basic folding with esm3-small-2024-08.
    • In initial release. (Credit: @colbyford)

About

Plugin for folding sequences directly in PyMOL

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 97.7%
  • Python 2.3%