1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165
|
//
// Copyright (C) 2013 Greg Landrum
//
// @@ All Rights Reserved @@
// This file is part of the RDKit.
// The contents are covered by the terms of the BSD license
// which is included in the file license.txt, found at the root
// of the RDKit source tree.
//
#include <RDGeneral/export.h>
#ifndef _RD_MOLFRAGMENTER_H__
#define _RD_MOLFRAGMENTER_H__
#include <istream>
#include <GraphMol/ROMol.h>
#include <RDGeneral/BetterEnums.h>
namespace RDKit {
namespace MolFragmenter {
struct RDKIT_CHEMTRANSFORMS_EXPORT FragmenterBondType {
unsigned int atom1Label, atom2Label;
unsigned int atom1Type, atom2Type;
Bond::BondType bondType;
ROMOL_SPTR query;
};
//! \brief Fragments a molecule by breaking a set of bonds
//!
/*!
\param mol - the molecule to be modified
\param bondIndices - indices of the bonds to be broken
optional:
\param addDummies - toggles addition of dummy atoms to indicate where
bonds were broken
\param dummyLabels - used to provide the labels to be used for the dummies.
the first element in each pair is the label for the dummy
that replaces the bond's beginAtom, the second is for the
dummy that replaces the bond's endAtom. If not provided, the
dummies are labeled with atom indices.
\param bondTypes - used to provide the bond type to use between the
fragments and the dummy atoms. If not provided, defaults to single.
\param nCutsPerAtom - used to return the number of bonds that were
cut at each atom. Should be nAtoms long.
\return a new ROMol with the modifications
The client is responsible for deleting this molecule.
*/
RDKIT_CHEMTRANSFORMS_EXPORT ROMol *fragmentOnBonds(
const ROMol &mol, const std::vector<unsigned int> &bondIndices,
bool addDummies = true,
const std::vector<std::pair<unsigned int, unsigned int>> *dummyLabels =
nullptr,
const std::vector<Bond::BondType> *bondTypes = nullptr,
std::vector<unsigned int> *nCutsPerAtom = nullptr);
//! \overload
RDKIT_CHEMTRANSFORMS_EXPORT ROMol *fragmentOnBonds(
const ROMol &mol, const std::vector<FragmenterBondType> &bondPatterns,
const std::map<unsigned int, ROMOL_SPTR> *atomEnvirons = nullptr,
std::vector<unsigned int> *nCutsPerAtom = nullptr);
RDKIT_CHEMTRANSFORMS_EXPORT void fragmentOnSomeBonds(
const ROMol &mol, const std::vector<unsigned int> &bondIndices,
std::vector<ROMOL_SPTR> &resMols, unsigned int maxToCut = 1,
bool addDummies = true,
const std::vector<std::pair<unsigned int, unsigned int>> *dummyLabels =
nullptr,
const std::vector<Bond::BondType> *bondTypes = nullptr,
std::vector<std::vector<unsigned int>> *nCutsPerAtom = nullptr);
//! \brief Fragments a molecule by breaking all BRICS bonds
/*!
\return a new ROMol with the modifications
The client is responsible for deleting this molecule.
*/
RDKIT_CHEMTRANSFORMS_EXPORT ROMol *fragmentOnBRICSBonds(const ROMol &mol);
RDKIT_CHEMTRANSFORMS_EXPORT void constructFragmenterAtomTypes(
std::istream *inStream, std::map<unsigned int, std::string> &defs,
const std::string &comment = "//", bool validate = true,
std::map<unsigned int, ROMOL_SPTR> *environs = nullptr);
RDKIT_CHEMTRANSFORMS_EXPORT void constructFragmenterAtomTypes(
const std::string &str, std::map<unsigned int, std::string> &defs,
const std::string &comment = "//", bool validate = true,
std::map<unsigned int, ROMOL_SPTR> *environs = nullptr);
RDKIT_CHEMTRANSFORMS_EXPORT void constructBRICSAtomTypes(
std::map<unsigned int, std::string> &defs,
std::map<unsigned int, ROMOL_SPTR> *environs = nullptr);
RDKIT_CHEMTRANSFORMS_EXPORT void constructFragmenterBondTypes(
std::istream *inStream,
const std::map<unsigned int, std::string> &atomTypes,
std::vector<FragmenterBondType> &defs, const std::string &comment = "//",
bool validate = true, bool labelByConnector = true);
RDKIT_CHEMTRANSFORMS_EXPORT void constructFragmenterBondTypes(
const std::string &str,
const std::map<unsigned int, std::string> &atomTypes,
std::vector<FragmenterBondType> &defs, const std::string &comment = "//",
bool validate = true, bool labelByConnector = true);
RDKIT_CHEMTRANSFORMS_EXPORT void constructBRICSBondTypes(
std::vector<FragmenterBondType> &defs);
} // namespace MolFragmenter
// n.b. AtomProperty must resolve to an unsigned integer value on an atom
// property
// clang-format off
BETTER_ENUM_CLASS(MolzipLabel, unsigned int,
AtomMapNumber,
Isotope,
FragmentOnBonds,
AtomType,
AtomProperty
);
// clang-format on
struct RDKIT_CHEMTRANSFORMS_EXPORT MolzipParams {
MolzipLabel label = MolzipLabel::AtomMapNumber;
std::vector<std::string> atomSymbols;
std::string atomProperty;
bool enforceValenceRules = true;
bool generateCoordinates = false;
};
RDKIT_CHEMTRANSFORMS_EXPORT std::unique_ptr<ROMol> molzip(
const ROMol &a, const ROMol &b,
const MolzipParams ¶ms = MolzipParams());
RDKIT_CHEMTRANSFORMS_EXPORT std::unique_ptr<ROMol> molzip(
const ROMol &a, const MolzipParams ¶ms = MolzipParams());
//! \brief Creates a molecule from an R group decomposition
/*!
*
* @param decomposition - A list of molecules that comprises an R group
* decomposition. The core must be the first molecule in the list. If
* generateCoordinates is set in the parameters then aligned depiction
* coordinates will be set on the returned molecule and the input decomposition
*
* optional:
* @param params - molzip parameters
*
* @return the zipped molecule
*/
RDKIT_CHEMTRANSFORMS_EXPORT std::unique_ptr<ROMol> molzip(
std::vector<ROMOL_SPTR> &decomposition,
const MolzipParams ¶ms = MolzipParams());
//! \brief Molzip an RGroupRow back into the original molecule if possible
/*! This correctly handles broken cycles that can happend during arbitrary
* RGroup Decomposition.
*
* @param row - rgroup row as returned by the rgroup decompisition
*
* optional:
* @param params - molzip parameters
*
* @return - the zipped molecule
*/
RDKIT_CHEMTRANSFORMS_EXPORT std::unique_ptr<ROMol> molzip(
const std::map<std::string, ROMOL_SPTR> &row,
const MolzipParams ¶ms = MolzipParams());
} // namespace RDKit
#endif
|