In many applications (e.g. More...
#include <ReferenceArguments.h>
Public Member Functions | |
ReferenceArguments (const ReferenceConfigurationOptions &ro) | |
virtual double | calc (const std::vector< Vector > &pos, const Pbc &pbc, const std::vector< Value *> &vals, const std::vector< double > &args, ReferenceValuePack &myder, const bool &squared) const =0 |
Calculate the distance from the reference configuration. More... | |
double | calculate (const std::vector< Vector > &pos, const Pbc &pbc, const std::vector< Value *> &vals, ReferenceValuePack &myder, const bool &squared=false) const |
Calculate the distance from the reference configuration. More... | |
virtual double | calculateArgumentDistance (const std::vector< Value *> &vals, const std::vector< double > &arg, ReferenceValuePack &myder, const bool &squared) const |
Calculate the euclidean/malanobius distance the atoms have moved from the reference configuration in CV space. More... | |
void | copyDerivatives (const ReferenceConfiguration *) |
Parse something from the pdb remarks Copy derivatives from one frame to this frame. More... | |
void | displaceReferenceArguments (const double &weight, const std::vector< double > &displace) |
Displace the positions of the reference atoms. More... | |
void | displaceReferenceConfiguration (const double &weight, Direction &dir) |
Move the reference configuration by an ammount specified using a Direction. More... | |
virtual void | extractArgumentDisplacement (const std::vector< Value *> &vals, const std::vector< double > &arg, std::vector< double > &dirout) const |
Extract the displacement from a position in a space. More... | |
void | extractDisplacementVector (const std::vector< Vector > &pos, const std::vector< Value *> &vals, const std::vector< double > &arg, const bool &nflag, Direction &mydir) const |
Extract a Direction giving you the displacement from some position. More... | |
virtual const std::vector< AtomNumber > & | getAbsoluteIndexes () |
These are overwritten in ReferenceArguments and ReferenceAtoms to make frame copying work. More... | |
const std::vector< std::string > & | getArgumentNames () |
Return names. More... | |
void | getArgumentRequests (std::vector< std::string > &, bool disable_checks=false) |
Get the arguments required. More... | |
virtual void | getAtomRequests (std::vector< AtomNumber > &, bool disable_checks=false) |
Retrieve the atoms that are required for this guy. More... | |
std::string | getName () const |
Return the name of this metric. More... | |
unsigned | getNumberOfReferenceArguments () const |
Get the number of reference arguments. More... | |
virtual unsigned | getNumberOfReferencePositions () const |
double | getReferenceArgument (const unsigned &i) const |
Get the value of the ith reference argument. More... | |
const std::vector< double > & | getReferenceArguments () const |
Return all the reference arguments. More... | |
const std::vector< double > & | getReferenceMetric () |
virtual const std::vector< Vector > & | getReferencePositions () const |
These are overwritten in ReferenceArguments and ReferenceAtoms but are required here to make PLMD::distance work. More... | |
void | moveReferenceArguments (const std::vector< double > &arg_vals) |
Set the positions of the reference arguments. More... | |
virtual bool | pcaIsEnabledForThisReference () |
Stuff for pca. More... | |
double | projectArgDisplacementOnVector (const std::vector< double > &eigv, const std::vector< Value *> &vals, const std::vector< double > &arg, ReferenceValuePack &mypack) const |
Project the displacement of the arguments on a vector. More... | |
double | projectDisplacementOnVector (const Direction &mydir, const std::vector< Value *> &vals, const std::vector< double > &arg, ReferenceValuePack &mypack) const |
virtual void | read (const PDB &)=0 |
Do all local business for setting the configuration. More... | |
void | setReferenceArguments (const std::vector< double > &arg_vals, const std::vector< double > &sigma) |
Set the positions of the refernce arguments. More... | |
virtual void | setupPCAStorage (ReferenceValuePack &mypack) |
Stuff to setup pca. More... | |
Protected Member Functions | |
void | error (const std::string &msg) |
Crash with an error. More... | |
void | readArgumentsFromPDB (const PDB &pdb) |
Read in the atoms from the pdb file. More... | |
void | setReferenceArguments () |
Set the values of the colvars based on their current instantanous values (used in Analysis) More... | |
Protected Attributes | |
bool | hasmetric |
Are we calculating a Malanobius distance. More... | |
bool | hasweights |
Are we reading weights from input. More... | |
Private Attributes | |
std::vector< unsigned > | arg_der_index |
The indices for setting derivatives. More... | |
std::vector< std::string > | arg_names |
The names of the arguments. More... | |
Matrix< double > | metric |
The N X N matrix we are using to calculate our Malanobius distance. More... | |
std::vector< double > | reference_args |
The values of the colvars in the reference configuration. More... | |
std::vector< double > | sqrtweight |
std::vector< double > | trig_metric |
std::vector< double > | weights |
The weights for normed euclidean distance. More... | |
Friends | |
class | Direction |
class | ReferenceConfiguration |
In many applications (e.g.
paths, fields, property maps) it is necessary to calculate the distance between two configurations. These distances can be calculated in a variety of different ways. For instance, one can assert that the distance between the two configuration is the distance one would have to move all the atoms to transform configuration 1 into configuration
|
explicit |
|
pure virtualinherited |
Calculate the distance from the reference configuration.
Implemented in PLMD::MultiDomainRMSD, PLMD::ArgumentOnlyDistance, PLMD::SingleDomainRMSD, PLMD::Direction, and PLMD::FakeFrame.
|
inherited |
Calculate the distance from the reference configuration.
|
virtual |
Calculate the euclidean/malanobius distance the atoms have moved from the reference configuration in CV space.
Reimplemented in PLMD::DotProductDistance.
|
inherited |
Parse something from the pdb remarks Copy derivatives from one frame to this frame.
void PLMD::ReferenceArguments::displaceReferenceArguments | ( | const double & | weight, |
const std::vector< double > & | displace | ||
) |
Displace the positions of the reference atoms.
|
inherited |
Move the reference configuration by an ammount specified using a Direction.
|
protectedinherited |
Crash with an error.
|
virtual |
Extract the displacement from a position in a space.
Reimplemented in PLMD::Direction.
|
inherited |
Extract a Direction giving you the displacement from some position.
|
inlinevirtualinherited |
These are overwritten in ReferenceArguments and ReferenceAtoms to make frame copying work.
Reimplemented in PLMD::ReferenceAtoms.
|
inlinevirtual |
Return names.
Reimplemented from PLMD::ReferenceConfiguration.
|
virtual |
Get the arguments required.
Reimplemented from PLMD::ReferenceConfiguration.
|
inlinevirtualinherited |
Retrieve the atoms that are required for this guy.
Reimplemented in PLMD::ReferenceAtoms.
|
inherited |
Return the name of this metric.
|
inlinevirtual |
Get the number of reference arguments.
Reimplemented from PLMD::ReferenceConfiguration.
|
inlinevirtualinherited |
Reimplemented in PLMD::ReferenceAtoms.
|
inlinevirtual |
Get the value of the ith reference argument.
Reimplemented from PLMD::ReferenceConfiguration.
|
inlinevirtual |
Return all the reference arguments.
Reimplemented from PLMD::ReferenceConfiguration.
|
virtual |
Reimplemented from PLMD::ReferenceConfiguration.
|
inlinevirtualinherited |
These are overwritten in ReferenceArguments and ReferenceAtoms but are required here to make PLMD::distance work.
Reimplemented in PLMD::ReferenceAtoms.
void PLMD::ReferenceArguments::moveReferenceArguments | ( | const std::vector< double > & | arg_vals | ) |
Set the positions of the reference arguments.
|
inlinevirtualinherited |
Stuff for pca.
Reimplemented in PLMD::MultiDomainRMSD, PLMD::ArgumentOnlyDistance, PLMD::OptimalRMSD, and PLMD::SimpleRMSD.
double PLMD::ReferenceArguments::projectArgDisplacementOnVector | ( | const std::vector< double > & | eigv, |
const std::vector< Value *> & | vals, | ||
const std::vector< double > & | arg, | ||
ReferenceValuePack & | mypack | ||
) | const |
Project the displacement of the arguments on a vector.
|
inherited |
|
pure virtualinherited |
Do all local business for setting the configuration.
Implemented in PLMD::DRMSD, PLMD::MultiDomainRMSD, PLMD::ArgumentOnlyDistance, PLMD::Direction, PLMD::OptimalRMSD, PLMD::FakeFrame, PLMD::IntermolecularDRMSD, PLMD::IntramolecularDRMSD, PLMD::SimpleRMSD, and PLMD::DotProductDistance.
|
protected |
Read in the atoms from the pdb file.
|
protected |
Set the values of the colvars based on their current instantanous values (used in Analysis)
void PLMD::ReferenceArguments::setReferenceArguments | ( | const std::vector< double > & | arg_vals, |
const std::vector< double > & | sigma | ||
) |
Set the positions of the refernce arguments.
|
inlinevirtualinherited |
Stuff to setup pca.
Reimplemented in PLMD::MultiDomainRMSD, PLMD::ArgumentOnlyDistance, PLMD::OptimalRMSD, and PLMD::SimpleRMSD.
|
friend |
|
friend |
|
private |
The indices for setting derivatives.
|
private |
The names of the arguments.
|
protected |
Are we calculating a Malanobius distance.
|
protected |
Are we reading weights from input.
|
private |
The N X N matrix we are using to calculate our Malanobius distance.
|
private |
The values of the colvars in the reference configuration.
|
private |
|
private |
|
private |
The weights for normed euclidean distance.
Hosted by GitHub | 1.8.14 |