OpenMM
 All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends Pages
CMAPTorsionForceImpl Class Reference

This is the internal implementation of CMAPTorsionForce. More...

#include <CMAPTorsionForceImpl.h>

+ Inheritance diagram for CMAPTorsionForceImpl:

Public Member Functions

 CMAPTorsionForceImpl (const CMAPTorsionForce &owner)
 
 ~CMAPTorsionForceImpl ()
 
void initialize (ContextImpl &context)
 This is called after the ForceImpl is created and before updateContextState(), calcForces(), or calcEnergy() is called on it. More...
 
const CMAPTorsionForcegetOwner () const
 Get the Force object from which this ForceImpl was created. More...
 
void updateContextState (ContextImpl &context)
 This method is called at the beginning of each time step. More...
 
double calcForcesAndEnergy (ContextImpl &context, bool includeForces, bool includeEnergy, int groups)
 Calculate the force on each particle generated by this ForceImpl and/or this ForceImpl's contribution to the potential energy of the system. More...
 
std::map< std::string, double > getDefaultParameters ()
 Get a map containing the default values for all adjustable parameters defined by this ForceImpl. More...
 
std::vector< std::string > getKernelNames ()
 Get the names of all Kernels used by this Force. More...
 
- Public Member Functions inherited from ForceImpl
virtual ~ForceImpl ()
 
virtual std::vector< std::pair
< int, int > > 
getBondedParticles () const
 Get pairs of particles connected by bonds by this force. More...
 

Static Public Member Functions

static void calcMapDerivatives (int size, const std::vector< double > &energy, std::vector< std::vector< double > > &c)
 Given the energy values for a map, compute the spline coefficients at each point of the map. More...
 

Detailed Description

This is the internal implementation of CMAPTorsionForce.

Constructor & Destructor Documentation

Member Function Documentation

double calcForcesAndEnergy ( ContextImpl context,
bool  includeForces,
bool  includeEnergy,
int  groups 
)
virtual

Calculate the force on each particle generated by this ForceImpl and/or this ForceImpl's contribution to the potential energy of the system.

Parameters
contextthe context in which the system is being simulated
includeForcestrue if forces should be calculated
includeEnergytrue if the energy should be calculated
groupsa set of bit flags for which force groups to include. Group i should be included if (groups&(1<<i)) != 0.
Returns
this force's contribution to the potential energy of the system, or 0 if this force does not contribute to potential energy (or if includeEnergy is false)

Implements ForceImpl.

static void calcMapDerivatives ( int  size,
const std::vector< double > &  energy,
std::vector< std::vector< double > > &  c 
)
static

Given the energy values for a map, compute the spline coefficients at each point of the map.

std::map<std::string, double> getDefaultParameters ( )
inlinevirtual

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.

Implements ForceImpl.

std::vector<std::string> getKernelNames ( )
virtual

Get the names of all Kernels used by this Force.

Implements ForceImpl.

const CMAPTorsionForce& getOwner ( ) const
inlinevirtual

Get the Force object from which this ForceImpl was created.

Implements ForceImpl.

void initialize ( ContextImpl context)
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.

Implements ForceImpl.

void updateContextState ( ContextImpl context)
inlinevirtual

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.

Parameters
contextthe context in which the system is being simulated

Implements ForceImpl.


The documentation for this class was generated from the following file: