1 | /*
|
---|
2 | * FourBodyPotential_Improper.hpp
|
---|
3 | *
|
---|
4 | * Created on: Jul 10, 2013
|
---|
5 | * Author: heber
|
---|
6 | */
|
---|
7 |
|
---|
8 | #ifndef FOURBODYPOTENTIAL_IMPROPER_HPP_
|
---|
9 | #define FOURBODYPOTENTIAL_IMPROPER_HPP_
|
---|
10 |
|
---|
11 | // include config.h
|
---|
12 | #ifdef HAVE_CONFIG_H
|
---|
13 | #include <config.h>
|
---|
14 | #endif
|
---|
15 |
|
---|
16 | #include "FourBodyPotential_Torsion.hpp"
|
---|
17 |
|
---|
18 | class FourBodyPotential_ImproperTest;
|
---|
19 | class PotentialFactory;
|
---|
20 |
|
---|
21 | /** The improper potential is identical to the torsion potential with exception
|
---|
22 | * of the way the angle is calculated.
|
---|
23 | *
|
---|
24 | * Hence, we only need to override function_theta().
|
---|
25 | *
|
---|
26 | */
|
---|
27 | class FourBodyPotential_Improper : public FourBodyPotential_Torsion
|
---|
28 | {
|
---|
29 | //!> grant unit test access to internal parts
|
---|
30 | friend class FourBodyPotential_ImproperTest;
|
---|
31 | //!> grant PotentialFactory access to default cstor
|
---|
32 | friend class PotentialFactory;
|
---|
33 | // some repeated typedefs to avoid ambiguities
|
---|
34 | typedef FunctionModel::result_t result_t;
|
---|
35 | typedef FunctionModel::results_t results_t;
|
---|
36 | private:
|
---|
37 | /** Private default constructor.
|
---|
38 | *
|
---|
39 | * This prevents creation of potential without set ParticleTypes_t.
|
---|
40 | *
|
---|
41 | * \note PotentialFactory may use this default cstor
|
---|
42 | *
|
---|
43 | */
|
---|
44 | FourBodyPotential_Improper();
|
---|
45 |
|
---|
46 | public:
|
---|
47 | FourBodyPotential_Improper(const ParticleTypes_t &_ParticleTypes);
|
---|
48 | FourBodyPotential_Improper(
|
---|
49 | const ParticleTypes_t &_ParticleTypes,
|
---|
50 | const double _spring_constant,
|
---|
51 | const double _equilibrium_distance);
|
---|
52 | virtual ~FourBodyPotential_Improper() {}
|
---|
53 |
|
---|
54 | private:
|
---|
55 | /** Function to obtain angle between planes from distances.
|
---|
56 | *
|
---|
57 | */
|
---|
58 | result_t function_theta(
|
---|
59 | const double &r_ij,
|
---|
60 | const double &r_ik,
|
---|
61 | const double &r_il,
|
---|
62 | const double &r_jk,
|
---|
63 | const double &r_jl,
|
---|
64 | const double &r_kl
|
---|
65 | ) const;
|
---|
66 |
|
---|
67 | /** Return the token name of this specific potential.
|
---|
68 | *
|
---|
69 | * We need to override the function in order to use a different static variable.
|
---|
70 | *
|
---|
71 | * \return token name of the potential
|
---|
72 | */
|
---|
73 | const std::string& getToken() const
|
---|
74 | { return improper_token; }
|
---|
75 |
|
---|
76 | private:
|
---|
77 | //!> static definitions of the parameter name for this potential
|
---|
78 | static const ParameterNames_t ParameterNames;
|
---|
79 |
|
---|
80 | //!> static token of this potential type
|
---|
81 | static const std::string improper_token;
|
---|
82 | };
|
---|
83 |
|
---|
84 | #endif /* FOURBODYPOTENTIAL_IMPROPER_HPP_ */
|
---|