Chemical Data Processing Library Python API - Version 1.4.0
Public Member Functions | Properties | List of all members
CDPL.Chem.AutomorphismGroupSearch Class Reference

Enumerates the atom/bond automorphisms of a molecular graph. More...

+ Inheritance diagram for CDPL.Chem.AutomorphismGroupSearch:

Public Member Functions

None __init__ (int atom_flags=12702, int bond_flags=30)
 Constructs and initializes a AutomorphismGroupSearch instance. More...
 
int getObjectID ()
 Returns the numeric identifier (ID) of the wrapped C++ class instance. More...
 
None setAtomPropertyFlags (int flags)
 Specifies the atomic properties considered for atom matching during automorphism search. More...
 
int getAtomPropertyFlags ()
 Returns the atomic properties currently considered for atom matching. More...
 
None setBondPropertyFlags (int flags)
 Specifies the bond properties considered for bond matching during automorphism search. More...
 
int getBondPropertyFlags ()
 Returns the bond properties currently considered for bond matching. More...
 
None includeIdentityMapping (bool include)
 Specifies whether the identity mapping shall be included in the search results. More...
 
bool identityMappingIncluded ()
 Tells whether the identity mapping is included in the search results. More...
 
bool findMappings (MolecularGraph molgraph)
 Searches for the possible atom/bond mappings in the automorphism group of the given molecular graph. More...
 
None stopSearch ()
 Aborts a currently running findMappings() call. More...
 
int getNumMappings ()
 Returns the number of atom/bond mappings that were recorded in the last call to findMappings(). More...
 
AtomBondMapping getMapping (int idx)
 Returns a reference to the stored atom/bond mapping object at index idx. More...
 
int getMaxNumMappings ()
 Returns the specified limit on the number of stored atom/bond mappings. More...
 
None setMaxNumMappings (int max_num_mappings)
 Allows to specify a limit on the number of stored atom/bond mappings. More...
 
None clearAtomMappingConstraints ()
 Clears all previously defined atom mapping constraints. More...
 
None addAtomMappingConstraint (int atom1_idx, int atom2_idx)
 Adds a constraint on the allowed atom mappings. More...
 
None clearBondMappingConstraints ()
 Clears all previously defined bond mapping constraints. More...
 
None addBondMappingConstraint (int bond1_idx, int bond2_idx)
 Adds a constraint on the allowed bond mappings. More...
 
None setFoundMappingCallback (BoolMolecularGraphAtomBondMappingFunctor func)
 Sets a callback that is invoked for every atom/bond mapping found during findMappings(). More...
 
BoolMolecularGraphAtomBondMappingFunctor getFoundMappingCallback ()
 Returns the currently installed found-mapping callback. More...
 
AtomBondMapping __getitem__ (int idx)
 
int __len__ ()
 

Properties

 objectID = property(getObjectID)
 
 atomPropertyFlags = property(getAtomPropertyFlags, setAtomPropertyFlags)
 
 bondPropertyFlags = property(getBondPropertyFlags, setBondPropertyFlags)
 
 incIdentityMapping = property(identityMappingIncluded, includeIdentityMapping)
 
 numMappings = property(getNumMappings)
 
 maxNumMappings = property(getMaxNumMappings, setMaxNumMappings)
 
 foundMappingCallback = property(getFoundMappingCallback, setFoundMappingCallback)
 

Detailed Description

Enumerates the atom/bond automorphisms of a molecular graph.

The automorphism group of a molecular graph is the set of self-mappings (atom-permutations and the induced bond-permutations) that preserve the molecular graph structure under the configured atom and bond property flags. Atom and bond matching is configurable via the Chem.AtomPropertyFlag and Chem.BondPropertyFlag bit masks. Found mappings are stored as Chem.AtomBondMapping objects and can be iterated or accessed by index.

Constructor & Destructor Documentation

◆ __init__()

None CDPL.Chem.AutomorphismGroupSearch.__init__ ( int   atom_flags = 12702,
int   bond_flags = 30 
)

Constructs and initializes a AutomorphismGroupSearch instance.

Parameters
atom_flagsThe bitwise-OR combination of Chem.AtomPropertyFlag values considered for atom matching.
bond_flagsThe bitwise-OR combination of Chem.BondPropertyFlag values considered for bond matching.

Member Function Documentation

◆ getObjectID()

int CDPL.Chem.AutomorphismGroupSearch.getObjectID ( )

Returns the numeric identifier (ID) of the wrapped C++ class instance.

Different Python AutomorphismGroupSearch instances may reference the same underlying C++ class instance. The commonly used Python expression a is not b thus cannot tell reliably whether the two AutomorphismGroupSearch instances a and b reference different C++ objects. The numeric identifier returned by this method allows to correctly implement such an identity test via the simple expression a.getObjectID() != b.getObjectID().

Returns
The numeric ID of the internally referenced C++ class instance.

◆ setAtomPropertyFlags()

None CDPL.Chem.AutomorphismGroupSearch.setAtomPropertyFlags ( int  flags)

Specifies the atomic properties considered for atom matching during automorphism search.

Parameters
flagsThe new bitwise-OR combination of Chem.AtomPropertyFlag values.

◆ getAtomPropertyFlags()

int CDPL.Chem.AutomorphismGroupSearch.getAtomPropertyFlags ( )

Returns the atomic properties currently considered for atom matching.

Returns
The bitwise-OR combination of Chem.AtomPropertyFlag values.

◆ setBondPropertyFlags()

None CDPL.Chem.AutomorphismGroupSearch.setBondPropertyFlags ( int  flags)

Specifies the bond properties considered for bond matching during automorphism search.

Parameters
flagsThe new bitwise-OR combination of Chem.BondPropertyFlag values.

