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
|
//
// Copyright (C) 2004-2006 Rational Discovery LLC
//
// @@ 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_NONBONDED_H__
#define __RD_NONBONDED_H__
#include <ForceField/Contrib.h>
namespace ForceFields {
namespace UFF {
class AtomicParams;
//! the van der Waals term for the Universal Force Field
/*!
<b>The Distance Threshold</b>
For the sake of efficiency, each vdwContrib maintains a threshold
distance. When the distance between the two atoms exceeds this
threshold, the vdwContrib makes no contribution to either the
energy or the gradient.
The threshold is set to a multiple of the vdW distance's preferred
length. This multiplier can be supplied to the constructor.
*/
class RDKIT_FORCEFIELD_EXPORT vdWContrib : public ForceFieldContrib {
public:
vdWContrib() : d_at1Idx(-1), d_at2Idx(-1){};
//! Constructor
/*!
\param owner pointer to the owning ForceField
\param idx1 index of end1 in the ForceField's positions
\param idx2 index of end2 in the ForceField's positions
\param at1Params pointer to the parameters for end1
\param at2Params pointer to the parameters for end2
\param threshMultiplier (optional) multiplier for the threshold
calculation. See class documentation for details.
*/
vdWContrib(ForceField *owner, unsigned int idx1, unsigned int idx2,
const AtomicParams *at1Params, const AtomicParams *at2Params,
double threshMultiplier = 10.0);
double getEnergy(double *pos) const;
void getGrad(double *pos, double *grad) const;
virtual vdWContrib *copy() const { return new vdWContrib(*this); };
private:
int d_at1Idx, d_at2Idx;
double d_xij; //!< the preferred length of the contact
double d_wellDepth; //!< the vdW well depth (strength of the interaction)
double d_thresh; //!< the distance threshold
};
namespace Utils {
//! calculates and returns the UFF minimum position for a vdW contact
/*!
\param at1Params pointer to the parameters for end1
\param at2Params pointer to the parameters for end2
\return the position of the minimum
*/
RDKIT_FORCEFIELD_EXPORT double calcNonbondedMinimum(const AtomicParams *at1Params,
const AtomicParams *at2Params);
//! calculates and returns the UFF well depth for a vdW contact
/*!
\param at1Params pointer to the parameters for end1
\param at2Params pointer to the parameters for end2
\return the depth of the well
*/
RDKIT_FORCEFIELD_EXPORT double calcNonbondedDepth(const AtomicParams *at1Params,
const AtomicParams *at2Params);
}
}
}
#endif
|