29 #ifndef CDPL_FORCEFIELD_MMFF94BONDCHARGEINCREMENTTABLE_HPP
30 #define CDPL_FORCEFIELD_MMFF94BONDCHARGEINCREMENTTABLE_HPP
35 #include <unordered_map>
39 #include <boost/iterator/transform_iterator.hpp>
63 typedef std::unordered_map<std::uint32_t, Entry> DataStorage;
88 Entry(
unsigned int bond_type_idx,
unsigned int atom1_type,
unsigned int atom2_type,
double bond_chg_inc);
121 unsigned int bondTypeIdx;
122 unsigned int atom1Type;
123 unsigned int atom2Type;
129 typedef boost::transform_iterator<std::function<
const Entry&(
const DataStorage::value_type&)>,
130 DataStorage::const_iterator>
134 typedef boost::transform_iterator<std::function<
Entry&(DataStorage::value_type&)>,
135 DataStorage::iterator>
150 void addEntry(
unsigned int bond_type_idx,
unsigned int atom1_type,
unsigned int atom2_type,
double bond_chg_inc);
159 const Entry&
getEntry(
unsigned int bond_type_idx,
unsigned int atom1_type,
unsigned int atom2_type)
const;
179 bool removeEntry(
unsigned int bond_type_idx,
unsigned int atom1_type,
unsigned int atom2_type);
Definition of the preprocessor macro CDPL_FORCEFIELD_API.
#define CDPL_FORCEFIELD_API
Tells the compiler/linker which classes, functions and variables are part of the library API.
A single bond charge increment table record.
Definition: MMFF94BondChargeIncrementTable.hpp:73
unsigned int getBondTypeIndex() const
Returns the MMFF94 bond type index.
unsigned int getAtom1Type() const
Returns the numeric MMFF94 atom type of the first bonded atom.
unsigned int getAtom2Type() const
Returns the numeric MMFF94 atom type of the second bonded atom.
Entry(unsigned int bond_type_idx, unsigned int atom1_type, unsigned int atom2_type, double bond_chg_inc)
Constructs an Entry for the given (bond type, atom type 1, atom type 2) triple with charge increment ...
Entry()
Constructs an empty (uninitialized) Entry instance.
double getChargeIncrement() const
Returns the bond charge increment.
Lookup table mapping (bond type, atom-type 1, atom-type 2) triples to MMFF94 bond charge increments.
Definition: MMFF94BondChargeIncrementTable.hpp:57
const Entry & getEntry(unsigned int bond_type_idx, unsigned int atom1_type, unsigned int atom2_type) const
Returns the entry for the given (bond type, atom type 1, atom type 2) triple.
ConstEntryIterator getEntriesBegin() const
Returns a constant iterator pointing to the beginning of the entry list.
static const SharedPointer & get()
Returns the process-wide default table (lazily initialized on first call).
EntryIterator removeEntry(const EntryIterator &it)
Removes the entry pointed to by the iterator it.
EntryIterator getEntriesEnd()
Returns a mutable iterator pointing one past the last entry.
EntryIterator getEntriesBegin()
Returns a mutable iterator pointing to the beginning of the entry list.
boost::transform_iterator< std::function< Entry &(DataStorage::value_type &)>, DataStorage::iterator > EntryIterator
A mutable iterator over the entries of the table.
Definition: MMFF94BondChargeIncrementTable.hpp:136
EntryIterator end()
Returns a mutable iterator pointing one past the last entry (alias of getEntriesEnd()).
void load(std::istream &is)
Loads table entries from the input stream is.
EntryIterator begin()
Returns a mutable iterator pointing to the beginning of the entry list (alias of getEntriesBegin()).
void addEntry(unsigned int bond_type_idx, unsigned int atom1_type, unsigned int atom2_type, double bond_chg_inc)
Adds (or overwrites) the entry for the given (bond type, atom type 1, atom type 2) triple.
ConstEntryIterator getEntriesEnd() const
Returns a constant iterator pointing one past the last entry.
void loadDefaults()
Loads the built-in default bond charge increment entries.
void clear()
Removes all entries from the table.
bool removeEntry(unsigned int bond_type_idx, unsigned int atom1_type, unsigned int atom2_type)
Removes the entry for the given (bond type, atom type 1, atom type 2) triple.
std::size_t getNumEntries() const
Returns the number of entries in the table.
ConstEntryIterator end() const
Returns a constant iterator pointing one past the last entry (alias of getEntriesEnd()).
std::shared_ptr< MMFF94BondChargeIncrementTable > SharedPointer
A reference-counted smart pointer [SHPTR] for dynamically allocated MMFF94BondChargeIncrementTable in...
Definition: MMFF94BondChargeIncrementTable.hpp:67
boost::transform_iterator< std::function< const Entry &(const DataStorage::value_type &)>, DataStorage::const_iterator > ConstEntryIterator
A constant iterator over the entries of the table.
Definition: MMFF94BondChargeIncrementTable.hpp:131
static void set(const SharedPointer &table)
Replaces the process-wide default table by table.
ConstEntryIterator begin() const
Returns a constant iterator pointing to the beginning of the entry list (alias of getEntriesBegin()).
MMFF94BondChargeIncrementTable()
Constructs an empty MMFF94BondChargeIncrementTable instance.
The namespace of the Chemical Data Processing Library.