◆ getBondPropertyFlags()

int CDPL.Chem.AutomorphismGroupSearch.getBondPropertyFlags ( )

Returns the bond properties currently considered for bond matching.

Returns
The bitwise-OR combination of Chem.BondPropertyFlag values.

◆ includeIdentityMapping()

None CDPL.Chem.AutomorphismGroupSearch.includeIdentityMapping ( bool  include)

Specifies whether the identity mapping shall be included in the search results.

Parameters
includeIf True, the identity mapping is also reported.

◆ identityMappingIncluded()

bool CDPL.Chem.AutomorphismGroupSearch.identityMappingIncluded ( )

Tells whether the identity mapping is included in the search results.

Returns
True if the identity mapping is included, and False otherwise.

◆ findMappings()

bool CDPL.Chem.AutomorphismGroupSearch.findMappings ( MolecularGraph  molgraph)

Searches for the possible atom/bond mappings in the automorphism group of the given molecular graph.

The method will store all found mappings up to the maximum number of recorded mappings specified by setMaxNumMappings().

Parameters
molgraphThe molecular graph that has to be searched for automorphisms.
Returns
True if any mappings of the specified molecular graph have been found, and False otherwise.
Note
Any atom/bond mappings that were recorded in a previous call to findMappings() will be discarded.

◆ stopSearch()

None CDPL.Chem.AutomorphismGroupSearch.stopSearch ( )

Aborts a currently running findMappings() call.

Intended to be invoked from within the callback installed via setFoundMappingCallback() to stop the automorphism enumeration early.

◆ getNumMappings()

int CDPL.Chem.AutomorphismGroupSearch.getNumMappings ( )

Returns the number of atom/bond mappings that were recorded in the last call to findMappings().

Returns
The number of atom/bond mappings that were recorded in the last call to findMappings().

◆ getMapping()

AtomBondMapping CDPL.Chem.AutomorphismGroupSearch.getMapping ( int  idx)

Returns a reference to the stored atom/bond mapping object at index idx.

Parameters
idxThe zero-based index of the atom/bond mapping object to return.
Returns
A reference to the atom/bond mapping object at index idx.
Exceptions
Base.IndexErrorif no mappings are available or idx is not in the range [0, getNumMappings() - 1].

◆ getMaxNumMappings()

int CDPL.Chem.AutomorphismGroupSearch.getMaxNumMappings ( )

Returns the specified limit on the number of stored atom/bond mappings.

Returns
The specified maximum number of stored atom/bond mappings.
See also
setMaxNumMappings(), findMappings()

◆ setMaxNumMappings()

None CDPL.Chem.AutomorphismGroupSearch.setMaxNumMappings ( int  max_num_mappings)

Allows to specify a limit on the number of stored atom/bond mappings.

In a call to findMappings() the automorphism search will terminate as soon as the specified maximum number of stored atom/bond mappings has been reached. A previously set limit on the number of mappings can be disabled by providing zero for the value of max_num_mappings.

Parameters
max_num_mappingsThe maximum number of atom/bond mappings to store.
Note
By default, no limit is imposed on the number of stored mappings.

◆ clearAtomMappingConstraints()

None CDPL.Chem.AutomorphismGroupSearch.clearAtomMappingConstraints ( )

Clears all previously defined atom mapping constraints.

See also
addAtomMappingConstraint()

◆ addAtomMappingConstraint()

None CDPL.Chem.AutomorphismGroupSearch.addAtomMappingConstraint ( int  atom1_idx,
int  atom2_idx 
)

Adds a constraint on the allowed atom mappings.

By default, an atom can be mapped to any valid other atom. When this method gets called for a particular atom pair (specified by atom1_idx and atom2_idx), a future search will report only those solutions which feature the specified mapping of the two atoms. Multiple calls to addAtomMappingConstraint() for a particular atom enlarges the set of valid mapping solutions.

Parameters
atom1_idxThe index of the first atom.
atom2_idxThe index of the second atom.

◆ clearBondMappingConstraints()

None CDPL.Chem.AutomorphismGroupSearch.clearBondMappingConstraints ( )

Clears all previously defined bond mapping constraints.

See also
addBondMappingConstraint()

◆ addBondMappingConstraint()

None CDPL.Chem.AutomorphismGroupSearch.addBondMappingConstraint ( int  bond1_idx,
int  bond2_idx 
)

Adds a constraint on the allowed bond mappings.

By default, an bond can be mapped to any valid other bond. When this method gets called for a particular bond pair (specified by bond1_idx and bond2_idx), a future search will report only those solutions which feature the specified mapping of the two bonds. Multiple calls to addBondMappingConstraint() for a particular bond enlarges the set of valid mapping solutions.

Parameters
bond1_idxThe index of the first bond.
bond2_idxThe index of the second bond.

◆ setFoundMappingCallback()

None CDPL.Chem.AutomorphismGroupSearch.setFoundMappingCallback ( BoolMolecularGraphAtomBondMappingFunctor  func)

Sets a callback that is invoked for every atom/bond mapping found during findMappings().

Returning False from the callback aborts the search (equivalent to calling stopSearch()).

Parameters
funcThe new found-mapping callback.

◆ getFoundMappingCallback()

BoolMolecularGraphAtomBondMappingFunctor CDPL.Chem.AutomorphismGroupSearch.getFoundMappingCallback ( )

Returns the currently installed found-mapping callback.

Returns
A reference to the found-mapping callback.

◆ __getitem__()

AtomBondMapping CDPL.Chem.AutomorphismGroupSearch.__getitem__ ( int  idx)
Parameters
idx
Returns

◆ __len__()

int CDPL.Chem.AutomorphismGroupSearch.__len__ ( )
Returns