Files
lammps/src/fix_dummy.cpp
2022-10-24 11:08:26 -04:00

75 lines
2.6 KiB
C++

/* ----------------------------------------------------------------------
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
https://www.lammps.org/, Sandia National Laboratories
LAMMPS development team: developers@lammps.org
Copyright (2003) Sandia Corporation. Under the terms of Contract
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
certain rights in this software. This software is distributed under
the GNU General Public License.
See the README file in the top-level LAMMPS directory.
------------------------------------------------------------------------- */
#include "fix_dummy.h"
#include "error.h"
#include <cstring>
using namespace LAMMPS_NS;
using namespace FixConst;
/* ---------------------------------------------------------------------- */
FixDummy::FixDummy(LAMMPS *lmp, int narg, char **arg) : Fix(lmp, narg, arg)
{
// process optional args
// customize here and in setmask() by adding a new keyword from fix.h
// only necessary if both of these are true:
// (a) the real fix you are placeholding for defines the method
// (b) the real fix will be defined so late in run initialization
// that the dummy fix will have already been processed by Modify::init()
// so its index needs to be added to lists of fixes invoked during a run
initial_integrate_flag = final_integrate_flag = 0;
pre_exchange_flag = pre_neighbor_flag = 0;
pre_force_flag = post_force_flag = 0;
end_of_step_flag = 0;
int iarg = 3;
while (iarg < narg) {
if (strcmp(arg[iarg], "initial_integrate") == 0)
initial_integrate_flag = 1;
else if (strcmp(arg[iarg], "final_integrate") == 0)
final_integrate_flag = 1;
else if (strcmp(arg[iarg], "pre_exchange") == 0)
pre_exchange_flag = 1;
else if (strcmp(arg[iarg], "pre_neighbor") == 0)
pre_neighbor_flag = 1;
else if (strcmp(arg[iarg], "pre_force") == 0)
pre_force_flag = 1;
else if (strcmp(arg[iarg], "post_force") == 0)
post_force_flag = 1;
else if (strcmp(arg[iarg], "end_of_step") == 0)
end_of_step_flag = 1;
else
error->all(FLERR, "Illegal fix DUMMY command");
iarg++;
}
}
/* ---------------------------------------------------------------------- */
int FixDummy::setmask()
{
int mask = 0;
if (initial_integrate_flag) mask |= INITIAL_INTEGRATE;
if (final_integrate_flag) mask |= FINAL_INTEGRATE;
if (pre_exchange_flag) mask |= PRE_EXCHANGE;
if (pre_neighbor_flag) mask |= PRE_NEIGHBOR;
if (pre_force_flag) mask |= PRE_FORCE;
if (post_force_flag) mask |= POST_FORCE;
if (end_of_step_flag) mask |= END_OF_STEP;
return mask;
}