Toolbox for chemical synthesis planning
Project description
End-to-end retrosynthetic planning from raw reaction data
SynPlanner is an open-source tool for retrosynthetic planning.
It integrates Monte Carlo Tree Search (MCTS) with graph neural networks
to evaluate applicable reaction rules (policy network) and
the synthesizability of intermediate products (value network).
- Data curation: standardize and filter raw chemical reaction data
- Rule extraction: extract reaction templates with configurable specificity
- Model training: train policy and value networks (supervised + RL)
- Retrosynthesis: MCTS-based planning with multiple search strategies
- Route quality: competing-sites scoring for functional group selectivity (Westerlund et al.)
- Route clustering: group routes by strategic bonds (Gilmullin et al.)
- Visualization: HTML route reports and interactive GUI
Installation
Requires: Python 3.10 – 3.14 · Linux x86_64, macOS arm64 · Docker images for other platforms
pip install SynPlanner
synplan --version
Quick start
1. Download pre-trained models, rules, and building blocks:
synplan download_preset --preset synplanner-article --save_to synplan_data
2. Run planning on a target molecule:
synplan planning \
--config configs/planning_standard.yaml \
--targets targets.smi \
--reaction_rules synplan_data/policy/supervised_gcn/v1/reaction_rules.tsv \
--building_blocks synplan_data/building_blocks/emolecules-salt-ln/building_blocks.tsv \
--policy_network synplan_data/policy/supervised_gcn/v1/v1/ranking_policy.ckpt \
--results_dir planning_results
[!TIP] Try it in the browser, no installation required: Retrosynthetic planning · Benchmarking · Route clustering
The full CLI includes commands for every pipeline step: reaction_mapping, reaction_standardizing, reaction_filtering, rule_extracting, ranking_policy_training, planning, clustering, and more. Run synplan --help for the complete list.
For local tutorials covering all steps from data curation to protection scoring, see the tutorials/ directory and the documentation.
Team
Questions & bug reports: open an issue or contact Tagir Akhmetshin (lead developer) and Almaz Gilmullin (clustering module)
Contributors: Timur Madzhidov (initiator), Alexandre Varnek (supervisor), Dmitry Zankov (data curation, tutorials, reproducibility), Philippe Gantzer (GUI, writing module), Dmitry Babadeev (planning, visualization), Anna Pinigina (rule extraction), Milo Roucairol (search strategies), Mikhail Volkov (testing)
Citation
If you use SynPlanner in your research, please cite:
Akhmetshin, T.; Zankov, D.; Gantzer, P.; Babadeev, D.; Pinigina, A.; Madzhidov, T.; Varnek, A. SynPlanner: An End-to-End Tool for Synthesis Planning. J. Chem. Inf. Model. 2025, 65 (1), 15–21. doi:10.1021/acs.jcim.4c02004
If you use route clustering, please also cite:
Gilmullin, A.; Akhmetshin, T.; Madzhidov, T.; Varnek, A. Route Clustering by Strategic Bonds. ChemRxiv, 2025. doi:10.26434/chemrxiv-2025-lnkz6-vz
If you use the protection / route quality scoring, please also cite:
Westerlund, A. M. et al. Toward Lab-Ready AI Synthesis Plans with Protection Strategies and Route Scoring. ChemRxiv, 2025. doi:10.26434/chemrxiv-2025-68ff6
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
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 synplanner-1.4.3-py3-none-any.whl.
File metadata
- Download URL: synplanner-1.4.3-py3-none-any.whl
- Upload date:
- Size: 248.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.12 {"installer":{"name":"uv","version":"0.10.12","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8939236f474e6645a8e1a10203593324e0055b461039c1a53030ce7ee6827e1d
|
|
| MD5 |
c94cc576ba7a2259dc00b3be64be0045
|
|
| BLAKE2b-256 |
ac3bb41b7794d23a35fce2781e48405979f91d5d254fb65d1cd84adb6db16eb0
|