ProDock — automation utilities for molecular docking workflows.
Project description
ProDock
Automatic pipeline for molecular modeling
Toolkit for molecular modeling
For more details on each utility within the repository, please refer to the documentation provided in the respective folders.
Overview
ProDock is a toolkit for building automated molecular docking workflows. It is designed for campaigns involving multiple receptors, multiple ligands, and multiple docking engines, with support for downstream pose extraction, interaction profiling, visualization, and SQLite-backed result management.
The project aims to provide one consistent workflow for:
- receptor and ligand preparation
- batch docking across one or more engines
- pose extraction into standardized tables
- interaction analysis from docked complexes
- database storage for poses, scores, and interactions
- reproducible downstream analysis
This makes ProDock useful both for small docking experiments and for larger benchmark-style or screening-style studies.
Main capabilities
Docking workflow
ProDock supports automated docking workflows across multiple receptor-ligand combinations and can be organized as single-target, multi-ligand, or multi-receptor campaigns.
Typical use cases include:
- one receptor with many ligands
- many receptors with one ligand set
- many receptors with many ligands
- comparison of multiple docking engines on the same campaign
Post-processing
After docking, ProDock can parse docking outputs and convert them into structured pose tables with canonical columns such as:
receptor_idligand_idenginepose_rankaffinitymolpose_id
These standardized tables make it easier to compare poses across engines and campaigns.
Interaction analysis
ProDock supports protein-ligand interaction extraction and summarization, enabling residue-level interaction profiles for each pose. This is intended for downstream comparison, ranking, and interpretation of docking results.
Database-backed storage
ProDock includes SQLite-based storage to keep docking poses and interaction records in a structured and queryable form. This is especially useful when handling many receptors, ligands, docking engines, and poses.
Database architecture
ProDock stores docking outputs and associated interaction information in a relational SQLite database. This supports scalable querying, reproducible analysis, and easy export into pandas dataframes.
Database architecture figure:
This architecture is intended to support:
- pose-centric storage
- stable pose identifiers
- interaction lookup by pose, receptor, ligand, or engine
- multi-receptor and multi-engine benchmarking workflows
- clean integration with pandas- and RDKit-based analysis
Step-by-Step Installation Guide
-
Python Installation: Ensure that Python 3.11 or later is installed on your system. You can download it from python.org.
-
Creating a Virtual Environment (Optional but Recommended): It's recommended to use a virtual environment to avoid conflicts with other projects or system-wide packages. Use the following commands to create and activate a virtual environment:
python -m venv prodock-env
source prodock-env/bin/activate
Or Conda
conda create --name prodock-env python=3.11
conda activate prodock-env
- Cloning and Installing SynTemp: Clone the SynTemp repository from GitHub and install it:
git clone https://github.com/Medicine-Artificial-Intelligence/ProDock.git
cd ProDock
pip install -r requirements.txt
pip install black flake8 pytest # black for formating, flake8 for checking format, pytest for testing
Setting Up Your Development Environment
Before you start, ensure your local development environment is set up correctly. Pull the latest version of the main branch to start with the most recent stable code.
git checkout main
git pull
Working on New Features
-
Create a New Branch:
For every new feature or bug fix, create a new branch from themainbranch. Name your branch meaningfully, related to the feature or fix you are working on.git checkout -b feature/your-feature-name
-
Develop and Commit Changes:
Make your changes locally, commit them to your branch. Keep your commits small and focused; each should represent a logical unit of work.git commit -m "Describe the change"
-
Run Quality Checks:
Before finalizing your feature, run the following commands to ensure your code meets our formatting standards and passes all tests:./lint.sh # Check code format pytest Test # Run tests
Fix any issues or errors highlighted by these checks.
Integrating Changes
-
Rebase onto Staging:
Once your feature is complete and tests pass, rebase your changes onto thestagingbranch to prepare for integration.git fetch origin git rebase origin/staging
Carefully resolve any conflicts that arise during the rebase.
-
Push to Your Feature Branch: After successfully rebasing, push your branch to the remote repository.
git push origin feature/your-feature-name
-
Create a Pull Request: Open a pull request from your feature branch to the
stagingbranch. Ensure the pull request description clearly describes the changes and any additional context necessary for review.
Important Notes
- Direct Commits Prohibited: Do not push changes directly to the
mainorstagingbranches. All changes must come through pull requests reviewed by at least one other team member. - Merge Restrictions: The
mainbranch can only be updated from thestagingbranch, not directly from feature branches.
Publication
License
This project is licensed under MIT License - see the License file for details.
Acknowledgments
This work has received support from the Korea International Cooperation Agency (KOICA) under the project entitled “Education and Research Capacity Building Project at University of Medicine and Pharmacy at Ho Chi Minh City”, conducted from 2024 to 2025 (Project No. 2021-00020-3).
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 prodock-0.1.0.tar.gz.
File metadata
- Download URL: prodock-0.1.0.tar.gz
- Upload date:
- Size: 8.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d35bc51f45d3baa969c368f5aed899ff9d2172a4c9b1acd713e71360f6079793
|
|
| MD5 |
a102adac15dda1700647ddd3aada0769
|
|
| BLAKE2b-256 |
bc7129466377547604dbef1b0954951533cfe4dab46b20b24bcf07a68b3e6bdc
|
Provenance
The following attestation bundles were made for prodock-0.1.0.tar.gz:
Publisher:
publish-package.yml on Medicine-Artificial-Intelligence/ProDock
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prodock-0.1.0.tar.gz -
Subject digest:
d35bc51f45d3baa969c368f5aed899ff9d2172a4c9b1acd713e71360f6079793 - Sigstore transparency entry: 1226994669
- Sigstore integration time:
-
Permalink:
Medicine-Artificial-Intelligence/ProDock@9ff9f14839b65800b7b25b4e04d84fba93de3523 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/Medicine-Artificial-Intelligence
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-package.yml@9ff9f14839b65800b7b25b4e04d84fba93de3523 -
Trigger Event:
release
-
Statement type:
File details
Details for the file prodock-0.1.0-py3-none-any.whl.
File metadata
- Download URL: prodock-0.1.0-py3-none-any.whl
- Upload date:
- Size: 8.1 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
919d0782cc876a30217b5fae5d49a34c239e82dc2f9ab81620dfe0c85002e183
|
|
| MD5 |
cbd50743d47e3ec15f20416400eac77d
|
|
| BLAKE2b-256 |
e64e0173bb2b24949c00426ac6b51ca65e922b3c24d62e4bb96b50d11542030c
|
Provenance
The following attestation bundles were made for prodock-0.1.0-py3-none-any.whl:
Publisher:
publish-package.yml on Medicine-Artificial-Intelligence/ProDock
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prodock-0.1.0-py3-none-any.whl -
Subject digest:
919d0782cc876a30217b5fae5d49a34c239e82dc2f9ab81620dfe0c85002e183 - Sigstore transparency entry: 1226994894
- Sigstore integration time:
-
Permalink:
Medicine-Artificial-Intelligence/ProDock@9ff9f14839b65800b7b25b4e04d84fba93de3523 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/Medicine-Artificial-Intelligence
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-package.yml@9ff9f14839b65800b7b25b4e04d84fba93de3523 -
Trigger Event:
release
-
Statement type: