use ev_init for kspace

This commit is contained in:
Sebastian Hütter 2019-03-13 17:55:30 +01:00
parent ff2d8e55c9
commit 985fc86aa3
17 changed files with 20 additions and 49 deletions

View File

@ -199,9 +199,7 @@ void PPPMGPU::compute(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
// If need per-atom energies/virials, allocate per-atom arrays here
// so that particle map on host can be done concurrently with GPU calculations

View File

@ -615,8 +615,7 @@ void PPPMKokkos<DeviceType>::compute(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag,0);
else evflag = evflag_atom = eflag_global = vflag_global =
ev_init(eflag,vflag,0);
eflag_atom = vflag_atom = 0;
// reallocate per-atom arrays if necessary

View File

@ -365,9 +365,7 @@ void Ewald::compute(int eflag, int vflag)
// set energy/virial flags
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
// if atom count has changed, update qsum and qsqsum

View File

@ -688,8 +688,7 @@ void EwaldDisp::compute(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = eflag_global = vflag_global = eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (!peratom_allocate_flag && (eflag_atom || vflag_atom)) {
allocate_peratom();

View File

@ -454,9 +454,7 @@ void MSM::compute(int eflag, int vflag)
// set energy/virial flags
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = eflag_either = vflag_either = 0;
ev_init(eflag,vflag);
if (scalar_pressure_flag && vflag_either) {
if (vflag_atom)

View File

@ -90,9 +90,7 @@ void MSMCG::compute(int eflag, int vflag)
// set energy/virial flags
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = eflag_either = vflag_either = 0;
ev_init(eflag,vflag);
// invoke allocate_peratom() if needed for first time

View File

@ -630,9 +630,7 @@ void PPPM::compute(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (evflag_atom && !peratom_allocate_flag) {
allocate_peratom();

View File

@ -88,9 +88,7 @@ void PPPMCG::compute(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (evflag_atom && !peratom_allocate_flag) {
allocate_peratom();

View File

@ -928,9 +928,7 @@ void PPPMDisp::compute(int eflag, int vflag)
int i;
// convert atoms from box to lamda coords
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (evflag_atom && !peratom_allocate_flag) {
allocate_peratom();

View File

@ -124,9 +124,7 @@ void PPPMStagger::compute(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (evflag_atom && !peratom_allocate_flag) {
allocate_peratom();

View File

@ -174,9 +174,7 @@ void PPPMDispIntel::compute(int eflag, int vflag)
int i;
// convert atoms from box to lamda coords
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (evflag_atom && !peratom_allocate_flag) {
allocate_peratom();

View File

@ -161,9 +161,7 @@ void PPPMIntel::compute_first(int eflag, int vflag)
// set energy/virial flags
// invoke allocate_peratom() if needed for first time
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
if (evflag_atom && !peratom_allocate_flag) {
allocate_peratom();

View File

@ -61,9 +61,7 @@ void EwaldOMP::compute(int eflag, int vflag)
{
// set energy/virial flags
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
// extend size of per-atom arrays if necessary

View File

@ -90,9 +90,7 @@ void MSMCGOMP::compute(int eflag, int vflag)
// set energy/virial flags
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = eflag_either = vflag_either = 0;
ev_init(eflag,vflag);
// invoke allocate_peratom() if needed for first time

View File

@ -197,12 +197,7 @@ void Scafacos::compute(int eflag, int vflag)
fcs_set_redistribute((FCS)fcs,0);
}
if (eflag || vflag) ev_setup(eflag,vflag);
else
{
eflag_atom = 0;
vflag_global = 0;
}
ev_init(eflag,vflag);
// grow xpbc, epot, efield if necessary

View File

@ -168,9 +168,7 @@ void KSpace::triclinic_check()
void KSpace::compute_dummy(int eflag, int vflag)
{
if (eflag || vflag) ev_setup(eflag,vflag);
else evflag = evflag_atom = eflag_global = vflag_global =
eflag_atom = vflag_atom = 0;
ev_init(eflag,vflag);
}
/* ----------------------------------------------------------------------

View File

@ -195,6 +195,10 @@ class KSpace : protected Pointers {
void pair_check();
void ev_setup(int, int, int alloc = 1);
void ev_init(int eflag, int vflag, int alloc = 1) {
if (eflag||vflag) ev_setup(eflag, vflag, alloc);
else evflag = eflag_either = eflag_global = eflag_atom = vflag_either = vflag_global = vflag_atom = 0;
}
double estimate_table_accuracy(double, double);
};