Syndirella
Generates and scores synthetically tractable elaborations from fragment screens
Install / Use
/learn @oxpig/SyndirellaREADME
Syndirella (Synthesis Directed Elaborations) is a tool for generating and scoring synthetically practical elaborations of molecules designed from fragment screens. Starting from the retrosynthetic analysis of fragment merged molecules, superstructures of the original reactants are found by catalog search and filtered by selectivity issues. The elaborated final products are defined by reaction SMIRKS patterns and energy minimized in the protein with restraints to experimental data.
Preprint: https://chemrxiv.org/engage/chemrxiv/article-details/68d4f08ff416303770403a44
Documentation
Full Documentation - Complete user guide, API reference, and examples
Quick Start
Installation
conda create -n syndirella python=3.10
conda activate syndirella
pip install syndirella
pip install aizynthfinder
python -c 'import pyrosetta_installer; pyrosetta_installer.install_pyrosetta()' # run once, for Fragmenstein
Note: PyRosetta is required by Fragmenstein to operate. Syndirella does not use PyRosetta by default to score compounds. PyRosetta is available for academic and non-commercial use (see PyRosetta License).
Troubleshooting:
cgrtools fails to install:
pip install "cython<3.2"
conda install -c conda-forge c-compiler cxx-compiler
pip install --no-build-isolation cgrtools
Install with HIPPO (optional)
pip install aizynthfinder --no-deps # HIPPO requires `rdkit>=2024.9.6`; AiZynthFinder declares `rdkit<2024`. Install in this order so pip does not pull AiZynthFinder’s RDKit
pip install syndirella[hippo]
conda install -c conda-forge chemicalite
See the HIPPO documentation for full setup and version compatibility.
Basic Usage
-
Setup AiZynthFinder (required for retrosynthesis):
⚠️ WARNING: This step downloads large model files (~750MB total) if run the first time. These are required to run AiZynthFinder.
Files will be downloaded to:
[syndirella_package_path]/aizynth/syndirella setup-aizynth -
Run the pipeline:
syndirella run --input /absolute/path/to/input.csv --output /absolute/path/to/output_directory --templates /absolute/path/to/templates/ --hits_path /absolute/path/to/fragments.sdfNote: All paths must be absolute paths.
Example Input
Create a CSV file with your fragment data. Hit names must match the exact names in your SDF file:
smiles,hit1,hit2,hit3,template,compound_set
O=C(NC1CC(C(F)(F)F)C1)c1cc2ccsc2[nH]1,A71EV2A-x0556_A_147_1_A71EV2A-x0526+A+147+1,A71EV2A-x0566_A_147_1_A71EV2A-x0526+A+147+1,,Ax0310a_apo-desolv,my_compound_set
CC(=O)Nc1cc(CC(=O)NCC(NC(=O)CCl)c2cccnc2)c(NC(C)=O)nn1,A71EV2A-x1346_A_250_1_A71EV2A-x0526+A+147+1,,,Ax1346a_apo-desolv,my_compound_set
For complete examples and templates, see the run_syndirella_example directory.
Output Files
The main output file to read is the structured_output.pkl.gz file, which contains:
- Complete synthesis routes with reaction details
- Placement information with energy values
- Structural quality metrics
- Product information and success flags
This file contains all the information needed to analyze and reproduce the elaborations.
Requirements
- Python 3.10
- RDKit
- AiZynthFinder
- Fragmenstein
- Additional dependencies (see pyproject.toml)
Learn More
- Examples - Jupyter notebooks and sample data
- User Guide - Detailed usage instructions
- Reaction Constants - Advanced reaction settings and options
License
This project is licensed under the MIT License.
Related Skills
node-connect
344.4kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
99.2kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
344.4kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
344.4kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
