OpenMD 3.0
Molecular Dynamics in the Open
Loading...
Searching...
No Matches
AtomType.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 TYPES_ATOMTYPE_HPP
46
47#define TYPES_ATOMTYPE_HPP
48
49#include <config.h>
50
51#include <set>
52#include <string>
53
54#include "utils/PropertyMap.hpp"
55
56using namespace std;
57
58namespace OpenMD {
59 /**
60 * @class AtomType
61 * AtomType is what OpenMD looks to for unchanging data about an atom.
62 * Things that belong to AtomType are universal properties (i.e. does
63 * this atom have a Charge? What is it's mass_?) Dynamic properties of
64 * an atom are not intended to be properties of an atom type
65 */
66 class AtomType {
67 public:
68 AtomType();
69
70 virtual ~AtomType() {};
71
72 virtual void useBase(AtomType* base);
73 virtual void copyAllData(AtomType* orig);
74 void setMass(RealType m);
75 RealType getMass();
76 void setIdent(int id);
77 int getIdent();
78 void setName(const string& name);
79 string getName();
80 std::vector<AtomType*> allYourBase();
81 std::vector<AtomType*> allYourZIG() { return everyZIG; }
82 void addZig(AtomType* at) { everyZIG.push_back(at); }
83
84 // below functions are just forward functions
85 /**
86 * Adds property into property map
87 * @param genData GenericData to be added into PropertyMap
88 */
89 void addProperty(std::shared_ptr<GenericData> genData);
90
91 /**
92 * Removes property from PropertyMap by name
93 * @param propName the name of property to be removed
94 */
95 void removeProperty(const string& propName);
96
97 /**
98 * Returns all names of properties
99 * @return all names of properties
100 */
101 std::vector<string> getPropertyNames();
102
103 /**
104 * Returns all of the properties in PropertyMap
105 * @return all of the properties in PropertyMap
106 */
107 std::vector<std::shared_ptr<GenericData>> getProperties();
108
109 /**
110 * Checks if property is in this PropertyMap
111 * @param propName name of property
112 * @return boolean
113 */
114 bool hasProperty(const string& propName);
115
116 /**
117 * Returns property
118 * @param propName name of property
119 * @return a pointer point to property with propName. If no
120 * property named propName exists, return NULL
121 */
122 std::shared_ptr<GenericData> getPropertyByName(const string& propName);
123
124 bool isLennardJones();
125 bool isElectrostatic();
126 bool isEAM();
127 bool isCharge();
128 bool isFixedCharge();
129 bool isDirectional();
130 bool isDipole();
131 bool isQuadrupole();
132 bool isMultipole();
133 bool isGayBerne();
134 bool isSticky();
135 bool isStickyPower();
136 bool isShape();
137 bool isSC();
138 bool isMetal();
139 bool isFluctuatingCharge();
140
141 protected:
142 int ident_;
143 RealType mass_;
144 string name_;
145 bool hasBase_; // All your base are belong to us
146 AtomType* base_;
147 vector<AtomType*> everyZIG; // list of atom types which use us as a base
148 map<string, bool> myResponsibilities_;
149 map<string, RealType> myValues_;
150
151 private:
152 // prevent copy construction and copy assignment, since property
153 // map contains pointers which can not be copied and managed
154 // safely, except make the generic data at PropertyMap as copy on
155 // write shared pointer
156 AtomType(const AtomType&);
157 AtomType& operator=(const AtomType& atomType);
158 PropertyMap properties_;
159 };
160
162 public:
163 bool operator()(AtomType* lhs, AtomType* rhs) const {
164 return lhs->getIdent() < rhs->getIdent();
165 }
166 };
167
168 using AtomTypeSet = std::set<AtomType*, AtomTypeCompare>;
169} // namespace OpenMD
170
171#endif
AtomType is what OpenMD looks to for unchanging data about an atom.
Definition AtomType.hpp:66
std::shared_ptr< GenericData > getPropertyByName(const string &propName)
Returns property.
Definition AtomType.cpp:134
std::vector< std::shared_ptr< GenericData > > getProperties()
Returns all of the properties in PropertyMap.
Definition AtomType.cpp:123
void removeProperty(const string &propName)
Removes property from PropertyMap by name.
Definition AtomType.cpp:114
bool hasProperty(const string &propName)
Checks if property is in this PropertyMap.
Definition AtomType.cpp:127
std::vector< string > getPropertyNames()
Returns all names of properties.
Definition AtomType.cpp:119
void addProperty(std::shared_ptr< GenericData > genData)
Adds property into property map.
Definition AtomType.cpp:109
PropertyMap class maintains a list of GenericData.
This basic Periodic Table class was originally taken from the data.cpp file in OpenBabel.