IMP  2.2.1
The Integrative Modeling Platform
BondSingletonScore.h
Go to the documentation of this file.
1 /**
2  * \file IMP/atom/BondSingletonScore.h
3  * \brief A Score on the distance between a the two particles in a bond.
4  *
5  * Copyright 2007-2014 IMP Inventors. All rights reserved.
6  */
7 
8 #ifndef IMPATOM_BOND_SINGLETON_SCORE_H
9 #define IMPATOM_BOND_SINGLETON_SCORE_H
10 
11 #include <IMP/atom/atom_config.h>
12 #include "bond_decorators.h"
13 #include <IMP/SingletonScore.h>
14 #include <IMP/UnaryFunction.h>
15 #include <IMP/base/Pointer.h>
16 
17 IMPATOM_BEGIN_NAMESPACE
18 
19 //! Score the bond based on a UnaryFunction,
20 /** The score is based on the difference between the stored length
21  and the actual length and scaled by the stiffness. That is
22  stiffness * (distance-bond_length)
23  \ingroup bond
24  \see Bond
25  \see Bonded
26  */
27 class IMPATOMEXPORT BondSingletonScore : public SingletonScore {
29 
30  public:
31  //! Use f to penalize deviations in length
33  UnaryFunction *get_unary_function() const { return f_; }
35  DerivativeAccumulator *da) const IMP_OVERRIDE;
37  kernel::Model *m, const kernel::ParticleIndexes &pis) const IMP_OVERRIDE;
40 };
41 
43 
44 IMPATOM_END_NAMESPACE
45 
46 #endif /* IMPATOM_BOND_SINGLETON_SCORE_H */
Class for adding derivatives from restraints to the model.
A nullptr-initialized pointer to an IMP Object.
A smart pointer to a ref-counted Object that is a class memeber.
Definition: base/Pointer.h:147
Import IMP/kernel/UnaryFunction.h in the namespace.
Abstract single variable functor class for score functions.
Contains decorators for a bond.
virtual double evaluate_index(kernel::Model *m, kernel::ParticleIndex vt, DerivativeAccumulator *da) const
Compute the score and the derivative if needed.
virtual ModelObjectsTemp do_get_inputs(kernel::Model *m, const ParticleIndexes &pis) const
#define IMP_OBJECT_METHODS(Name)
Define the basic things needed by any Object.
Score the bond based on a UnaryFunction,.
Import IMP/kernel/SingletonScore.h in the namespace.
#define IMP_OBJECTS(Name, PluralName)
Define the types for storing sets of objects.
Abstract score function.
#define IMP_SINGLETON_SCORE_METHODS(Name)
Class for storing model, its restraints, constraints, and particles.
Definition: kernel/Model.h:72