When converting molecules with wavy bonds (Bond::STEREOANY on double bonds) through InChI and back, the stereo information was silently dropped. This affected any workflow using InChI roundtrips for canonicalization (e.g. with -SUU flag). Two bugs in External/INCHI-API/inchi.cpp: Reverse path (InchiToMol): The stereo0D processing loop skipped INCHI_PARITY_UNDEFINED entries before they could reach the double bond handler. The handler already had an else clause that correctly sets Bond::STEREOANY, but it was never reached. Fix: only skip INCHI_PARITY_NONE at the top level, and add a guard in the Tetrahedral case to prevent UNDEFINED/UNKNOWN from incorrectly setting chirality. Forward path (MolToInchi): STEREOANY double bonds were only handled by collapsing the coordinates — InChI then produced no stereo annotation under -SUU. Fix: also emit a stereo0D entry with INCHI_PARITY_UNKNOWN parity so InChI's -SUU output correctly carries the "stereo unknown" designation. StereoAtoms may be cleared for STEREOANY, so we locate the two outer neighbors by iterating bonds. New test testStereoAnyRoundtrip in External/INCHI-API/test.cpp covers 9 representative cases (Schiff base, oxime, cinnamic acid, chalcone, crotonaldehyde, tamoxifen-like, retinal-like, plus two molecules with a chiral center adjacent to the wavy bond). Counts in rdkit/Chem/UnitTestInchi.py shift by 1 (689 same, 492 reasonable) because the new STEREOANY emission produces a more accurate roundtrip for one entry in the test inventory. Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
RDKit
What is it?
The RDKit is a collection of cheminformatics and machine-learning software written in C++ and Python.
- BSD license - a business friendly license for open source
- Core data structures and algorithms in C++
- Python 3.x wrapper generated using Boost.Python
- Java and C# wrappers generated with SWIG
- JavaScript (generated with emscripten) and CFFI wrappers around important functionality
- 2D and 3D molecular operations
- Descriptor and Fingerprint generation for machine learning
- Molecular database cartridge for PostgreSQL supporting substructure and similarity searches as well as many descriptor calculators
- Cheminformatics nodes for KNIME
- Contrib folder with useful community-contributed software harnessing the power of the RDKit
Installation and getting started
If you are working in Python and using conda (our recommendation), installation is super easy:
$ conda install -c conda-forge rdkit
You can then take a look at our Getting Started in Python guide.
More detailed installation instructions are available in Docs/Book/Install.md.
Documentation
Available on the RDKit page and in the Docs folder on GitHub
The RDKit blog often has useful tips and tricks.
Support and Community
If you have questions, comments, or suggestions, the best places for those are:
If you've found a bug or would like to request a feature, please create an issue
We also have a LinkedIn group
We have a yearly user group meeting (the UGM) where members of the community do presentations and lightning talks on things they've done with the RDKit. Materials from past UGMs, which can quite useful, are also online:
- 2012 UGM, London
- 2013 UGM, Hinxton
- 2014 UGM, Darmstadt
- 2015 UGM, Zurich
- 2016 UGM, Basel
- 2017 UGM, Berlin
- 2018 UGM, Cambridge
- 2019 UGM, Hamburg
- 2020 UGM, virtual
- 2021 UGM, virtual
- 2022 UGM, Berlin
- 2023 UGM, Mainz
- 2024 UGM, Zurich
License
Code released under the BSD license.