OpenMM
|
A ForceImpl provides the internal implementation of a Force. More...
#include <ForceImpl.h>
Public Member Functions | |
virtual | ~ForceImpl () |
virtual void | initialize (ContextImpl &context)=0 |
This is called after the ForceImpl is created and before updateContextState(), calcForces(), or calcEnergy() is called on it. More... | |
virtual const Force & | getOwner () const =0 |
Get the Force object from which this ForceImpl was created. More... | |
virtual void | updateContextState (ContextImpl &context)=0 |
This method is called at the beginning of each time step. More... | |
virtual double | calcForcesAndEnergy (ContextImpl &context, bool includeForces, bool includeEnergy, int groups)=0 |
Calculate the force on each particle generated by this ForceImpl and/or this ForceImpl's contribution to the potential energy of the system. More... | |
virtual std::map< std::string, double > | getDefaultParameters ()=0 |
Get a map containing the default values for all adjustable parameters defined by this ForceImpl. More... | |
virtual std::vector< std::string > | getKernelNames ()=0 |
Get the names of all Kernels used by this Force. More... | |
virtual std::vector< std::pair < int, int > > | getBondedParticles () const |
Get pairs of particles connected by bonds by this force. More... | |
A ForceImpl provides the internal implementation of a Force.
When a Context is created for a System, it creates a ForceImpl for each Force in the System. The ForceImpl is permitted to cache information from the Force or System which is needed to apply the force efficiently. If the user calls reinitialize() on the Context, all ForceImpl objects it had previously created are deleted and recreated from scratch.
This is an abstract class. Each Force subclass is responsible for defining its own ForceImpl subclass.
|
inlinevirtual |
|
pure virtual |
Calculate the force on each particle generated by this ForceImpl and/or this ForceImpl's contribution to the potential energy of the system.
context | the context in which the system is being simulated |
includeForces | true if forces should be calculated |
includeEnergy | true if the energy should be calculated |
groups | a set of bit flags for which force groups to include. Group i should be included if (groups&(1<<i)) != 0. |
Implemented in GBVIForceImpl, CustomCompoundBondForceImpl, CustomHbondForceImpl, NonbondedForceImpl, DrudeForceImpl, AmoebaVdwForceImpl, CustomNonbondedForceImpl, AmoebaBondForceImpl, CustomAngleForceImpl, CustomBondForceImpl, CustomExternalForceImpl, CustomGBForceImpl, CustomTorsionForceImpl, HarmonicAngleForceImpl, HarmonicBondForceImpl, PeriodicTorsionForceImpl, RBTorsionForceImpl, AmoebaAngleForceImpl, AmoebaInPlaneAngleForceImpl, AmoebaMultipoleForceImpl, AmoebaOutOfPlaneBendForceImpl, AmoebaPiTorsionForceImpl, AmoebaStretchBendForceImpl, AmoebaWcaDispersionForceImpl, CMAPTorsionForceImpl, AmoebaTorsionTorsionForceImpl, AndersenThermostatImpl, GBSAOBCForceImpl, AmoebaGeneralizedKirkwoodForceImpl, MonteCarloAnisotropicBarostatImpl, MonteCarloBarostatImpl, and CMMotionRemoverImpl.
|
inlinevirtual |
Get pairs of particles connected by bonds by this force.
This is used to determine which particles are part of the same molecule.
Reimplemented in AmoebaBondForceImpl, HarmonicBondForceImpl, and CustomBondForceImpl.
|
pure virtual |
Get a map containing the default values for all adjustable parameters defined by this ForceImpl.
These parameters and their default values will automatically be added to the Context.
Implemented in GBVIForceImpl, CustomCompoundBondForceImpl, CustomHbondForceImpl, NonbondedForceImpl, DrudeForceImpl, AmoebaVdwForceImpl, CustomNonbondedForceImpl, AmoebaBondForceImpl, AndersenThermostatImpl, CustomAngleForceImpl, CustomBondForceImpl, CustomExternalForceImpl, CustomGBForceImpl, CustomTorsionForceImpl, HarmonicAngleForceImpl, HarmonicBondForceImpl, PeriodicTorsionForceImpl, RBTorsionForceImpl, AmoebaAngleForceImpl, AmoebaInPlaneAngleForceImpl, AmoebaMultipoleForceImpl, AmoebaOutOfPlaneBendForceImpl, AmoebaPiTorsionForceImpl, AmoebaStretchBendForceImpl, AmoebaWcaDispersionForceImpl, CMAPTorsionForceImpl, MonteCarloAnisotropicBarostatImpl, MonteCarloBarostatImpl, AmoebaTorsionTorsionForceImpl, CMMotionRemoverImpl, GBSAOBCForceImpl, and AmoebaGeneralizedKirkwoodForceImpl.
|
pure virtual |
Get the names of all Kernels used by this Force.
Implemented in GBVIForceImpl, NonbondedForceImpl, DrudeForceImpl, AmoebaVdwForceImpl, CustomCompoundBondForceImpl, CustomHbondForceImpl, AmoebaBondForceImpl, HarmonicAngleForceImpl, HarmonicBondForceImpl, PeriodicTorsionForceImpl, RBTorsionForceImpl, AmoebaAngleForceImpl, AmoebaInPlaneAngleForceImpl, AmoebaMultipoleForceImpl, AmoebaOutOfPlaneBendForceImpl, AmoebaPiTorsionForceImpl, AmoebaStretchBendForceImpl, AmoebaWcaDispersionForceImpl, CMAPTorsionForceImpl, CustomNonbondedForceImpl, AmoebaTorsionTorsionForceImpl, AndersenThermostatImpl, CustomAngleForceImpl, CustomBondForceImpl, CustomExternalForceImpl, CustomGBForceImpl, CustomTorsionForceImpl, CMMotionRemoverImpl, GBSAOBCForceImpl, MonteCarloAnisotropicBarostatImpl, MonteCarloBarostatImpl, and AmoebaGeneralizedKirkwoodForceImpl.
|
pure virtual |
Get the Force object from which this ForceImpl was created.
Implemented in CustomCompoundBondForceImpl, CustomHbondForceImpl, NonbondedForceImpl, DrudeForceImpl, AmoebaVdwForceImpl, CustomNonbondedForceImpl, AmoebaBondForceImpl, CustomAngleForceImpl, CustomBondForceImpl, CustomExternalForceImpl, CustomGBForceImpl, CustomTorsionForceImpl, HarmonicAngleForceImpl, HarmonicBondForceImpl, PeriodicTorsionForceImpl, RBTorsionForceImpl, AmoebaAngleForceImpl, AmoebaInPlaneAngleForceImpl, AmoebaMultipoleForceImpl, AmoebaOutOfPlaneBendForceImpl, AmoebaPiTorsionForceImpl, AmoebaStretchBendForceImpl, AmoebaWcaDispersionForceImpl, AndersenThermostatImpl, CMAPTorsionForceImpl, AmoebaTorsionTorsionForceImpl, MonteCarloAnisotropicBarostatImpl, MonteCarloBarostatImpl, GBSAOBCForceImpl, GBVIForceImpl, AmoebaGeneralizedKirkwoodForceImpl, and CMMotionRemoverImpl.
|
pure virtual |
This is called after the ForceImpl is created and before updateContextState(), calcForces(), or calcEnergy() is called on it.
This allows it to do any necessary initialization.
Implemented in CustomCompoundBondForceImpl, CustomHbondForceImpl, NonbondedForceImpl, DrudeForceImpl, AmoebaVdwForceImpl, CustomNonbondedForceImpl, AmoebaBondForceImpl, CustomAngleForceImpl, CustomBondForceImpl, CustomExternalForceImpl, CustomGBForceImpl, CustomTorsionForceImpl, HarmonicAngleForceImpl, HarmonicBondForceImpl, PeriodicTorsionForceImpl, RBTorsionForceImpl, AmoebaAngleForceImpl, AmoebaInPlaneAngleForceImpl, AmoebaMultipoleForceImpl, AmoebaOutOfPlaneBendForceImpl, AmoebaPiTorsionForceImpl, AmoebaStretchBendForceImpl, AmoebaWcaDispersionForceImpl, AndersenThermostatImpl, CMAPTorsionForceImpl, AmoebaTorsionTorsionForceImpl, MonteCarloAnisotropicBarostatImpl, MonteCarloBarostatImpl, GBSAOBCForceImpl, GBVIForceImpl, AmoebaGeneralizedKirkwoodForceImpl, and CMMotionRemoverImpl.
|
pure virtual |
This method is called at the beginning of each time step.
It give the ForceImpl a chance to modify the state variables (positions, velocities, and parameters) stored in the Context in arbitrary ways before integration is performed.
context | the context in which the system is being simulated |
Implemented in GBVIForceImpl, CustomCompoundBondForceImpl, CustomHbondForceImpl, NonbondedForceImpl, DrudeForceImpl, AmoebaVdwForceImpl, CustomNonbondedForceImpl, AmoebaBondForceImpl, CustomAngleForceImpl, CustomBondForceImpl, CustomExternalForceImpl, CustomGBForceImpl, CustomTorsionForceImpl, HarmonicAngleForceImpl, HarmonicBondForceImpl, PeriodicTorsionForceImpl, RBTorsionForceImpl, AmoebaAngleForceImpl, AmoebaInPlaneAngleForceImpl, AmoebaMultipoleForceImpl, AmoebaOutOfPlaneBendForceImpl, AmoebaPiTorsionForceImpl, AmoebaStretchBendForceImpl, AmoebaWcaDispersionForceImpl, AndersenThermostatImpl, CMAPTorsionForceImpl, AmoebaTorsionTorsionForceImpl, MonteCarloAnisotropicBarostatImpl, MonteCarloBarostatImpl, GBSAOBCForceImpl, AmoebaGeneralizedKirkwoodForceImpl, and CMMotionRemoverImpl.