OpenMD 3.1
Molecular Dynamics in the Open
Loading...
Searching...
No Matches
ReplacementVisitor.hpp
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 appropriate papers when you publish your
33 * work. Good starting points are:
34 *
35 * [1] Meineke, et al., J. Comp. Chem. 26, 252-271 (2005).
36 * [2] Fennell & Gezelter, J. Chem. Phys. 124, 234104 (2006).
37 * [3] Sun, Lin & Gezelter, J. Chem. Phys. 128, 234107 (2008).
38 * [4] Vardeman, Stocker & Gezelter, J. Chem. Theory Comput. 7, 834 (2011).
39 * [5] Kuang & Gezelter, Mol. Phys., 110, 691-701 (2012).
40 * [6] Lamichhane, Gezelter & Newman, J. Chem. Phys. 141, 134109 (2014).
41 * [7] Lamichhane, Newman & Gezelter, J. Chem. Phys. 141, 134110 (2014).
42 * [8] Bhattarai, Newman & Gezelter, Phys. Rev. B 99, 094106 (2019).
43 */
44
45#ifndef VISITORS_REPLACEMENTVISITOR_HPP
46#define VISITORS_REPLACEMENTVISITOR_HPP
47
48#include <memory>
49#include <set>
50
51#include "visitors/AtomVisitor.hpp"
52
53namespace OpenMD {
54
55 /**
56 * @class ReplacementVisitor
57 *
58 * Replaces an atomic object with a collection atomic sites. These
59 * sites are specified with reference location to the object, as well as
60 * a name.
61 */
63 public:
64 using BaseVisitor::visit;
66 visitorName = "ReplacementVisitor";
67 sites_ = std::make_shared<AtomData>();
68 }
69
70 void visit(Atom*) {}
71 void visit(DirectionalAtom* datom);
72 void visit(RigidBody*) {}
73
74 const std::string toString();
75
76 void addReplacedAtomName(const std::string& repName);
77 void addSite(const std::string& name, const Vector3d& refPos);
78 void addSite(const std::string& name, const Vector3d& refPos,
79 const Vector3d& refVec);
80
81 private:
82 inline bool isReplacedAtom(const std::string& atomType);
83 std::set<std::string> myTypes_;
84 std::shared_ptr<AtomData> sites_;
85 };
86
88 public:
89 using BaseVisitor::visit;
91 visitorName = "SSDAtomVisitor";
92
93 /// these are the atom names we can replace with a fixed structure
94 addReplacedAtomName("SSD");
95 addReplacedAtomName("SSD_E");
96 addReplacedAtomName("SSD_RF");
97 addReplacedAtomName("SSD1");
98 addReplacedAtomName("SSDQ");
99 addReplacedAtomName("SSDQO");
100 addReplacedAtomName("TAP");
101 addReplacedAtomName("TRED");
102
103 // this is the reference structure we'll use for the replacement:
104 addSite("H", Vector3d(0.0, -0.75695, 0.5206));
105 addSite("H", Vector3d(0.0, 0.75695, 0.5206));
106 addSite("O", Vector3d(0.0, 0.0, -0.0654));
107 addSite("X", Vector3d(0.0, 0.0, 0.0), Vector3d(0, 0, 1));
108 }
109 };
110
112 public:
113 using BaseVisitor::visit;
115 visitorName = "GBtailVisitor";
116
117 /// these are the atom names we can replace with a fixed structure
118 addReplacedAtomName("GBtail");
119
120 // this is the reference structure we'll use for the replacement:
121 addSite("C", Vector3d(0.0, 0.0, 9.0));
122 addSite("C", Vector3d(0.0, 0.0, 0.0));
123 addSite("C", Vector3d(0.0, 0.0, -9.0));
124 }
125 };
126
128 public:
129 using BaseVisitor::visit;
131 visitorName = "GBheadVisitor";
132
133 /// these are the atom names we can replace with a fixed structure
134 addReplacedAtomName("GBhead");
135
136 // this is the reference structure we'll use for the replacement:
137 addSite("N", Vector3d(0.0, 0.0, 3.5));
138 addSite("C", Vector3d(0.0, 0.0, 0.0));
139 addSite("P", Vector3d(0.0, 0.0, -3.5));
140 }
141 };
142} // namespace OpenMD
143
144#endif
Replaces an atomic object with a collection atomic sites.
One of the heavy-weight classes of OpenMD, SimInfo maintains objects and variables relating to the cu...
Definition SimInfo.hpp:93
This basic Periodic Table class was originally taken from the data.cpp file in OpenBabel.