OpenMD 3.1
Molecular Dynamics in the Open
Loading...
Searching...
No Matches
RNEMDParameters.cpp
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#include "rnemd/RNEMDParameters.hpp"
46
47#include <cstdlib>
48#include <cstring>
49#include <iostream>
50
51namespace OpenMD::RNEMD {
52
53 RNEMDParameters::RNEMDParameters() {
54 DefineOptionalParameterWithDefaultValue(UseRNEMD, "useRNEMD", false);
55 DefineOptionalParameterWithDefaultValue(ObjectSelection, "objectSelection",
56 "select all");
57
58 DefineOptionalParameterWithDefaultValue(Method, "method", "VSS");
59 DefineOptionalParameter(FluxType, "fluxType");
60
61 DefineOptionalParameterWithDefaultValue(ExchangeTime, "exchangeTime",
62 100.0);
63 DefineOptionalParameter(KineticFlux, "kineticFlux");
64 DefineOptionalParameter(ParticleFlux, "particleFlux");
65 DefineOptionalParameter(MomentumFlux, "momentumFlux");
66 DefineOptionalParameter(MomentumFluxVector, "momentumFluxVector");
67 DefineOptionalParameter(AngularMomentumFlux, "angularMomentumFlux");
68 DefineOptionalParameter(AngularMomentumFluxVector,
69 "angularMomentumFluxVector");
70 DefineOptionalParameter(SlabWidth, "slabWidth");
71 DefineOptionalParameter(SlabACenter, "slabAcenter");
72 DefineOptionalParameter(SlabBCenter, "slabBcenter");
73 DefineOptionalParameter(SphereARadius, "sphereAradius");
74 DefineOptionalParameter(SphereBRadius, "sphereBradius");
75 DefineOptionalParameter(SelectionA, "selectionA");
76 DefineOptionalParameter(SelectionB, "selectionB");
77 DefineOptionalParameter(CoordinateOrigin, "coordinateOrigin");
78 DefineOptionalParameter(OutputFileName, "outputFileName");
79 DefineOptionalParameterWithDefaultValue(OutputBins, "outputBins", 20);
80 DefineOptionalParameterWithDefaultValue(OutputBinWidth, "outputBinWidth",
81 2.0);
82 DefineOptionalParameter(OutputSelection, "outputSelection");
83 DefineOptionalParameter(OutputFields, "outputFields");
84 DefineOptionalParameter(DividingArea, "dividingArea");
85 DefineOptionalParameterWithDefaultValue(PrivilegedAxis, "privilegedAxis",
86 "z");
87 DefineOptionalParameterWithDefaultValue(SPFScalingPower, "spfScalingPower",
88 3);
89 DefineOptionalParameterWithDefaultValue(SPFUniformKineticScaling,
90 "spfUniformKineticScaling", false);
91 }
92
93 void RNEMDParameters::validate() {
94 CheckParameter(ExchangeTime, isPositive());
95 CheckParameter(OutputBins, isPositive());
96 CheckParameter(OutputBinWidth, isPositive());
97 CheckParameter(Method,
98 isEqualIgnoreCase("Swap") || isEqualIgnoreCase("NIVS") ||
99 isEqualIgnoreCase("VSS") || isEqualIgnoreCase("SPF"));
100 CheckParameter(
101 FluxType,
102 isEqualIgnoreCase("KE") || isEqualIgnoreCase("Px") ||
103 isEqualIgnoreCase("Py") || isEqualIgnoreCase("Pz") ||
104 isEqualIgnoreCase("Lx") || isEqualIgnoreCase("Ly") ||
105 isEqualIgnoreCase("Lz") || isEqualIgnoreCase("Pvector") ||
106 isEqualIgnoreCase("Lvector") || isEqualIgnoreCase("KE+Px") ||
107 isEqualIgnoreCase("KE+Py") || isEqualIgnoreCase("KE+Lx") ||
108 isEqualIgnoreCase("KE+Ly") || isEqualIgnoreCase("KE+Lz") ||
109 isEqualIgnoreCase("KE+Pvector") ||
110 isEqualIgnoreCase("KE+Lvector") || isEqualIgnoreCase("Particle") ||
111 isEqualIgnoreCase("Particle+KE"));
112 CheckParameter(PrivilegedAxis, isEqualIgnoreCase("x") ||
113 isEqualIgnoreCase("y") ||
114 isEqualIgnoreCase("z"));
115 }
116
117 bool RNEMDParameters::requiresElectricField() {
118 static bool wasParsed {false};
119
120 if (!wasParsed) {
121 StringTokenizer tokenizer(getOutputFields(), " ,;|\t\n\r");
122
123 while (tokenizer.hasMoreTokens()) {
124 std::string token(tokenizer.nextToken());
125 toUpper(token);
126
127 if (token == "ELECTRICFIELD" || token == "ELECTROSTATICPOTENTIAL") {
128 calculateElectricField_ = true;
129 break;
130 }
131 }
132
133 wasParsed = true;
134 }
135
136 return calculateElectricField_;
137 }
138} // namespace OpenMD::RNEMD