![]() |
RDKit
Open-source cheminformatics and machine learning.
|
This is a class for storing and applying general chemical reactions. More...
#include <Reaction.h>
Public Member Functions | |
ChemicalReaction () | |
ChemicalReaction (const ChemicalReaction &other) | |
ChemicalReaction (const std::string &binStr) | |
construct a reaction from a pickle string More... | |
unsigned int | addReactantTemplate (ROMOL_SPTR mol) |
Adds a new reactant template. More... | |
unsigned int | addAgentTemplate (ROMOL_SPTR mol) |
Adds a new agent template. More... | |
unsigned int | addProductTemplate (ROMOL_SPTR mol) |
Adds a new product template. More... | |
void | removeUnmappedReactantTemplates (double thresholdUnmappedAtoms=0.2, bool moveToAgentTemplates=true, MOL_SPTR_VECT *targetVector=NULL) |
Removes the reactant templates from a reaction if atom mapping ratio is below a given threshold. More... | |
void | removeUnmappedProductTemplates (double thresholdUnmappedAtoms=0.2, bool moveToAgentTemplates=true, MOL_SPTR_VECT *targetVector=NULL) |
Removes the product templates from a reaction if its atom mapping ratio is below a given threshold. More... | |
std::vector< MOL_SPTR_VECT > | runReactants (const MOL_SPTR_VECT reactants) const |
Runs the reaction on a set of reactants. More... | |
const MOL_SPTR_VECT & | getReactants () const |
const MOL_SPTR_VECT & | getAgents () const |
const MOL_SPTR_VECT & | getProducts () const |
MOL_SPTR_VECT::const_iterator | beginReactantTemplates () const |
MOL_SPTR_VECT::const_iterator | endReactantTemplates () const |
MOL_SPTR_VECT::const_iterator | beginProductTemplates () const |
MOL_SPTR_VECT::const_iterator | endProductTemplates () const |
MOL_SPTR_VECT::const_iterator | beginAgentTemplates () const |
MOL_SPTR_VECT::const_iterator | endAgentTemplates () const |
MOL_SPTR_VECT::iterator | beginReactantTemplates () |
MOL_SPTR_VECT::iterator | endReactantTemplates () |
MOL_SPTR_VECT::iterator | beginProductTemplates () |
MOL_SPTR_VECT::iterator | endProductTemplates () |
MOL_SPTR_VECT::iterator | beginAgentTemplates () |
MOL_SPTR_VECT::iterator | endAgentTemplates () |
unsigned int | getNumReactantTemplates () const |
unsigned int | getNumProductTemplates () const |
unsigned int | getNumAgentTemplates () const |
void | initReactantMatchers () |
initializes our internal reactant-matching datastructures. More... | |
bool | isInitialized () const |
bool | validate (unsigned int &numWarnings, unsigned int &numErrors, bool silent=false) const |
validates the reactants and products to make sure the reaction seems "reasonable" More... | |
bool | getImplicitPropertiesFlag () const |
void | setImplicitPropertiesFlag (bool val) |
Friends | |
class | ReactionPickler |
This is a class for storing and applying general chemical reactions.
basic usage will be something like:
ChemicalReaction rxn; rxn.addReactantTemplate(r1); rxn.addReactantTemplate(r2); rxn.addProductTemplate(p1); rxn.initReactantMatchers(); MOL_SPTR_VECT prods; for(MOL_SPTR_VECT::const_iterator r1It=reactantSet1.begin(); r1It!=reactantSet1.end();++r1It;){ for(MOL_SPTR_VECT::const_iterator r2It=reactantSet2.begin(); r2It!=reactantSet2.end();++r2It;){ MOL_SPTR_VECT rVect(2); rVect[0] = *r1It; rVect[1] = *r2It; std::vector<MOL_SPTR_VECT> lprods; lprods = rxn.runReactants(rVect); for(std::vector<MOL_SPTR_VECT>::const_iterator lpIt=lprods.begin(); lpIt!=lprods.end();++lpIt){ // we know this is a single-product reaction: prods.push_back((*lpIt)[0]); } } }
NOTES:
std::string smi="[O:1]>>[N:1]"; ChemicalReaction *rxn = RxnSmartsToChemicalReaction(smi); rxn->initReactantMatchers(); MOL_SPTR_VECT reacts; reacts.clear(); smi = "OCO"; ROMol *mol = SmilesToMol(smi); reacts.push_back(ROMOL_SPTR(mol)); std::vector<MOL_SPTR_VECT> prods; prods = rxn->runReactants(reacts); // here prods has two entries, because there are two Os in the // reactant. reacts[0]->getAtomWithIdx(0)->setProp(common_properties::_protected,1); prods = rxn->runReactants(reacts); // here prods only has one entry, the reaction at atom 0 // has been blocked by the _protected property
Definition at line 113 of file Reaction.h.
|
inline |
Definition at line 117 of file Reaction.h.
|
inline |
Definition at line 118 of file Reaction.h.
RDKit::ChemicalReaction::ChemicalReaction | ( | const std::string & | binStr | ) |
construct a reaction from a pickle string
|
inline |
|
inline |
Adds a new product template.
Definition at line 154 of file Reaction.h.
|
inline |
Adds a new reactant template.
Definition at line 133 of file Reaction.h.
|
inline |
Definition at line 210 of file Reaction.h.
|
inline |
Definition at line 231 of file Reaction.h.
|
inline |
Definition at line 203 of file Reaction.h.
|
inline |
Definition at line 224 of file Reaction.h.
|
inline |
Definition at line 196 of file Reaction.h.
|
inline |
Definition at line 217 of file Reaction.h.
|
inline |
Definition at line 213 of file Reaction.h.
|
inline |
Definition at line 234 of file Reaction.h.
|
inline |
Definition at line 206 of file Reaction.h.
|
inline |
Definition at line 227 of file Reaction.h.
|
inline |
Definition at line 199 of file Reaction.h.
|
inline |
Definition at line 220 of file Reaction.h.
|
inline |
Definition at line 193 of file Reaction.h.
|
inline |
returns whether or not the reaction uses implicit properties on the product atoms
This toggles whether or not unspecified atomic properties in the products are considered to be implicit and should be copied from the actual reactants. This is necessary due to a semantic difference between the "reaction SMARTS" approach and the MDL RXN approach: In "reaction SMARTS", this reaction: [C:1]-[Br:2].[O-:3]>>[C:1]-[O:3].[Br-:2] applied to [CH4+]Br should yield [CH4+]O Something similar drawn in an rxn file, and applied to [CH4+]Br should yield [CH3]O. In rxn there is no charge on the product C because nothing is specified in the rxn file; in "SMARTS" the charge from the actual reactants is not removed because no charge is specified in the reaction.
Definition at line 286 of file Reaction.h.
|
inline |
Definition at line 239 of file Reaction.h.
|
inline |
Definition at line 238 of file Reaction.h.
|
inline |
Definition at line 237 of file Reaction.h.
|
inline |
Definition at line 194 of file Reaction.h.
|
inline |
Definition at line 192 of file Reaction.h.
void RDKit::ChemicalReaction::initReactantMatchers | ( | ) |
initializes our internal reactant-matching datastructures.
This must be called after adding reactants and before calling runReactants.
|
inline |
Definition at line 248 of file Reaction.h.
void RDKit::ChemicalReaction::removeUnmappedProductTemplates | ( | double | thresholdUnmappedAtoms = 0.2 , |
bool | moveToAgentTemplates = true , |
||
MOL_SPTR_VECT * | targetVector = NULL |
||
) |
Removes the product templates from a reaction if its atom mapping ratio is below a given threshold.
By default the removed products templates were attached to the agent templates. An alternative will be to provide a pointer to a molecule vector where these products should be saved.
void RDKit::ChemicalReaction::removeUnmappedReactantTemplates | ( | double | thresholdUnmappedAtoms = 0.2 , |
bool | moveToAgentTemplates = true , |
||
MOL_SPTR_VECT * | targetVector = NULL |
||
) |
Removes the reactant templates from a reaction if atom mapping ratio is below a given threshold.
By default the removed reactant templates were attached to the agent templates. An alternative will be to provide a pointer to a molecule vector where these reactants should be saved.
std::vector<MOL_SPTR_VECT> RDKit::ChemicalReaction::runReactants | ( | const MOL_SPTR_VECT | reactants | ) | const |
Runs the reaction on a set of reactants.
reactants | the reactants to be used. The length of this must be equal to this->getNumReactantTemplates() |
We return a vector of vectors of products because each individual template may map multiple times onto its reactant. This leads to multiple possible result sets.
|
inline |
sets the implicit properties flag. See the documentation for getImplicitProertiesFlag() for a discussion of what this means.
Definition at line 289 of file Reaction.h.
References RDKit::addRecursiveQueriesToReaction(), RDKit::getReactingAtoms(), RDKit::isMoleculeAgentOfReaction(), RDKit::isMoleculeProductOfReaction(), and RDKit::isMoleculeReactantOfReaction().
bool RDKit::ChemicalReaction::validate | ( | unsigned int & | numWarnings, |
unsigned int & | numErrors, | ||
bool | silent = false |
||
) | const |
validates the reactants and products to make sure the reaction seems "reasonable"
numWarnings | used to return the number of validation warnings |
numErrors | used to return the number of validation errors |
silent | If this bool is true, no messages will be logged during the validation. By default, validation problems are reported to the warning and error logs depending on their severity. |
|
friend |
Definition at line 114 of file Reaction.h.