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
|
// Copyright (C) 2013-2025 Paolo Tosco and other RDKit contributors
//
// @@ 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_MMFFBONDSTRETCH_H__
#define __RD_MMFFBONDSTRETCH_H__
#include <ForceField/Contrib.h>
#include <vector>
namespace ForceFields {
namespace MMFF {
class MMFFBond;
class MMFFBondStretchEmpiricalRule;
//! The bond-stretch term for MMFF
class RDKIT_FORCEFIELD_EXPORT BondStretchContrib : public ForceFieldContrib {
public:
BondStretchContrib() {}
//! Constructor
BondStretchContrib(ForceField *owner);
/*! Adds a bond stretch to the contrib
\param idx1 index of end1 in the ForceField's positions
\param idx2 index of end2 in the ForceField's positions
\param bondType MMFF94 type of the bond (as an unsigned int)
\param end1Params pointer to the parameters for end1
\param end2Params pointer to the parameters for end2
*/
void addTerm(const unsigned int idx1,
const unsigned int idx2,
const MMFFBond *mmffBondParams);
double getEnergy(double *pos) const override;
void getGrad(double *pos, double *grad) const override;
BondStretchContrib *copy() const override {
return new BondStretchContrib(*this);
}
private:
std::vector<int> d_at1Idxs, d_at2Idxs; //!< indices of end points
std::vector<double> d_r0; //!< rest length of the bond
std::vector<double> d_kb; //!< force constant of the bond
};
namespace Utils {
//! returns the MMFF rest length for a bond
RDKIT_FORCEFIELD_EXPORT double calcBondRestLength(
const MMFFBond *mmffBondParams);
//! returns the MMFF force constant for a bond
RDKIT_FORCEFIELD_EXPORT double calcBondForceConstant(
const MMFFBond *mmffBondParams);
//! calculates and returns the bond stretching MMFF energy
RDKIT_FORCEFIELD_EXPORT double calcBondStretchEnergy(const double r0,
const double kb,
const double distance);
} // namespace Utils
} // namespace MMFF
} // namespace ForceFields
#endif
|