Release Notes
Release V1.3.0
New Functionality and Features
The LigandScout PML data I/O code now reads/writes the value of the pharm. feature attribute envCompound which provides information about environment residues that interact with the feature. The read/written value is stored to/taken from the feature property Pharm::FeatureProperty::ENVIRONMENT_RESIDUE_INFO (see API Changes for further information)
New fingerprint/descriptor-based similarity screening command line tool simscreen
New functionality for the generation and export of 3D visual representations of Pharm::FeatureContainer instances in Stereolithography (STL), Virtual Reality Modeling Language 97 (VRML), Polygon File Format (PLY) and Raster3D (R3D) format (see API Changes)
Added infrastructure for the construction and on disk storage of arbitrary 3D object scene graphs (see API Changes)
Added support for the display of 2D structure renderings of Chem::MolecularGraph and Chem::Reaction instances in Jupyter notebooks
Added methods controlling whether hydrogen atoms shall be included or not when perceiving the bond paths of a molecular graph for path fingerprint generation (class Descr::PathFingerprintGenerator, see API Changes)
The command line tool tautgen provides two new options -r and -R that allow control whether input 2D or 3D atom coordinates shall be retained (might lead to distorted and/or invalid 2D/3D structures) or removed (default) from the generated tautomers
SMILES reading/writing code has been extended to support atoms with the novel type Chem::AtomType::R (see API Changes)
Added methods to class Descr::NPointPharmacophoreFingerprintGenerator allowing to set a callback function that tells for each pharm. feature whether it shall be considered for fingerprint generation or not (see API Changes)
New option –conj-ring-bond-pattern of command line tool tautgen for enabling (= default setting)/disabling a new tautomerization rule that flips the orders of bonds in conjugated rings having one or more N, O, S, Se or P substituent(s) bearing at least one hydrogen (see API Changes)
New control-parameter allowing to specify what kind of bond type shall be output for aromatic bonds when writing molecular graph data in an MDL CTab based format (see API Changes)
It is now possible to customize the way how atom, bond and molecular graph match expression functions employed for common connected substructure matching will be retrieved (see API Changes)
New function (see API Changes) that computes and carries out a transformation which aligns 2D coordinates of a set of atoms with given reference coordinates in the best possible way
New class (see API Changes) implementing the perception of the functional groups of a molecular graph by P. Ertl’s algorithm
New control-parameter (plus associated functions, see API Changes) that for SMILES output allows to determine whether implicit hydrogen count specifications for atoms requiring brackets shall be written or not (default: yes)
New utility functions that perform 2D visualization specific setup work for Chem::MolecularGraph and Chem::Reaction instances
New class and utility functions implementing the editing of atoms and/or bonds of molecular graph substructures according to a specified target substructure template (see API Changes)
C++ standard input, output and error streams are now exposed as class variables of the CDPL Python API class Base.IStream (see API Changes for further details)
New method of the CDPL Python API class Base.StringIOStream that allows to retrieve written data as Python bytes object
Improvements
CDPL Python bindings now also work with free-threaded CPython builds (V3.13t and V3.14t)
The extraction of property table view column names from SD-file property record headers in program ChOX is now more robust
The SDF reader now does not raise an exception anymore if the last molecule record lacks a $$$$ delimiter
Readers for various text-based file formats now allow the last line of a file to be terminated directly by EOF
Significant improvement of the tautomer scoring function with focus on the evaluation of hydroxy-pyridine containing and highly conjugated molecule tautomers
Made the ChEMBL standardization code also work with Chem::MolecularGraph instances if the standardization result shall be stored in a supplied Chem::Molecule instance
Support for the automated generation and installation of a CMake package configuration file that significantly lowers the barrier for downstream C++ applications to use functionality provied by the CDPL C++ API
Improved and much more comprehensive Sphinx documentation index page
Complete overhaul of the CDPL Python tutorial which is now based on a Jupyter notebook (made available for download)
Additional Python cookbook script demonstrating the calculation of Kuvek binding pocket shape and electrostatics descriptors
Additional Python cookbook script demonstrating the molecule substrucuture editing functionality
Additional Python cookbook script demonstrating the perception of functional groups of molecular graphs
Additional Python cookbook script demonstrating the generation of visual 3D representations of pharmacophore models
Bug Fixes
Fixed methods write() and writelines() of the CDPL Python API class Base.IOStream which both failed when being called with an argument of type str or sequences thereof
Fixed an issue with the command line tool psdscreen where the default value of option -u was not properly set at program startup. In screening mode
ALL-MATCHES, multiple program executions using the same input files might thus have led to varying number of reported hitsFixed an issue with spiro ring systems in the implementation of the Extended Smallest Set of Smallest Sings (ESSSR) perception algorithm (class Chem::ExtendedSSSR)
API Changes
New class Descr::KuvekPocketDescriptorCalculator implementing a method developed by Kuvek et al. for the calculation of receptor binding pocket shape and electrostatics descriptors
New pharm. feature property Pharm::FeatureProperty::ENVIRONMENT_RESIDUE_INFO (plus associated functions) which stores a string representing a comma-separated list of identifiers of environment residues that were found to interact with the feature
New setter/getter method pair Descr::PathFingerprintGenerator::includeHydrogens()/Descr::PathFingerprintGenerator::hydrogensIncluded() controlling whether hydrogen atoms shall be included or not when perceiving the bond paths of a molecular graph
New method getbytes() of the CDPL Python API class Base.StringIOStream that allows to retrieve written data as Python bytes object
New setter/getter method pair Descr::NPointPharmacophoreFingerprintGenerator::setFeatureFilterFunction/Descr::NPointPharmacophoreFingerprintGenerator::getFeatureFilterFunction() allowing to set a callback function that tells for each pharm. feature whether it shall be considered for fingerprint generation or not
Declaration of new type Vis::STLFeatureContainerWriter implementing the output of visual 3D representations of Pharm::FeatureContainer instances in the Stereolithography (STL) format
Declaration of new type Vis::PLYFeatureContainerWriter implementing the output of visual 3D representations of Pharm::FeatureContainer instances in the Polygon File Format (PLY)
Declaration of new type Vis::VRMLFeatureContainerWriter implementing the output of visual 3D representations of Pharm::FeatureContainer instances in the Virtual Reality Modeling Language 97 (VRML) format
Declaration of new type Vis::R3DFeatureContainerWriter implementing the output of visual 3D representations of Pharm::FeatureContainer instances in the Raster3D (R3D) format
New class template Vis::FeatureContainerObject3DWriter implementing the output of visual 3D representations of Pharm::FeatureContainer instances in a supported output format (currently PLY, STL, R3D and VRML)
Declaration of new type Vis::STLFeatureContainerOutputHandler mediating the output of visual 3D representations of Pharm::FeatureContainer instances in the Stereolithography (STL) format
Declaration of new type Vis::PLYFeatureContainerOutputHandler mediating the output of visual 3D representations of Pharm::FeatureContainer instances in the Polygon File Format (PLY)
Declaration of new type Vis::VRMLFeatureContainerOutputHandler mediating the output of visual 3D representations of Pharm::FeatureContainer instances in the Virtual Reality Modeling Language 97 (VRML) format
Declaration of new type Vis::R3DFeatureContainerOutputHandler mediating the output of visual 3D representations of Pharm::FeatureContainer instances in the Raster3D (R3D) format
New class Vis::STLObject3DWriter implementing the output of 3D scene data described by Vis::Object3D instances in the Stereolithography (STL) format
New class Vis::VRMLObject3DWriter implementing the output of 3D scene data described by Vis::Object3D instances in the Virtual Reality Modeling Language 97 (VRML) format
New class Vis::PLYObject3DWriter implementing the output of 3D scene data described by Vis::Object3D instances in the Polygon File Format (PLY)
New class Vis::R3DObject3DWriter implementing the output of 3D scene data described by Vis::Object3D instances in the Raster3D (R3D) format
Declaration of new type Vis::STLObject3DOutputHandler mediating the output of 3D scene data described by Vis::Object3D instances in the Stereolithography (STL) format
Declaration of new type Vis::PLYObject3DOutputHandler mediating the output of 3D scene data described by Vis::Object3D instances in the Polygon File Format (PLY)
Declaration of new type Vis::VRMLObject3DOutputHandler mediating the output of 3D scene data described by Vis::Object3D instances in the Virtual Reality Modeling Language 97 (VRML) format
Declaration of new type Vis::R3DObject3DOutputHandler mediating the output of 3D scene data described by Vis::Object3D instances in the Raster3D (R3D) format
Declaration of new type Vis::Object3DWriter for the output of 3D scene data described by Vis::Object3D instances in a supported output format (currently PLY, STL, R3D and VRML)
Declaration of new type Vis::Object3DReader for reading 3D model data stored in a supported input format (none, currently) into a given Vis::Object3D instance
New control-parameter default values Vis::ControlParameterDefault::FEATURE_COLOR_TABLE, Vis::ControlParameterDefault::DEFAULT_MATERIAL and Vis::ControlParameterDefault:SHOW_FEATURE_CENTERS
New control-parameters Vis::ControlParameter::FEATURE_COLOR_TABLE, Vis::ControlParameter::DEFAULT_MATERIAL and Vis::ControlParameter::SHOW_FEATURE_CENTERS plus associated functions
New data format descriptors Vis::DataFormat::STL, Vis::DataFormat::PLY, Vis::DataFormat::VRML and Vis::DataFormat::R3D
New class Vis::FeatureContainerObject3DFactory implementing the creation of a visual 3D representation of Pharm::FeatureContainer instances
New class Vis::Object3DFactory defining the common interface of classes which implement the creation of 3D representations (as Vis::Object3D instances) of different types of built-in data structures (e.g. Pharm::FeatureContainer, Chem::MolecularGraph, …)
New class Vis::DefaultFeatureColorTable specifying default colors for built-in pharmacophoric feature types
New utility functions Vis::subdivideSpherical(), Vis::removeVertexDuplicates(), Vis::calcVertexFromFaceNormals(), Vis::translate(), Vis::scale(), Vis::rotateX(), Vis::rotateY(), Vis::rotateZ() and Vis::transform() for the manipulation of Vis::TriangleMesh3D objects
New class Vis::IcosahedronMesh3D implementing the generation of icosahedron vertices and faces
New class Vis::RightFrustumMesh3D implementing the creation of triangle meshes modeling various shapes in the right frustum category (arbitary (truncated) pyramids)
New class Vis::TorusMesh3D implementing the creation of triangle meshes modeling the shape of a torus
New class Vis::TriangleMesh3D used to store the basic data (vertices, faces, vertex normals) of triangle meshes
New property default values Vis::Object3DPropertyDefault::SHAPE and Vis::Object3DPropertyDefault::TRANSFORMATION_MATRIX
New properties Vis::Object3DProperty::SHAPE, Vis::Object3DProperty::TRANSFORMATION_MATRIX and Vis::Object3DProperty::MATERIAL plus associated functions
New class Vis::Shape3DVisitor for the type-safe processing of Vis::Shape3D subclass instances
New class Vis::Shape3D serving as base class of data structures implementing the description of particular types of 3D shape geometries
New class Vis::Material for the specification of ambient, diffuse, specular color and translucency properties of a 3D shapes’s material
New class Vis::Object3D which allows to store the description of the geometry of an arbitrary 3D shape together with a transformation matrix and material properties. Moreover, Vis::Object3D instances may be used to build a simple 3D scene graph by connecting Vis::Object3D instances in a parent -> child object(s) manner
Renamed functions Biomol::*PDBIgnoreConectRecordsParameter() into Biomol::*PDBIgnoreCONECTRecordsParameter()
Removed namespace Vis::AtomColorTable
New class Vis::DefaultAtomColorTable replacing Vis::AtomColorTable namespace member ELEMENT_COLORS_2D
New atom type constant Chem::AtomType::R for the specification of atoms representing R-groups
Signature of method Base::DataOutputHandler::createWriter(std::iostream&) has been changed to Base::DataOutputHandler<T>::createWriter(std::ostream&) in order to support write-only output streams
New control-parameter default value Chem::ControlParameterDefault::MDL_OUTPUT_AROMATIC_BOND_TYPES
New control-parameter Chem::ControlParameter::MDL_OUTPUT_AROMATIC_BOND_TYPES plus associated functions allowing to specify what kind of bond type shall be output for aromatic bonds when writing molecular graph data in an MDL CTab based format
Added methods to class Chem::CommonConnectedSubstructureSearch that allow to customize the way atom, bond and molecular graph match expression functions employed for substructure matching will be retrieved (default: use the expressions provided as properties)
New function Chem::align2DCoordinates() that computes and carries out a transformation which aligns 2D coordinates of a set of atoms with given reference coordinates in the best possible way
New molecular graph property MolProp::MolecularGraphProperty::FUNCTIONAL_GROUPS plus associated functions for the storage of perceived functional groups (see below)
New class MolProp::FunctionalGroupList plus convencience functions MolProp::perceiveFunctionalGroups() that identify and extract functional group substructures of a molecular graph via the algorithm developed by P. Ertl. Core atoms/bonds of detected functional groups are made available as a list of Chem::Fragment objects. The name property (accessible via property function Chem::getName()) of each func. group fragment then provides the generalized form of the functional group as a canonical SMILES string
New control-parameter default value Chem::ControlParameterDefault::SMILES_OUTPUT_HYDROGEN_COUNT
New control-parameter Chem::ControlParameter::SMILES_OUTPUT_HYDROGEN_COUNT plus associated functions allowing to control whether implicit hydrogen count specifications for atoms in brackets shall be written on SMILES output
Added new tautomerization rule identifier Chem::TautomerizationType::CONJ_RING_BOND_SWITCH
New tautomerization rule implementation Chem::ConjugatedRingBondPatternSwitching for flipping the orders of bonds in conjugated rings having one or more N, O, S, Se or P substituent(s) bearing at least one hydrogen
New utility functions Vis::prepareFor2DVisualization() that perform 2D visualization specific setup work for Chem::MolecularGraph and Chem::Reaction instances
New utility functions Chem::editSubstructures() for editing substructures of Chem::Molecule instances (directly or as a copy of a given Chem::MolecularGraph instance). The substructure search and optional exclude pattern(s) are specified by SMARTS strings. Multiple search/exclude patterns can be specified as whitespace separated lists of the respective patterns. The editing result pattern is provided as a SMILES string (with SMILES extensions implemented especially for substructure editing)
New class Chem::SubstructureEditor for editing the atoms and/or bonds of molecular graph substructures according to a specified target substructure template
C++ standard input, output and error streams (std::cin, std::cout and std::cerr) are now exposed as class variables Base.IStream.STD_IN, Base.OStream.STD_OUT and Base.OStream.STD_ERR, respectively For example, Base.IStream.STD_IN might be passed as argument to the constructor of a Chem.MoleculeReader instance which will then read molecule data from the standard input of the current process
Miscellaneous Changes
Generated SMILES, SMARTS, JME and INCHI output data now, by default, end with a newline character which is more in line with user expectations
The default feature distance bin size used by Descr::NPoint3DPharmacophoreFingerprintGenerator instances has been changed to 3.0 (before 0.5)
The default feature distance bin size used by Descr::NPointPharmacophoreFingerprintGenerator instances has been changed to 2.0 (before 0.5)
The calculation of Manhattan similarity scores has bee changed so that a value of 1.0 now indicates the highest possible similarity and 0.0 the lowest one (before: highest sim. = 0.0, lowest sim. = 1.0)
The command line tool tautgen now removes all for the sake of processing added explicit hydrogens from the generated tautomers before output
The screening hit rate reported by command line tool psdscreen now always specifies the number of matched unique database molecules in relation to the total amount of screened molecules - irrespective of the number of query pharmacophores and screening mode (-m option)
Release V1.2.3
New Functionality and Features
New feature of program ChOX that allows to display structure/reaction data associated with the currently shown molecule/reaction records
See section below
Bug Fixes
Fix for a Base::ItemNotFound exception thrown during the merging of temporary PSD files when running the command line tool psdcreate in multi-threaded mode
API Changes
New control-parameters Chem::ControlParameter::MOL2_READ_PARTIAL_AS_FORMAL_CHARGES and Chem::ControlParameter::MOL2_OUTPUT_FORMAL_CHARGES plus associated setter/getter functions that allow to control whether formal instead of partial charges shall be read from/written to MOL2 files
New class template Descr::BulkSimilarityCalculator for the calculation of multiple query <-> target descriptor similarities/distances in a single run
Similarity and distance functions in namespace Descr are now also available as functor classes (e.g. Descr::TanimotoSimilarity)
New similarity and distance functions supporting generic mathematical vectors
Release V1.2.2
New Functionality and Features
The command line tool psdcreate now offers the possibility to process only a subset of the input molecules which can be specified by means of a start (option -s) and an end molecule index (option -e)
The command line tool psdscreen now offers a new option -r that allows to specify a report file in which sceening hit molecule information will be written as lines of tab-separated values (i.e., without any mol. structure data). The new option can be used in additon or instead of option -o which, as before, specifies an output file for saving aligned hit molecule structures
Improvements
Reduction of RAM consumption when querying pharmacophore feature count data stored in *.psd files
Reduction of pharmacophore screening database (PSD) file sizes by ~55% due to the introduction of more compact molecule/pharmacophore data storage formats
Additional Python cookbook script demonstrating how to use the stereoisomer enumeration functionality
Bug Fixes
Fix for an issue leading to a segmentation fault during the parsing of partially invalid SMILES/SMARTS strings that occurs if a ring closure at a chiral atom cannot be completed due to either missing or erroneously placed closure bond numbers
Fix for a bug in the command line tool structgen that led to process termination due to a Base::ItemNotFound exception which was thrown when the set time limit got exceeded without having generated a complete set of 3D atom coordinates
API Changes
Added new setter/getter method pair outputZeroBasedIndices(bool)/outputZeroBasedIndices() to class Pharm::FileScreeningHitCollector that allows to control whether any indices (mol. index, conf. index, etc.) stored as SD-entries of output molecules shall be zero- or one-based
Release V1.2.1
Improvements
New implementation of Greene’s algorithm for the calculation of atom hydrophobicities which is now more correct and ~100 times faster than the previous one
Additional Python cookbook scripts
Documentation updates
All disk space consumed by an existing pharmacophore screening database (PSD) that is specified as destination file for a new database to be created by the tool subsearch is now completely freed and not just internally marked as unallocated space
Bug Fixes
Fix for function Pharm::removePositionalDuplicates(Pharmacophore&) which erroneously retained the duplicate features (to be removed) instead of the desired features all having unique position and type
Release V1.2.0
New Functionality and Features
New utility functions for the manipulation of pharmacophore data
New command line tool subsearch for substructure searching on molecular data files with support for multiple query substructures and customizable logical expressions
Added support for the I/O of molecular structure data in CML format
Added support for the I/O of macromolecular structure data in mmCIF format
New atom classification functions for the detection of bridgehead atoms and spirocenters in complex ring systems
The residue database now also provides parent structure and single letter code information for a query residue
New class implementing substructure searching with multiple query substructures that can be combined by boolean expressions
New class implementing the generation of variably sized hashed 2D and 3D pharmacophore fingerprints
New class implementing the generation of 881 bit PubChem fingerprints
New class implementing the generation of 166 bit MACCS key fingerprints
New class implementing the perception of the extended smallest set of smallest rings of molecular graphs (ESSSR)
New class implementing the visualization of multiple molecules as separate 2D structure diagrams arranged in a grid of arbitrary size
New 2D graphics primitive for the rendering of multi-line text blocks supporting several options for the styling of individual text fragments
New control-parameter allowing to customize the resolution of 2D structure/reaction depictions saved in a pixel-based output format
Support for atom and bond highlighting in 2D structure/reaction depictions
Support for the rendering of custom atom and bond labels in 2D structure/reaction depictions
Improvements
Improved the visual appearance of command line tool progress bars
Additional Python cookbook scripts
Sphinx documentation updates
Improved support for different Python installation flavors on macOS (the help provided by Yakov Pechersky is greatly appreciated)
Perception of atom/bond stereochemistry from input 3D coordinates in the conformer generation molecule preprocessing stage now does not require the presence of explicit hydrogens anymore
Updated PDB/mmCIF residue dictionary which now features 44906 chemical components
CDPL Python bindings now support NumPy V≥2.0
Program ChOX now uses the same file open/save dialog instance for all opened main windows
Program ChOX now supports basic cut/copy/paste as well as drag and drop operations
Program ChOX now allows to perform substructure searching with logical combinations of SMARTS patterns
Program ChOX now allows to highlight substructures defined by SMARTS patterns
The SDF data reader (class Chem::SDFMoleculeReader) now also accepts input data that do not end with a newline character
Made the MOL2 data reader (class Chem::MOL2MoleculeReader) more tolerant regarding missing sections
Extended the set of supported chemical elements to atomic number 114
Control-parameter Vis::ControlParameter::BACKGROUND_COLOR was replaced by Vis::ControlParameter::BACKGROUND_BRUSH which now allows to also specify a background fill pattern (see class Vis::Brush) for 2D structure renderings
Class Vis::CairoRenderer2D now supports the rendering of overlined, underlined and striked-out text
Support for setting the image output scaling factor in the program ChOX
Bug Fixes
Fixed an issue concerning the calculation of pharmacophore fit scores that previously also considered mappings of multiple query features to the same target feature. Now, more correctly, the best score that could be calculated for all possible one-to-one feature mappings is reported.
Fixed a bug in program ChOX that prevented the successful saving of data in *.psd format
Fixed the missing support for certain chemical element symbols in class Chem::SMARTSMoleculeReader
Fixed a bug in class Math::RegularSpatialGrid that caused an erroneous transformation of world to grid-local coordinates
Fixed a problem in Chem::RECAPFragmentGenerator that lead to the generation of too few fragments for H-depleted molecules
Fixed a problem in Chem::BRICSFragmentGenerator that lead to the generation of too few fragments for H-depleted molecules
Fixed an issue with the calculation of text bounds in the implementation of classes Vis::CairoFontMetrics and Vis::QtFontMetrics that lead to too small bounding boxes in the presence of leading and/or trailing whitespace
Fixed an issue with whitespace-only data elements that were missing in the DOM-trees generated by the internally used RapidXml XML-parser library
Fixed an issue in program ChOX where the background color setting of 2D structure/reaction depictions got ignored when saving data in an image output format
Fixed several minor bugs in Python cookbook scripts
API Changes
New setter/getter method pair groupReferenceFeatures()/referenceFeaturesGrouped() in class Pharm::PharmacophoreFitScore for controlling whether multiple directed features of the same type at the same position shall be considered as independent individual features or as different orientation options of a single feature
New utility functions Pharm::clearOrientations(), Pharm::removePositionalDuplicates(), Pharm::removeFeaturesWithType() for the manipulation of pharmacophore data
Unified the naming of control-parameters and associated functions in namespaces Chem, Pharm, Grid, and Biomol
Renamed function MolProp::isCarbonylLikeAtom() into MolProp::isCarbonylLike()
Renamed function MolProp::isAmideCenterAtom() into MolProp::isAmideCenter()
New atom classification functions MolProp::isBridgehead() and MolProp::isSpiroCenter()
New control-parameters, properties and associated functions in namespace Chem for CML data I/O
New constants in namespace Biomol::ResidueType which now fully cover the set of residue types defined by the mmCIF/PDBX specification
Renamed some previously PDB format-specific control-parameters and associated functions in namespace Biomol for dual-use by the mmCIF data I/O code
New class Biomol::MMCIFMoleculeReader for reading macromolecular data in mmCIF format
New class Biomol::MMCIFMolecularGraphWriter for writing macromolecular data in mmCIF format
New class Chem::CMLMoleculeReader for reading molecular data in CML format
New class Chem::CMLMolecularGraphWriter for writing molecular data in CML format
New data format descriptors in namespaces Chem::DataFormat and Biomol::DataFormat
New class Biomol::MMCIFData for the in-memory storage and postprocessing of mmCIF formatted input data
Added new method getParentCode() to classes Biomol::ResidueDictionary and Biomol::ResidueDictionary::Entry for the lookup of residue parent structure information
Added new method getOneLetterCode() to classes Biomol::ResidueDictionary and Biomol::ResidueDictionary::Entry for the lookup of residue single letter codes
New control-parameters, atom properties and associated functions in namespace Biomol for mmCIF data I/O
Removed function Biomol::convertMOL2ToPDBResidueInfo() (the conversion of MOL2 substructure to PDB residue/sequence information is now carried out automatically)
New class Chem::MultiSubstructureSearch for performing substructure searching with multiple query substructures that can be combined by boolean expressions
New classes Descr::NPoint2DPharmacophoreFingerprintGenerator and Descr::NPoint3DPharmacophoreFingerprintGenerator for the generation of variably sized hashed 2D and 3D pharmacophore fingerprints
Removed methods setNumBits() and getNumBits() of class Descr::PathFingerprintGenerator (fp-length is now implicitly given by the size of the Util::BitSet instance provided as argument to method generate())
New class Descr::PubChemFingerprintGenerator for the generation of 881 bit PubChem fingerprints
New class Chem::ExtendedSSSR for the perception of the extended smallest set of smallest rings (ESSSR)
New class Descr::MACCSFingerprintGenerator for the generation of 166 bit MACCS key fingerprints
New class Vis::StructureGridView2D for the visualization of molecules as 2D structure diagrams arranged in a grid of arbitrary size
New class Vis::TextBlockPrimitive2D for the rendering of multi-line text blocks supporting several options for the styling of individual text fragments
New control-parameter Vis::ControlParameter::OUTPUT_SCLAING_FACTOR that allows to achieve higher resolutions of 2D structure/reaction depictions saved in pixel-based output formats
New control-parameters, properties and associated functions in namespace Vis for the rendering of custom atom and bond labels in 2D structure/reaction depictions
New control-parameters, properties and associated functions in namespace Vis for the customization of the atom and bond highlighting style in 2D structure/reaction depictions
Additional constants in namespace Chem::AtomType increasing the coverage of chemical elements up to atomic number 114
Miscellaneous Changes
CDPL Python bindings wheel files for Linux are now built for a manylinux_2_28 environment
Updated embedded MessagePack library to version 6.1.1
Updated embedded SQLite3 database to version 3.46.1
Updated embedded MMTF library to version 1.1.0
Updated the internally used RapidXml XML-parser library to version 1.13
Unit test case updates for functionality in namespace CDPL::Vis
Release V1.1.1
Improvements
Significantly improved the generation of 2D coordinates for macrocyclic structures
Bug Fixes
Fixed an issue with the generation of conformers under application of a fixed substructure template where the generated conformers sometimes displayed the mirror image of the specified 3D template structure
The command line tools structgen and confgen erroneously used the already reserved letter p as shortcut for the option –fixed-substr-min-atoms. The new shortcut is ~
Miscellaneous Changes
Rewrote code that uses the boost filesystem library to use C++17 equivalents
Compiling CDPKit now requires a compiler with C++17 support
Release V1.1.0
New Functionality and Features
The tool tautgen provides two new tautomer generation modes
BEST_SCORINGandBEST_SCORING_UNIQUE(the new default mode) for generating only the chemically most reasonable tautomersNew option in class Chem::TautomerGenerator that allows to suppress the output of generated tautomers which represent just a different resonance structure of a previously reported tautomeric form
New structgen feature that allows to enforce a particular 3D structure for defined parts of the input molecules
New confgen feature that allows to specify substructures of the input molecules that shall adopt a particular conformation which is then kept ‘fixed’ during conformer generation (more information and examples can be found here)
Conformer generator settings now allow to specify rotatable bond count dependent values for RMSD threshold, energy window and max. output ensemble size
The pharmacophore screening application psdscreen provides a new option –unique-hits which enforces that a database molecule matched by multiple query pharmacophores is saved only once to the output hit list
New Python example script for database preparation
New Python example script demonstrating how the torsion driving functionality can be used for conformer sampling
The visual molecule and reaction data inspection tool ChOX now allows to display atom and bond configuration labels
The 2D molecule structure rendering code (implemented by class Vis::StructureView2D) now allows to display atom and bond configuration labels
Full implementation of the CIP sequence rule stack for the correct labeling of atom and bond stereocenters (new class Chem::CIPConfigurationLabeler)
Support for reading/writing molecular structures in XYZ format (classes Chem::XYZMoleculeReader and Chem::XYZMolecularGraphWriter)
New command line application isogen for the enumeration of R/S and E/Z stereoisomers of molecules
New class Chem::StereoisomerGenerator for the exhaustive enumeration of R/S and E/Z stereoisomers
New 2D drawing primitives (classes Vis::Path2D and Vis::PathPrimitive2D) and support for clipping operations (class Vis::ClipPathPrimitive2D)
New class Chem::BemisMurckoAnalyzer for the extraction of Bemis-Murcko scaffolds
New functions for the alignment conformers
New utility functions Chem::calcBasicProperties() that ease the recurring task of initializing Chem::MolecularGraph and Chem::Reaction instances for further processing
Improvements
Overhaul of the tautomer generation code for increased efficiency and flexibility
The output conformer ensemble compilation process now strives for higher energetic diversity among the picked conformers which, on average, leads to higher accuracy in the reproduction of experimental structures (benchmarking results can be found here)
Update of the torsion library used for systematic conformer generation (more information can be found here)
Systematic conformer sampling speed optimizations
Reduction of the memory footprint of the conformer generation procedure which could become unacceptably large under some circumstances
Documentation updates and corrections
Refactoring of stereochemistry related code
Cleanup of the CDPL Python bindings code
When deep copying Chem::Reaction or Chem::Molecule instances, values of properties referencing atoms and/or bonds (e.g. stereodescriptors, SSSR) now get automatically translated to values referencing the corresponding atoms/bonds of the copying target
Cleanup of CDPL C++ header files
Added support for building CDPL Python bindings pip installer wheel files under Windows
Added support for building manylinux2014 compliant CDPL Python bindings pip installer wheel files
Build system cleanup
Bug Fixes
Fixed bugs in classes Chem::MaxCommonAtomSubstructureSearch and Chem::MaxCommonBondSubstructureSearch that led to a loss of expected matches
Fix for a bug in the SMARTS parser that lead to the storage of wrong bond directions
Bond direction specifications (up/down) in SMILES and SMARTS strings are now correctly interpreted
Fixed a bug that may lead to the generation of conformers with wrong geometries at exocyclic double bonds
Fixed a bug in the shapescreen tool that lead to the calculation of erroneous similarity scores when option –score-only was set
Fix for a minor bug that affected the indentation of SD-file property entries
Function overload resolution order fixes in the CDPL.Math Python package
Prevented the throwing of exceptions when the env. variable LC_ALL has not been initialized
API Changes
New getter/setter method pair in class Chem::TautomerGenerator for suppressing the output of generated tautomers which represent just a different resonance structure of a previously reported tautomer
Data structures with names ForceField::MMFF94XXXInteractionData were renamed into ForceField::MMFF94XXXInteractionList (XXX = force field interaction type)
New class ForceField::ElasticPotential plus elastic potential energy and gradient calculation functions
New class Chem::CIPConfigurationLabeler for the labeling of atom and bond stereocenters
New class Chem::StereoisomerGenerator for the exhaustive enumeration of R/S and E/Z stereoisomers
New classes Chem::XYZMoleculeReader and Chem::XYZMolecularGraphWriter implementing reading and writing of molecule data in XYZ format
New 2D drawing primitives (classes Vis::Path2D and Vis::PathPrimitive2D) and support for clipping operations (class Vis::ClipPathPrimitive2D)
New class Chem::BemisMurckoAnalyzer for the extraction of Bemis-Murcko scaffolds
New CDPL::Chem functions for the alignment conformers
Python exports of Util::Map and Util::MultiMap do not provide the properties keys, values, and entries anymore. They were replaced by the corresponding methods keys(), values() and items()
The MolProp::getAtomCount() function has been extended by a strict argument which, if set to
false, instructs the accounting procedure to regard the meaning of generic atom types (e.g. any halogen)New utility functions Chem::calcBasicProperties() for a more comfortable initialization of Chem::MolecularGraph and Chem::Reaction instances for further processing
Code in class GRAIL::GRAILDescriptorCalculator now calculates a shorter GRAIL descriptor (35 elements) with not further subdivided H-bond donor/acceptor feature types
Class GRAIL::GRAILDescriptorCalculator was renamed into GRAIL::GRAILXDescriptorCalculator
Release V1.0.0
- Initial release -