OpenMD
3.2
Molecular Dynamics in the Open
Toggle main menu visibility
Loading...
Searching...
No Matches
Bond.hpp
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2004-present, The University of Notre Dame. All rights
3
* reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
*
8
* 1. Redistributions of source code must retain the above copyright notice,
9
* this list of conditions and the following disclaimer.
10
*
11
* 2. Redistributions in binary form must reproduce the above copyright notice,
12
* this list of conditions and the following disclaimer in the documentation
13
* and/or other materials provided with the distribution.
14
*
15
* 3. Neither the name of the copyright holder nor the names of its
16
* contributors may be used to endorse or promote products derived from
17
* this software without specific prior written permission.
18
*
19
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29
* POSSIBILITY OF SUCH DAMAGE.
30
*
31
* SUPPORT OPEN SCIENCE! If you use OpenMD or its source code in your
32
* research, please cite the following paper when you publish your work:
33
*
34
* [1] Drisko et al., J. Open Source Softw. 9, 7004 (2024).
35
*
36
* Good starting points for code and simulation methodology are:
37
*
38
* [2] Meineke, et al., J. Comp. Chem. 26, 252-271 (2005).
39
* [3] Fennell & Gezelter, J. Chem. Phys. 124, 234104 (2006).
40
* [4] Sun, Lin & Gezelter, J. Chem. Phys. 128, 234107 (2008).
41
* [5] Vardeman, Stocker & Gezelter, J. Chem. Theory Comput. 7, 834 (2011).
42
* [6] Kuang & Gezelter, Mol. Phys., 110, 691-701 (2012).
43
* [7] Lamichhane, Gezelter & Newman, J. Chem. Phys. 141, 134109 (2014).
44
* [8] Bhattarai, Newman & Gezelter, Phys. Rev. B 99, 094106 (2019).
45
* [9] Drisko & Gezelter, J. Chem. Theory Comput. 20, 4986-4997 (2024).
46
*/
47
48
/**
49
* @file Bond.hpp
50
* @author tlin
51
* @date 11/01/2004
52
* @version 1.0
53
*/
54
55
#ifndef PRIMITIVES_BOND_HPP
56
#define PRIMITIVES_BOND_HPP
57
58
#include "
primitives/Atom.hpp
"
59
#include "primitives/ShortRangeInteraction.hpp"
60
#include "
types/BondType.hpp
"
61
62
namespace
OpenMD
{
63
64
class
Bond :
public
ShortRangeInteraction {
65
public
:
66
using
ShortRangeInteraction::getPrevValue
;
67
using
ShortRangeInteraction::getValue
;
68
Bond(
Atom
* atom1,
Atom
* atom2,
BondType
* bt) :
69
ShortRangeInteraction(), bondType_(bt) {
70
atoms_.resize(2);
71
atoms_[0] = atom1;
72
atoms_[1] = atom2;
73
}
74
virtual
~Bond() {}
75
void
calcForce(
bool
doParticlePot) {
76
RealType len;
77
RealType dvdr;
78
Vector3d r12;
79
Vector3d force;
80
81
r12 = atoms_[1]->getPos() - atoms_[0]->getPos();
82
snapshotMan_->getCurrentSnapshot()->wrapVector(r12);
83
len = r12.
length
();
84
bondType_->calcForce(len, potential_, dvdr);
85
86
force = r12 * (-dvdr / len);
87
88
atoms_[0]->addFrc(-force);
89
atoms_[1]->addFrc(force);
90
if
(doParticlePot) {
91
atoms_[0]->addParticlePot(potential_);
92
atoms_[1]->addParticlePot(potential_);
93
}
94
}
95
96
RealType
getValue
(
int
snap) {
97
Vector3d r12 = atoms_[1]->getPos(snap) - atoms_[0]->getPos(snap);
98
snapshotMan_->getSnapshot(snap)->wrapVector(r12);
99
return
r12.
length
();
100
}
101
102
RealType getPotential() {
return
potential_; }
103
104
Atom* getAtomA() {
return
atoms_[0]; }
105
106
Atom* getAtomB() {
return
atoms_[1]; }
107
108
BondType* getBondType() {
return
bondType_; }
109
110
virtual
std::string
getName
() {
return
name_; }
111
/** Sets the name of this bond for selections */
112
virtual
void
setName
(
const
std::string& name) { name_ = name; }
113
114
void
accept
(
BaseVisitor
* v) { v->visit(
this
); }
115
116
private
:
117
RealType potential_ {};
118
BondType* bondType_;
/**< bond type */
119
std::string name_;
120
};
121
}
// namespace OpenMD
122
123
#endif
// PRIMITIVES_BOND_HPP
Atom.hpp
BondType.hpp
OpenMD::Atom
Definition
Atom.hpp:62
OpenMD::BaseVisitor
Definition
BaseVisitor.hpp:66
OpenMD::Bond::getName
virtual std::string getName()
Returns the name of this ShortRangeInteraction.
Definition
Bond.hpp:110
OpenMD::Bond::accept
void accept(BaseVisitor *v)
Definition
Bond.hpp:114
OpenMD::Bond::setName
virtual void setName(const std::string &name)
Sets the name of this bond for selections.
Definition
Bond.hpp:112
OpenMD::Bond::getValue
RealType getValue(int snap)
Returns the value of this ShortRangeInteraction in specified snapshot.
Definition
Bond.hpp:96
OpenMD::BondType
BondType class is responsible for calculating the force and energy of the bond.
Definition
BondType.hpp:67
OpenMD::ShortRangeInteraction::getValue
virtual RealType getValue()
Returns the current value of this ShortRangeInteraction.
Definition
ShortRangeInteraction.cpp:59
OpenMD::ShortRangeInteraction::getPrevValue
virtual RealType getPrevValue()
Returns the previous value of this ShortRangeInteraction.
Definition
ShortRangeInteraction.cpp:64
OpenMD::Vector::length
Real length() const
Returns the length of this vector.
Definition
Vector.hpp:397
OpenMD
This basic Periodic Table class was originally taken from the data.cpp file in OpenBabel.
Definition
ActionCorrFunc.cpp:63
primitives
Bond.hpp
Generated on
for OpenMD by
1.17.0