31#include <boost/graph/adjacency_list.hpp>
32#include <boost/smart_ptr.hpp>
33#include <boost/dynamic_bitset.hpp>
35#ifdef RDK_USE_BOOST_SERIALIZATION
36#include <boost/serialization/split_member.hpp>
55typedef boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS,
64template <
class T1,
class T2>
69template <
class T1,
class T2>
71template <
class T1,
class T2>
73template <
class T1,
class T2>
75template <
class T1,
class T2>
115template <
class Graph,
class Vertex,
116 class Iterator =
typename Graph::vertex_iterator>
189 return !(*
this == other);
208 std::ranges::random_access_range<CXXAtomIterator<MolGraph, Atom *>>
209 and std::ranges::sized_range<CXXAtomIterator<MolGraph, Atom *>>
213template <
class Graph,
class Edge,
214 class Iterator =
typename Graph::edge_iterator>
258 return !(*
this == other);
263 auto vs = boost::edges(*
graph);
283 std::ranges::bidirectional_range<CXXBondIterator<MolGraph, Bond *>>);
294 typedef MolGraph::vertex_descriptor vertex_descriptor;
295 typedef MolGraph::edge_descriptor edge_descriptor;
297 typedef MolGraph::edge_iterator EDGE_ITER;
298 typedef MolGraph::out_edge_iterator OEDGE_ITER;
299 typedef MolGraph::vertex_iterator VERTEX_ITER;
300 typedef MolGraph::adjacency_iterator ADJ_ITER;
301 typedef std::pair<EDGE_ITER, EDGE_ITER> BOND_ITER_PAIR;
302 typedef std::pair<OEDGE_ITER, OEDGE_ITER> OBOND_ITER_PAIR;
303 typedef std::pair<VERTEX_ITER, VERTEX_ITER> ATOM_ITER_PAIR;
304 typedef std::pair<ADJ_ITER, ADJ_ITER> ADJ_ITER_PAIR;
306 typedef std::vector<Atom *> ATOM_PTR_VECT;
307 typedef ATOM_PTR_VECT::iterator ATOM_PTR_VECT_I;
308 typedef ATOM_PTR_VECT::const_iterator ATOM_PTR_VECT_CI;
309 typedef std::vector<Bond *> BOND_PTR_VECT;
310 typedef BOND_PTR_VECT::iterator BOND_PTR_VECT_I;
311 typedef BOND_PTR_VECT::const_iterator BOND_PTR_VECT_CI;
313 typedef std::list<Atom *> ATOM_PTR_LIST;
314 typedef ATOM_PTR_LIST::iterator ATOM_PTR_LIST_I;
315 typedef ATOM_PTR_LIST::const_iterator ATOM_PTR_LIST_CI;
316 typedef std::list<Bond *> BOND_PTR_LIST;
317 typedef BOND_PTR_LIST::iterator BOND_PTR_LIST_I;
318 typedef BOND_PTR_LIST::const_iterator BOND_PTR_LIST_CI;
321 typedef std::list<CONFORMER_SPTR> CONF_SPTR_LIST;
322 typedef CONF_SPTR_LIST::iterator CONF_SPTR_LIST_I;
323 typedef CONF_SPTR_LIST::const_iterator CONF_SPTR_LIST_CI;
324 typedef std::pair<CONF_SPTR_LIST_I, CONF_SPTR_LIST_I> CONFS_I_PAIR;
327 typedef std::map<int, ATOM_PTR_LIST> ATOM_BOOKMARK_MAP;
328 typedef std::map<int, BOND_PTR_LIST> BOND_BOOKMARK_MAP;
336 ConstAromaticAtomIterator;
339 ConstHeteroatomIterator;
342 ConstQueryAtomIterator;
345 ConstMatchingAtomIterator;
347 typedef CONF_SPTR_LIST_I ConformerIterator;
348 typedef CONF_SPTR_LIST_CI ConstConformerIterator;
372 return {&d_graph, pr.first, pr.second};
378 return {&d_graph, pr.first, pr.second};
384 return {&d_graph, pr.first, pr.second};
390 return {&d_graph, pr.first, pr.second};
421 ROMol(
const ROMol &other,
bool quickCopy =
false,
int confId = -1)
423 dp_ringInfo =
nullptr;
424 initFromOther(other, quickCopy, confId);
430 ROMol(
const std::string &binStr,
unsigned int propertyFlags);
434 d_graph(std::move(o.d_graph)),
435 d_atomBookmarks(std::move(o.d_atomBookmarks)),
436 d_bondBookmarks(std::move(o.d_bondBookmarks)),
437 d_confs(std::move(o.d_confs)),
438 d_sgroups(std::move(o.d_sgroups)),
439 d_stereo_groups(std::move(o.d_stereo_groups)),
441 for (
auto atom :
atoms()) {
442 atom->setOwningMol(
this);
444 for (
auto bond :
bonds()) {
445 bond->setOwningMol(
this);
447 for (
auto conf : d_confs) {
448 conf->setOwningMol(
this);
450 for (
auto &sg : d_sgroups) {
451 sg.setOwningMol(
this);
455 dp_ringInfo = std::exchange(o.dp_ringInfo,
nullptr);
456 dp_delAtoms = std::exchange(o.dp_delAtoms,
nullptr);
457 dp_delBonds = std::exchange(o.dp_delBonds,
nullptr);
464 d_graph = std::move(o.d_graph);
465 d_atomBookmarks = std::move(o.d_atomBookmarks);
466 d_bondBookmarks = std::move(o.d_bondBookmarks);
470 dp_ringInfo = std::exchange(o.dp_ringInfo,
nullptr);
472 d_confs = std::move(o.d_confs);
473 d_sgroups = std::move(o.d_sgroups);
474 d_stereo_groups = std::move(o.d_stereo_groups);
475 dp_delAtoms = std::exchange(o.dp_delAtoms,
nullptr);
476 dp_delBonds = std::exchange(o.dp_delBonds,
nullptr);
480 for (
auto atom :
atoms()) {
481 atom->setOwningMol(
this);
483 for (
auto bond :
bonds()) {
484 bond->setOwningMol(
this);
486 for (
auto conf : d_confs) {
487 conf->setOwningMol(
this);
489 for (
auto &sg : d_sgroups) {
490 sg.setOwningMol(
this);
555 template <
class U,
class V>
561 template <
class U,
class V>
574 d_atomBookmarks[mark].push_back(at);
578 d_atomBookmarks[mark].clear();
579 d_atomBookmarks[mark].push_back(at);
602 d_bondBookmarks[mark].push_back(bond);
823 bool (*query)(
const Atom *))
const;
834 return d_confs.begin();
837 inline ConstConformerIterator
endConformers()
const {
return d_confs.end(); }
878 return d_stereo_groups;
890#ifdef RDK_USE_BOOST_SERIALIZATION
893 template <
class Archive>
894 void save(Archive &ar,
const unsigned int version)
const;
895 template <
class Archive>
896 void load(Archive &ar,
const unsigned int version);
897 BOOST_SERIALIZATION_SPLIT_MEMBER()
903 ATOM_BOOKMARK_MAP d_atomBookmarks;
904 BOND_BOOKMARK_MAP d_bondBookmarks;
906 CONF_SPTR_LIST d_confs;
907 std::vector<SubstanceGroup> d_sgroups;
908 std::vector<StereoGroup> d_stereo_groups;
909 std::unique_ptr<boost::dynamic_bitset<>> dp_delAtoms =
nullptr;
910 std::unique_ptr<boost::dynamic_bitset<>> dp_delBonds =
nullptr;
916 void clearSubstanceGroups() { d_sgroups.clear(); }
925 virtual void destroy();
937 unsigned int addAtom(
Atom *atom,
bool updateLabel =
true,
938 bool takeOwnership =
false);
948 unsigned int addBond(
Bond *bond,
bool takeOwnership =
false);
960 void initFromOther(
const ROMol &other,
bool quickCopy,
int confId);
Defines the Atom class and associated typedefs.
Defines the class StereoGroup which stores relationships between the absolute configurations of atoms...
Defines the SubstanceGroup class.
Iterate over aromatic atoms, this is bidirectional.
A general random access iterator.
The class for representing atoms.
iterator for a molecule's bonds, currently BiDirectional, but it theoretically ought to be RandomAcce...
class for representing a bond
const iterator for a molecule's bonds, currently BiDirectional, but it theoretically ought to be Rand...
Iterate over heteroatoms, this is bidirectional.
Iterate over atoms matching a query function. This is bidirectional.
handles pickling (serializing) molecules
Iterate over atoms matching a query. This is bidirectional.
Class for storing atomic queries.
Class for storing Bond queries.
RDProps & operator=(const RDProps &rhs)
ConstAromaticAtomIterator endAromaticAtoms() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
ADJ_ITER_PAIR getAtomNeighbors(Atom const *at) const
provides access to all neighbors around an Atom
ConstQueryAtomIterator endQueryAtoms() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
bool needsUpdatePropertyCache() const
OBOND_ITER_PAIR getAtomBonds(Atom const *at) const
provides access to all Bond objects connected to an Atom
unsigned int getNumBonds(bool onlyHeavy=1) const
returns our number of Bonds
CXXAtomIterator< const MolGraph, Atom *const > atoms() const
void clearAtomBookmark(int mark)
removes a bookmark from our collection
unsigned int getNumHeavyAtoms() const
returns our number of heavy atoms (atomic number > 1)
void clearAtomBookmark(int mark, const Atom *atom)
removes a particular Atom from the list associated with the bookmark
Atom * getAtomWithIdx(unsigned int idx)
returns a pointer to a particular Atom
unsigned int getNumConformers() const
AtomIterator endAtoms()
get an AtomIterator pointing at the end of our Atoms
BOND_PTR_LIST & getAllBondsWithBookmark(int mark)
returns all bonds associated with the bookmark provided
const std::vector< StereoGroup > & getStereoGroups() const
Gets a reference to the groups of atoms with relative stereochemistry.
ConstAtomIterator endAtoms() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
BondIterator beginBonds()
get a BondIterator pointing at our first Bond
bool hasAtomBookmark(int mark) const
queries whether or not any atoms are associated with a bookmark
Atom * getAtomWithIdx(const U idx)
This is an overloaded member function, provided for convenience. It differs from the above function o...
ConstQueryAtomIterator beginQueryAtoms(QueryAtom const *) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
unsigned int getNumAtoms() const
returns our number of atoms
ConstConformerIterator endConformers() const
ConstMatchingAtomIterator beginMatchingAtoms(bool(*query)(const Atom *)) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
ROMol & operator=(ROMol &&o) noexcept
ROMol(const ROMol &other, bool quickCopy=false, int confId=-1)
copy constructor with a twist
ROMol & operator=(const ROMol &)=delete
Bond * getUniqueBondWithBookmark(int mark)
ConstMatchingAtomIterator endMatchingAtoms() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
BOND_ITER_PAIR getEdges()
returns an iterator pair for looping over all Bonds
void clearConformers()
Clear all the conformations on the molecule.
void setBondBookmark(Bond *bond, int mark)
associates a Bond pointer with a bookmark
void updatePropertyCache(bool strict=true)
calculates any of our lazy properties
CXXAtomIterator< MolGraph, Atom * > atoms()
C++11 Range iterator.
Atom * getAtomWithBookmark(int mark)
returns the first Atom associated with the bookmark provided
CXXAtomIterator< const MolGraph, Atom *const, MolGraph::adjacency_iterator > atomNeighbors(Atom const *at) const
BOND_BOOKMARK_MAP * getBondBookmarks()
returns a pointer to all of our bond bookmarks
Conformer & getConformer(int id=-1)
QueryAtomIterator endQueryAtoms()
get an AtomIterator pointing at the end of our Atoms
const Conformer & getConformer(int id=-1) const
unsigned int addConformer(Conformer *conf, bool assignId=false)
Add a new conformation to the molecule.
const Atom * operator[](const vertex_descriptor &v) const
bool hasQuery() const
if the Mol has any Query atoms or bonds
void clearAllBondBookmarks()
blows out all bond bookmarks
const Atom * getAtomWithIdx(const U idx) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
CXXBondIterator< MolGraph, Bond * > bonds()
ATOM_ITER_PAIR getVertices()
returns an iterator pair for looping over all Atoms
friend RDKIT_GRAPHMOL_EXPORT std::vector< SubstanceGroup > & getSubstanceGroups(ROMol &)
BOND_ITER_PAIR getEdges() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
void clearComputedProps(bool includeRings=true) const
clears all of our computed properties
const Bond * getBondWithIdx(const U idx) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
ATOM_PTR_LIST & getAllAtomsWithBookmark(int mark)
returns all Atoms associated with the bookmark provided
const Bond * getBondBetweenAtoms(unsigned int idx1, unsigned int idx2) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
ROMol(const std::string &binStr, unsigned int propertyFlags)
construct a molecule from a pickle string
Bond * getBondWithIdx(const U idx)
This is an overloaded member function, provided for convenience. It differs from the above function o...
ATOM_BOOKMARK_MAP * getAtomBookmarks()
returns a pointer to all of our atom bookmarks
ConstAtomIterator beginAtoms() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
ConstAromaticAtomIterator beginAromaticAtoms() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
CXXAtomIterator< MolGraph, Atom *, MolGraph::adjacency_iterator > atomNeighbors(Atom const *at)
void debugMol(std::ostream &str) const
const Bond * getBondBetweenAtoms(const U idx1, const V idx2) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
void setAtomBookmark(Atom *at, int mark)
associates an Atom pointer with a bookmark
MatchingAtomIterator endMatchingAtoms()
get an AtomIterator pointing at the end of our Atoms
ConstBondIterator beginBonds() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
BondIterator endBonds()
get a BondIterator pointing at the end of our Bonds
ROMol(const std::string &binStr)
construct a molecule from a pickle string
Atom * getUniqueAtomWithBookmark(int mark)
QueryAtomIterator beginQueryAtoms(QueryAtom const *query)
get an AtomIterator pointing at our first Atom that matches query
ConstHeteroatomIterator endHeteros() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
void clearPropertyCache()
void replaceAtomBookmark(Atom *at, int mark)
associates an Atom pointer with a bookmark
Bond * getBondWithBookmark(int mark)
returns the first Bond associated with the bookmark provided
CXXBondIterator< const MolGraph, Bond *const, MolGraph::out_edge_iterator > atomBonds(Atom const *at) const
unsigned int getAtomDegree(const Atom *at) const
returns the degree (number of neighbors) of an Atom in the graph
void setStereoGroups(std::vector< StereoGroup > stereo_groups)
Sets groups of atoms with relative stereochemistry.
CXXBondIterator< MolGraph, Bond *, MolGraph::out_edge_iterator > atomBonds(Atom const *at)
AromaticAtomIterator endAromaticAtoms()
get an AtomIterator pointing at the end of our Atoms
RingInfo * getRingInfo() const
void clearAllAtomBookmarks()
blows out all atomic bookmarks
const Bond * operator[](const edge_descriptor &e) const
Bond * operator[](const edge_descriptor &e)
Bond * getBondWithIdx(unsigned int idx)
returns a pointer to a particular Bond
ConformerIterator beginConformers()
ConstBondIterator endBonds() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
unsigned int getNumAtoms(bool onlyExplicit) const
HeteroatomIterator endHeteros()
get an AtomIterator pointing at the end of our Atoms
ROMol(ROMol &&o) noexcept
Bond * getBondBetweenAtoms(const U idx1, const V idx2)
This is an overloaded member function, provided for convenience. It differs from the above function o...
ConstConformerIterator beginConformers() const
void clearBondBookmark(int mark, const Bond *bond)
removes a particular Bond from the list associated with the bookmark
MatchingAtomIterator beginMatchingAtoms(bool(*query)(Atom *))
get an AtomIterator pointing at our first Atom that matches query
MolGraph const & getTopology() const
brief returns a pointer to our underlying BGL object
bool hasBondBookmark(int mark) const
queries whether or not any bonds are associated with a bookmark
const Bond * getBondWithIdx(unsigned int idx) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
AtomIterator beginAtoms()
get an AtomIterator pointing at our first Atom
const Atom * getAtomWithIdx(unsigned int idx) const
This is an overloaded member function, provided for convenience. It differs from the above function o...
void removeConformer(unsigned int id)
Delete the conformation with the specified ID.
AromaticAtomIterator beginAromaticAtoms()
get an AtomIterator pointing at our first aromatic Atom
Atom * operator[](const vertex_descriptor &v)
ConstHeteroatomIterator beginHeteros() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
ConformerIterator endConformers()
ATOM_ITER_PAIR getVertices() const
This is an overloaded member function, provided for convenience. It differs from the above function o...
friend RDKIT_GRAPHMOL_EXPORT const std::vector< SubstanceGroup > & getSubstanceGroups(const ROMol &)
void clearBondBookmark(int mark)
removes a bookmark from our collection
HeteroatomIterator beginHeteros()
get an AtomIterator pointing at our first hetero Atom
Bond * getBondBetweenAtoms(unsigned int idx1, unsigned int idx2)
returns a pointer to the bond between two atoms, Null on failure
CXXBondIterator< const MolGraph, Bond *const > bonds() const
RWMol is a molecule class that is intended to be edited.
The class for representing SubstanceGroups.
#define RDKIT_GRAPHMOL_EXPORT
std::vector< ROMol > MOL_VECT
MOL_PTR_VECT::const_iterator MOL_PTR_VECT_CI
RDKIT_GRAPHMOL_EXPORT const int ci_RIGHTMOST_ATOM
RDKIT_GRAPHMOL_EXPORT const int ci_ATOM_HOLDER
std::vector< ROMol * > MOL_PTR_VECT
boost::shared_ptr< ROMol > ROMOL_SPTR
MOL_PTR_VECT::iterator MOL_PTR_VECT_I
boost::adjacency_list< boost::vecS, boost::vecS, boost::undirectedS, Atom *, Bond * > MolGraph
This is the BGL type used to store the topology:
std::vector< boost::shared_ptr< ROMol > > MOL_SPTR_VECT
RDKIT_GRAPHMOL_EXPORT const int ci_LEADING_BOND
Vertex const & const_reference
std::ptrdiff_t difference_type
bool operator!=(const CXXAtomIter &other) const
bool operator<(const CXXAtomIter &other) const
CXXAtomIter & operator+=(difference_type n)
CXXAtomIter & operator++()
CXXAtomIter operator--(int)
CXXAtomIter operator-(difference_type n) const
CXXAtomIter operator+(difference_type n) const
std::random_access_iterator_tag iterator_category
bool operator>=(const CXXAtomIter &other) const
friend CXXAtomIter operator+(difference_type n, const CXXAtomIter &it)
CXXAtomIter & operator-=(difference_type n)
const_reference operator*() const
CXXAtomIter & operator--()
CXXAtomIter operator++(int)
difference_type operator-(const CXXAtomIter &other) const
bool operator==(const CXXAtomIter &other) const
CXXAtomIter(Graph *graph, Iterator pos)
bool operator<=(const CXXAtomIter &other) const
bool operator>(const CXXAtomIter &other) const
const_reference operator[](difference_type n) const
CXXAtomIterator(Graph *graph, Iterator start, Iterator end)
CXXAtomIterator(Graph *graph)
const_reference operator*() const
std::bidirectional_iterator_tag iterator_category
CXXBondIter(Graph *graph, Iterator pos)
bool operator==(const CXXBondIter &other) const
Edge const & const_reference
CXXBondIter & operator--()
bool operator!=(const CXXBondIter &other) const
std::ptrdiff_t difference_type
CXXBondIter & operator++()
CXXBondIter operator--(int)
CXXBondIter operator++(int)
CXXBondIterator(Graph *graph)
CXXBondIterator(Graph *graph, Iterator start, Iterator end)