OEFFParams¶
Attention
This API is currently available in C++ and Python.
class OEFFParams
The OEFFParams is an abstract base class. This class defines the interface to retrieve parameters defined by a force field. In addition, simple methods are included for facile extraction of idealized geometric information base on the force field.
- The OEFFParams class defines the following public methods:
- The following classes derive from this class:
Constructors¶
OEFFParams() = default;
OEFFParams(const OEFFParams&) = default;
Constructor and copy constructor.
CreateCopy¶
OEFFParams *CreateCopy() const
This method returns a deep copy of the OEFFParams derived object. The copy of the object returned is in memory owned by the user making the function call. The delete operator must be called for the returned pointer when the copy is no longer needed in order to avoid memory leaks.
GetAtomTypeIndex¶
unsigned int GetAtomTypeIndex(unsigned int) const
Provides interface to get an atom type index for the atom identified by the force field type passed as an argument. The point is that a number of chemically different atom types in the force field can belong to a single type for which force field parameters are defined.
GetAtomTypeName¶
const char *GetAtomTypeName(unsigned int) const
Provides interface to convert the integer force field atom type into a symbolic type.
GetContactDistance¶
bool GetContactDistance(double &, const OEChem::OEAtomBase *,
const OEChem::OEAtomBase *) const
Provides the interface for retrieving the distance between two atoms corresponding to the minimum
on their VdW potential curve. The double precision floating point reference passed as the first
argument to the method is assigned to the contact distance for the two atoms if it is defined by
the force field. The method returns true
only if a valid force field parameter for the
interaction exists. OEFFParams.PrepMol
must be called for the molecule
prior to using this method.
GetCoulombParams¶
bool GetCoulombParams(OEInteractParams &, const OEChem::OEAtomBase *,
const OEChem::OEAtomBase *) const
Defines the interface for retrieving the parameters used in calculating an electrostatic
interaction for two atoms. Overriding methods return true
only if valid parameters exist
for the atoms passed as the second and third arguments, otherwise they return false
.
OEFFParams.PrepMol
must be called for the molecule prior to using
this method.
GetEquilibriumAngle¶
bool GetEquilibriumAngle(double &, const OEChem::OEAtomBase *,
const OEChem::OEAtomBase *,
const OEChem::OEAtomBase *) const
This method is used to retrieve the equilibrium bond angle for the three atoms passed to it.
The second atom passed to the method (atom2
) must be the central atom of the requested
bond angle. The double precision floating point reference passed as the first argument to the
method is assigned to the equilibrium bond angle if it is defined by the force field.
The method returns true
only if a valid force field parameter for the interaction exists.
OEFFParams.PrepMol
must be called for the molecule prior to using
this method.
GetEquilibriumBondLength¶
bool GetEquilibriumBondLength(double &, const OEChem::OEBondBase *) const
This method is used to retrieve the equilibrium bond length for the bond passed as the second
argument. The double precision floating point reference passed as the first argument to the
method is assigned to the equilibrium bond length if it is defined by the force field.
The method returns true
only if a valid force field parameter for the bond exists.
OEFFParams.PrepMol
must be called for the molecule prior to using
this method.
GetStretchBendParams¶
bool GetStretchBendParams(OEInteractParams &, const OEChem::OEAtomBase *,
const OEChem::OEAtomBase *,
const OEChem::OEAtomBase *) const
Defines the interface for retrieving the parameters used in calculating a stretch-bend
interaction. The central atom of the bond-angle must be passed as the third argument to the
method. Overriding methods return true
only if valid parameters exist for the atoms passed
as arguments, otherwise they should return false
.
OEFFParams.PrepMol
must be called for the molecule prior to using this
method.
GetVdwRadius¶
bool GetVdwRadius(double &, const OEChem::OEAtomBase *atm) const
Defines the interface for retrieving the VdW radius for an atom. Overriding methods return
true
only if a VdW radius can be calculated or retrieved for an atom, false
otherwise. OEFFParams.PrepMol
must be called for the molecule prior
to using this method.
PrepMol¶
bool PrepMol(OEChem::OEMolBase &mol, bool sweep=true, bool closestTypeAllowed=true) const
Defines the interface for preparing a molecule for force field parameter retrieval.
Atom types, names, partial charges, and indices stored within the molecule may be
modified by overriding methods. The second argument to the method specifies whether a
call to OEMolBase.Sweep
is allowed during the preparation. By default,
sweeping a molecule is allowed by the method. A return value of true
indicates a successful
preparation, however, if the method returns false
calculations with the resultant
modified molecule should not be attempted. The return value of this method should always be
checked before use with its associated force field and components.
- closestTypeAllowed
If true then the MMFF typing method will substitute close atom types if exact atom types do not exist.
See also
OEMMFFAtomType
function
GetVdwParams¶
bool GetVdwParams(OEMolPotential::OEInteractParams&, const OEChem::OEAtomBase*,
const OEChem::OEAtomBase*) const
Fills the first argument, OEInteractParams, with the Vdw parameters for the two non-bonded atoms specified by the second and the third arguments,
OEAtomBase. If parameters were not found, it returns false
;
otherwise, it returns true
.
OESystem::OEIterBase<OEMolPotential::OEVdwParams>*
GetVdwParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase>* pred=0,
const double rcut=0.0) const
Takes a molecule object, mol
, and returns an iterator to all
OEVdwParams objects created for that molecule. If the pointer
to atom predicate is passed as the second argument, all atoms engaged in vdw non-bonded
interactions will be tested against with that predicate. In this case, the returned
iterator will contain parameters for only those pairs of atoms that pass the test.
Similarly, all OEVdwParams objects for pairs outside the cutoff
radius, rcut
, will be eliminated. An rcut
value of 0.0
or less assumes that all interactions
should be included without any cutoff.
OESystem::OEIterBase<OEMolPotential::OEVdwParams>*
GetVdwParams(const OEChem::OEMolBase& mol,
const OEChem::OEMolBase& host,
const double rcut=0.0) const
Returns an iterator to all OEVdwParams objects created for
host-ligand interactions specified by the ligand molecule, mol
, and the host molecule, host
.
All OEVdwParams objects for pairs outside the cutoff
radius, rcut
, will be eliminated. An rcut
value of 0.0
or less assumes that all interactions
should be included without any cutoff.
GetStretchParams¶
bool GetStretchParams(OEMolPotential::OEInteractParams&, const OEChem::OEBondBase*) const
Fills the first argument, OEInteractParams, with the bond stretch parameters for the bond, OEBondBase
. If the parameters
were not found, it returns false
; otherwise, it returns true
.
OESystem::OEIterBase<OEMolPotential::OEStretchParams>*
GetStretchParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Takes a molecule object, mol
, and returns an iterator to all
OEStretchParams objects created for that molecule. If the pointer
to an atom predicate is passed as the second argument, all atoms making bonds will be tested
against with that predicate. In this case, the returned iterator will contain parameters for
only those bonds made between the atoms that pass the test.
GetBendParams¶
bool GetBendParams(OEMolPotential::OEInteractParams&, const OEChem::OEAtomBase*,
const OEChem::OEAtomBase*, const OEChem::OEAtomBase*) const
Fills the first argument, OEInteractParams, with the bend
parameters for a bond angle made by 3 atoms, OEAtomBase, passed as the second,
third and the forth arguments. If the parameters were not found, it returns false
; otherwise, it returns true
.
OESystem::OEIterBase<OEMolPotential::OEBendParams>*
GetBendParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Takes a molecule object, mol
, and returns an iterator to all
OEBendParams objects created for that molecule. If the pointer
to an atom predicate is passed as the second argument, all atoms making bond angles will be
tested against that with predicate and the returned iterator will contain parameters for only those
bond angles whose atom members pass the test.
GetTorsionParams¶
bool GetTorsionParams(OEMolPotential::OEInteractParams&, const OEChem::OEAtomBase*,
const OEChem::OEAtomBase*, const OEChem::OEAtomBase*,
const OEChem::OEAtomBase*) const
Fills the first argument, OEInteractParams, with the
torsion parameters for a torsion made by 4 atoms, OEAtomBase, passed as
the second, third, forth and the fifth arguments. If the parameters were not found, it
returns false
; otherwise, it returns true
.
OESystem::OEIterBase<OEMolPotential::OETorsionParams>*
GetTorsionParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Takes a molecule object, mol
, and returns an iterator to all
OETorsionParams objects created for that molecule. If the pointer
to an atom predicate is passed as the second argument, all atoms making torsions will be
tested against with that predicate and the returned iterator will contain parameters for
only those torsions whose atom members pass the test.
GetOutOfPlaneParams¶
bool GetOutOfPlaneParams(OEMolPotential::OEInteractParams&, const OEChem::OEAtomBase*,
const OEChem::OEAtomBase*, const OEChem::OEAtomBase*,
const OEChem::OEAtomBase*) const
Fills the first argument, OEInteractParams, with the
improper torsion parameters for an improper torsion made by 4 atoms, OEAtomBase,
passed as the second, third, forth and the fifth arguments. If the parameters were not found,
it returns false
; otherwise, it returns true
.
OESystem::OEIterBase<OEMolPotential::OEOutOfPlaneParams>*
GetOutOfPlaneParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Takes a molecule object, mol
, and returns an iterator to all
OESmirnoffOutOfPlane objects created for that molecule. If the pointer
to an atom predicate is passed as the second argument, all atoms making improper torsions will be
tested against with that predicate and the returned iterator will contain parameters for only those
improper torsions whose atom members pass the test.
HasVdwParams¶
bool HasVdwParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase>* pred=0,
const double rcut=0.0) const
bool HasVdwParams(const OEChem::OEMolBase& mol,
const OEChem::OEMolBase& host,
const double rcut=0.0) const
Returns if the desired Vdw parameters exist for the specified molecule, mol
.
See the GetVdwParams method.
HasStretchParams¶
bool HasStretchParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Returns if the desired bond stretching parameters exist for the specified molecule, mol
.
See the GetStretchParams method.
HasBendParams¶
bool HasBendParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Returns if the desired bend parameters exist for the specified molecule, mol
.
See the GetBendParams method.
HasTorsionParams¶
bool HasTorsionParams(const OEChem::OEMolBase& mol,
const OESystem::OEUnaryPredicate<OEChem::OEAtomBase> *pred=0) const
Returns if the desired torison parameters exist for the specified molecule, mol
.
See the GetTorsionParams method.