forked from lijiext/lammps
git-svn-id: svn://svn.icms.temple.edu/lammps-ro/trunk@10130 f3b2605a-c512-4ea7-a41b-209d697bcdaa
This commit is contained in:
parent
1e4b3bcf87
commit
440d389779
|
@ -297,6 +297,7 @@ void PPPM::init()
|
||||||
error->warning(FLERR,"Reducing PPPM order b/c stencil extends "
|
error->warning(FLERR,"Reducing PPPM order b/c stencil extends "
|
||||||
"beyond nearest neighbor processor");
|
"beyond nearest neighbor processor");
|
||||||
|
|
||||||
|
if (stagger_flag && !differentiation_flag) compute_gf_denom();
|
||||||
set_grid_global();
|
set_grid_global();
|
||||||
set_grid_local();
|
set_grid_local();
|
||||||
if (overlap_allowed) break;
|
if (overlap_allowed) break;
|
||||||
|
@ -780,7 +781,7 @@ void PPPM::allocate()
|
||||||
|
|
||||||
// summation coeffs
|
// summation coeffs
|
||||||
|
|
||||||
memory->create(gf_b,order,"pppm:gf_b");
|
if (!stagger_flag) memory->create(gf_b,order,"pppm:gf_b");
|
||||||
memory->create2d_offset(rho1d,3,-order/2,order/2,"pppm:rho1d");
|
memory->create2d_offset(rho1d,3,-order/2,order/2,"pppm:rho1d");
|
||||||
memory->create2d_offset(drho1d,3,-order/2,order/2,"pppm:drho1d");
|
memory->create2d_offset(drho1d,3,-order/2,order/2,"pppm:drho1d");
|
||||||
memory->create2d_offset(rho_coeff,order,(1-order)/2,order/2,"pppm:rho_coeff");
|
memory->create2d_offset(rho_coeff,order,(1-order)/2,order/2,"pppm:rho_coeff");
|
||||||
|
@ -866,6 +867,7 @@ void PPPM::deallocate()
|
||||||
}
|
}
|
||||||
|
|
||||||
memory->destroy(gf_b);
|
memory->destroy(gf_b);
|
||||||
|
if (stagger_flag) gf_b = NULL;
|
||||||
memory->destroy2d_offset(rho1d,-order/2);
|
memory->destroy2d_offset(rho1d,-order/2);
|
||||||
memory->destroy2d_offset(drho1d,-order/2);
|
memory->destroy2d_offset(drho1d,-order/2);
|
||||||
memory->destroy2d_offset(rho_coeff,(1-order)/2);
|
memory->destroy2d_offset(rho_coeff,(1-order)/2);
|
||||||
|
@ -982,7 +984,7 @@ void PPPM::set_grid_global()
|
||||||
|
|
||||||
if (!gridflag) {
|
if (!gridflag) {
|
||||||
|
|
||||||
if (differentiation_flag == 1) {
|
if (differentiation_flag == 1 || stagger_flag) {
|
||||||
|
|
||||||
h = h_x = h_y = h_z = 4.0/g_ewald;
|
h = h_x = h_y = h_z = 4.0/g_ewald;
|
||||||
int count = 0;
|
int count = 0;
|
||||||
|
@ -1131,7 +1133,7 @@ double PPPM::compute_df_kspace()
|
||||||
double zprd_slab = zprd*slab_volfactor;
|
double zprd_slab = zprd*slab_volfactor;
|
||||||
bigint natoms = atom->natoms;
|
bigint natoms = atom->natoms;
|
||||||
double df_kspace = 0.0;
|
double df_kspace = 0.0;
|
||||||
if (differentiation_flag == 1) {
|
if (differentiation_flag == 1 || stagger_flag) {
|
||||||
double qopt = compute_qopt();
|
double qopt = compute_qopt();
|
||||||
df_kspace = sqrt(qopt/natoms)*q2/(xprd*yprd*zprd_slab);
|
df_kspace = sqrt(qopt/natoms)*q2/(xprd*yprd*zprd_slab);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1420,6 +1422,12 @@ void PPPM::set_grid_local()
|
||||||
nzlo_out = nlo + nlower;
|
nzlo_out = nlo + nlower;
|
||||||
nzhi_out = nhi + nupper;
|
nzhi_out = nhi + nupper;
|
||||||
|
|
||||||
|
if (stagger_flag) {
|
||||||
|
nxhi_out++;
|
||||||
|
nyhi_out++;
|
||||||
|
nzhi_out++;
|
||||||
|
}
|
||||||
|
|
||||||
// for slab PPPM, change the grid boundary for processors at +z end
|
// for slab PPPM, change the grid boundary for processors at +z end
|
||||||
// to include the empty volume between periodically repeating slabs
|
// to include the empty volume between periodically repeating slabs
|
||||||
// for slab PPPM, want charge data communicated from -z proc to +z proc,
|
// for slab PPPM, want charge data communicated from -z proc to +z proc,
|
||||||
|
|
|
@ -120,8 +120,8 @@ class PPPM : public KSpace {
|
||||||
int factorable(int);
|
int factorable(int);
|
||||||
double compute_df_kspace();
|
double compute_df_kspace();
|
||||||
double estimate_ik_error(double, double, bigint);
|
double estimate_ik_error(double, double, bigint);
|
||||||
double compute_qopt();
|
virtual double compute_qopt();
|
||||||
void compute_gf_denom();
|
virtual void compute_gf_denom();
|
||||||
virtual void compute_gf_ik();
|
virtual void compute_gf_ik();
|
||||||
virtual void compute_gf_ad();
|
virtual void compute_gf_ad();
|
||||||
void compute_sf_precoeff();
|
void compute_sf_precoeff();
|
||||||
|
|
|
@ -37,6 +37,7 @@ KSpace::KSpace(LAMMPS *lmp, int narg, char **arg) : Pointers(lmp)
|
||||||
ewaldflag = pppmflag = msmflag = dispersionflag = tip4pflag = dipoleflag = 0;
|
ewaldflag = pppmflag = msmflag = dispersionflag = tip4pflag = dipoleflag = 0;
|
||||||
compute_flag = 1;
|
compute_flag = 1;
|
||||||
group_group_enable = 0;
|
group_group_enable = 0;
|
||||||
|
stagger_flag = 0;
|
||||||
|
|
||||||
order = 5;
|
order = 5;
|
||||||
gridflag = 0;
|
gridflag = 0;
|
||||||
|
|
|
@ -69,6 +69,8 @@ class KSpace : protected Pointers {
|
||||||
int compute_flag; // 0 if skip compute()
|
int compute_flag; // 0 if skip compute()
|
||||||
int fftbench; // 0 if skip FFT timing
|
int fftbench; // 0 if skip FFT timing
|
||||||
|
|
||||||
|
int stagger_flag; // 1 if using staggered PPPM grids
|
||||||
|
|
||||||
KSpace(class LAMMPS *, int, char **);
|
KSpace(class LAMMPS *, int, char **);
|
||||||
virtual ~KSpace();
|
virtual ~KSpace();
|
||||||
void triclinic_check();
|
void triclinic_check();
|
||||||
|
|
Loading…
Reference in New Issue