29 #ifndef CDPL_CHEM_BASICATOM_HPP
30 #define CDPL_CHEM_BASICATOM_HPP
35 #include <boost/iterator/transform_iterator.hpp>
58 typedef std::pair<BasicAtom*, BasicBond*> AtomBondPair;
59 typedef std::vector<AtomBondPair> NeighborList;
61 template <
typename AtomType>
65 typedef AtomType& result_type;
67 AtomType& operator()(
const AtomBondPair& ab_pair)
const
69 return *ab_pair.first;
73 template <
typename BondType>
77 typedef BondType& result_type;
79 BondType& operator()(
const AtomBondPair& ab_pair)
const
81 return *ab_pair.second;
86 typedef boost::transform_iterator<AtomAccessor<BasicAtom>, NeighborList::iterator>
AtomIterator;
87 typedef boost::transform_iterator<AtomAccessor<const BasicAtom>, NeighborList::const_iterator>
ConstAtomIterator;
88 typedef boost::transform_iterator<BondAccessor<BasicBond>, NeighborList::iterator>
BondIterator;
89 typedef boost::transform_iterator<BondAccessor<const BasicBond>, NeighborList::const_iterator>
ConstBondIterator;
184 using Atom::operator=;
193 void setIndex(std::size_t idx);
195 void clearAdjacencyLists();
199 static void disconnectAtoms(
BasicBond& bond);
203 NeighborList neighbors;
Definition of the class CDPL::Chem::Atom.
Definition of the preprocessor macro CDPL_CHEM_API.
#define CDPL_CHEM_API
Tells the compiler/linker which classes, functions and variables are part of the library API.
Atom.
Definition: Atom.hpp:52
BasicAtom.
Definition: BasicAtom.hpp:54
void orderAtoms(const AtomCompareFunction &func)
Orders the stored atoms according to criteria implemented by the provided atom comparison function.
AtomIterator getAtomsEnd()
Returns a mutable iterator pointing to the end of the connected atoms.
Bond & getBondToAtom(const Atom &atom)
Returns a non-const reference to the Chem::Bond object that connects this atom to the argument atom.
BondIterator getBondsEnd()
Returns a mutable iterator pointing to the end of the incident bonds.
ConstBondIterator getBondsEnd() const
Returns a constant iterator pointing to the end of the incident bonds.
boost::transform_iterator< AtomAccessor< const BasicAtom >, NeighborList::const_iterator > ConstAtomIterator
Definition: BasicAtom.hpp:87
ConstAtomIterator getAtomsEnd() const
Returns a constant iterator pointing to the end of the connected atoms.
BondIterator getBondsBegin()
Returns a mutable iterator pointing to the beginning of the incident bonds.
bool containsAtom(const Atom &atom) const
Tells whether this atom and the argument atom are connected by a bond.
std::size_t getIndex() const
Returns the index of the atom in its parent molecule.
bool containsBond(const Bond &bond) const
Tells whether the specified bond is incident to this atom.
ConstBondIterator getBondsBegin() const
Returns a constant iterator pointing to the beginning of the incident bonds.
Bond * findBondToAtom(const Atom &atom)
Returns a pointer to the non-const Chem::Bond object that connects this atom to the argument atom.
std::size_t getNumBonds() const
Returns the number of incident bonds.
std::size_t getBondIndex(const Bond &bond) const
Returns the index of the specified incident bond.
BasicAtom & operator=(const BasicAtom &atom)
Assignment operator that replaces the current set of properties with the properties of atom;.
Molecule & getMolecule()
Returns a non-const reference to the parent molecule.
boost::transform_iterator< BondAccessor< BasicBond >, NeighborList::iterator > BondIterator
Definition: BasicAtom.hpp:88
const Bond & getBondToAtom(const Atom &atom) const
Returns a const reference to the Chem::Bond object that connects this atom to the argument atom.
void orderBonds(const BondCompareFunction &func)
Orders the stored bonds according to criteria implemented by the provided bond comparison function.
AtomIterator getAtomsBegin()
boost::transform_iterator< AtomAccessor< BasicAtom >, NeighborList::iterator > AtomIterator
Definition: BasicAtom.hpp:86
const Bond * findBondToAtom(const Atom &atom) const
Returns a pointer to the const Chem::Bond object that connects this atom to the argument atom.
ConstAtomIterator getAtomsBegin() const
std::size_t getAtomIndex(const Atom &atom) const
Returns the index of the specified connected atom.
Bond & getBond(std::size_t idx)
Returns a non-const reference to the incident bond at index idx.
std::size_t getNumAtoms() const
Returns the number of connected atoms.
const Bond & getBond(std::size_t idx) const
Returns a const reference to the incident bond at index idx.
boost::transform_iterator< BondAccessor< const BasicBond >, NeighborList::const_iterator > ConstBondIterator
Definition: BasicAtom.hpp:89
const Molecule & getMolecule() const
Returns a const reference to the parent molecule.
Atom & getAtom(std::size_t idx)
Returns a non-const reference to the connected atom at index idx.
const Atom & getAtom(std::size_t idx) const
Returns a const reference to the connected atom at index idx.
BasicBond.
Definition: BasicBond.hpp:49
BasicMolecule.
Definition: BasicMolecule.hpp:54
Bond.
Definition: Bond.hpp:50
Molecule.
Definition: Molecule.hpp:49
A STL compatible random access iterator for container elements accessible by index.
Definition: IndexedElementIterator.hpp:125
std::function< bool(const Chem::Atom &, const Chem::Atom &)> AtomCompareFunction
A generic wrapper class used to store a user-defined atom compare function.
Definition: AtomCompareFunction.hpp:41
CDPL_CHEM_API void connectAtoms(Molecule &mol, double dist_tol=0.3, std::size_t atom_idx_offs=0)
std::function< bool(const Chem::Bond &, const Chem::Bond &)> BondCompareFunction
A generic wrapper class used to store a user-defined bond compare function.
Definition: BondCompareFunction.hpp:41
The namespace of the Chemical Data Processing Library.