#ifdef KSPACE_CLASS
KSpaceStyle(pppm/disp/tip4p/omp,PPPMDispTIP4POMP)
#else
#ifndef LMP_PPPM_DISP_TIP4P_OMP_H
#define LMP_PPPM_DISP_TIP4P_OMP_H
#include "pppm_disp_tip4p.h"
#include "thr_omp.h"
namespace LAMMPS_NS {
class PPPMDispTIP4POMP : public PPPMDispTIP4P, public ThrOMP {
public:
PPPMDispTIP4POMP(class LAMMPS *);
virtual ~PPPMDispTIP4POMP ();
protected:
virtual void allocate();
virtual void compute_gf();
virtual void compute_gf_6();
virtual void compute(int,int);
virtual void particle_map(double, double, double,
double, int **, int, int,
int, int, int, int, int, int);
virtual void particle_map_c(double, double, double,
double, int **, int, int,
int, int, int, int, int, int);
virtual void make_rho_c(); virtual void make_rho_g();
virtual void make_rho_a();
virtual void fieldforce_c_ik();
virtual void fieldforce_c_ad();
virtual void fieldforce_g_ik();
virtual void fieldforce_g_ad();
virtual void fieldforce_g_peratom();
virtual void fieldforce_a_ik();
virtual void fieldforce_a_ad();
virtual void fieldforce_a_peratom();
private:
void compute_rho1d_thr(FFT_SCALAR * const * const, const FFT_SCALAR &,
const FFT_SCALAR &, const FFT_SCALAR &,
const int, FFT_SCALAR * const * const);
void compute_drho1d_thr(FFT_SCALAR * const * const, const FFT_SCALAR &,
const FFT_SCALAR &, const FFT_SCALAR &,
const int, FFT_SCALAR * const * const);
virtual void find_M_thr(int, int &, int &, dbl3_t &);
};
}
#endif
#endif