GBSAOBCForce¶
-
class
OpenMM::
GBSAOBCForce
¶ This class implements an implicit solvation force using the GBSA-OBC model.
To use this class, create a
GBSAOBCForce
object, then calladdParticle()
once for each particle in theSystem
to define its parameters. The number of particles for which you define GBSA parameters must be exactly equal to the number of particles in theSystem
, or else an exception will be thrown when you try to create aContext
. After a particle has been added, you can modify its force field parameters by callingsetParticleParameters()
. This will have no effect on Contexts that already exist unless you callupdateParametersInContext()
.When using this
Force
, theSystem
should also include aNonbondedForce
, and both objects must specify identical charges for all particles. Otherwise, the results will not be correct. Furthermore, if the nonbonded method is set to CutoffNonPeriodic or CutoffPeriodic, you should call setReactionFieldDielectric(1.0) on theNonbondedForce
to turn off the reaction field approximation, which does not produce correct results when combined with GBSA.Methods
GBSAOBCForce
Create a GBSAOBCForce
.getNumParticles
Get the number of particles in the system. addParticle
Add the GBSA parameters for a particle. getParticleParameters
Get the force field parameters for a particle. setParticleParameters
Set the force field parameters for a particle. getSolventDielectric
Get the dielectric constant for the solvent. setSolventDielectric
Set the dielectric constant for the solvent. getSoluteDielectric
Get the dielectric constant for the solute. setSoluteDielectric
Set the dielectric constant for the solute. getSurfaceAreaEnergy
Get the energy scale for the surface energy term, measured in kJ/mol/nm^2. setSurfaceAreaEnergy
Set the energy scale for the surface energy term, measured in kJ/mol/nm^2. getNonbondedMethod
Get the method used for handling long range nonbonded interactions. setNonbondedMethod
Set the method used for handling long range nonbonded interactions. getCutoffDistance
Get the cutoff distance (in nm) being used for nonbonded interactions. setCutoffDistance
Set the cutoff distance (in nm) being used for nonbonded interactions. updateParametersInContext
Update the particle parameters in a Context
to match those stored in thisForce
object.usesPeriodicBoundaryConditions
Returns whether or not this force makes use of periodic boundary conditions. Enum: NonbondedMethod
NoCutoff No cutoff is applied to nonbonded interactions. The full set of N^2 interactions is computed exactly. This necessarily means that periodic boundary conditions cannot be used. This is the default. CutoffNonPeriodic Interactions beyond the cutoff distance are ignored. CutoffPeriodic Periodic boundary conditions are used, so that each particle interacts only with the nearest periodic copy of each other particle. Interactions beyond the cutoff distance are ignored. -
GBSAOBCForce
()¶ Create a
GBSAOBCForce()
.
-
int
getNumParticles
() const¶ Get the number of particles in the system.
-
int
addParticle
(double charge, double radius, double scalingFactor)¶ Add the GBSA parameters for a particle. This should be called once for each particle in the
System
. When it is called for the i’th time, it specifies the parameters for the i’th particle.Parameters: - charge – the charge of the particle, measured in units of the proton charge
- radius – the GBSA radius of the particle, measured in nm
- scalingFactor – the OBC scaling factor for the particle
Returns: the index of the particle that was added
-
void
getParticleParameters
(int index, double &charge, double &radius, double &scalingFactor) const¶ Get the force field parameters for a particle.
Parameters: - index – the index of the particle for which to get parameters
- charge – [out] the charge of the particle, measured in units of the proton charge
- radius – [out] the GBSA radius of the particle, measured in nm
- scalingFactor – [out] the OBC scaling factor for the particle
-
void
setParticleParameters
(int index, double charge, double radius, double scalingFactor)¶ Set the force field parameters for a particle.
Parameters: - index – the index of the particle for which to set parameters
- charge – the charge of the particle, measured in units of the proton charge
- radius – the GBSA radius of the particle, measured in nm
- scalingFactor – the OBC scaling factor for the particle
-
double
getSolventDielectric
() const¶ Get the dielectric constant for the solvent.
-
void
setSolventDielectric
(double dielectric)¶ Set the dielectric constant for the solvent.
-
double
getSoluteDielectric
() const¶ Get the dielectric constant for the solute.
-
void
setSoluteDielectric
(double dielectric)¶ Set the dielectric constant for the solute.
-
double
getSurfaceAreaEnergy
() const¶ Get the energy scale for the surface energy term, measured in kJ/mol/nm^2.
-
void
setSurfaceAreaEnergy
(double energy)¶ Set the energy scale for the surface energy term, measured in kJ/mol/nm^2.
-
NonbondedMethod
getNonbondedMethod
() const¶ Get the method used for handling long range nonbonded interactions.
-
void
setNonbondedMethod
(NonbondedMethod method)¶ Set the method used for handling long range nonbonded interactions.
-
double
getCutoffDistance
() const¶ Get the cutoff distance (in nm) being used for nonbonded interactions. If the NonbondedMethod in use is NoCutoff, this value will have no effect.
Returns: the cutoff distance, measured in nm
-
void
setCutoffDistance
(double distance)¶ Set the cutoff distance (in nm) being used for nonbonded interactions. If the NonbondedMethod in use is NoCutoff, this value will have no effect.
Parameters: - distance – the cutoff distance, measured in nm
-
void
updateParametersInContext
(Context &context)¶ Update the particle parameters in a
Context
to match those stored in thisForce
object. This method provides an efficient method to update certain parameters in an existingContext
without needing to reinitialize it. Simply callsetParticleParameters()
to modify this object’s parameters, then callupdateParametersInContext()
to copy them over to theContext
.The only information this method updates is the values of per-particle parameters. All other aspects of the
Force
(the nonbonded method, the cutoff distance, etc.) are unaffected and can only be changed by reinitializing theContext
. Furthermore, this method cannot be used to add new particles, only to change the parameters of existing ones.
-
bool
usesPeriodicBoundaryConditions
() const¶ Returns whether or not this force makes use of periodic boundary conditions.
Returns: true if force uses PBC and false otherwise
-