2012-02-17 00:13:15 +08:00
|
|
|
/* -*- c++ -*- ----------------------------------------------------------
|
2006-09-28 03:51:33 +08:00
|
|
|
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
|
2007-01-30 08:22:05 +08:00
|
|
|
http://lammps.sandia.gov, Sandia National Laboratories
|
|
|
|
Steve Plimpton, sjplimp@sandia.gov
|
2006-09-28 03:51:33 +08:00
|
|
|
|
|
|
|
Copyright (2003) Sandia Corporation. Under the terms of Contract
|
|
|
|
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
|
2012-06-07 06:47:51 +08:00
|
|
|
certain rights in this software. This software is distributed under
|
2006-09-28 03:51:33 +08:00
|
|
|
the GNU General Public License.
|
|
|
|
|
|
|
|
See the README file in the top-level LAMMPS directory.
|
|
|
|
------------------------------------------------------------------------- */
|
|
|
|
|
2010-01-12 09:37:48 +08:00
|
|
|
#ifndef LMP_PAIR_H
|
|
|
|
#define LMP_PAIR_H
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
#include "pointers.h"
|
2015-02-05 06:14:27 +08:00
|
|
|
#include "accelerator_kokkos.h"
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
namespace LAMMPS_NS {
|
|
|
|
|
|
|
|
class Pair : protected Pointers {
|
2011-12-01 23:47:17 +08:00
|
|
|
friend class AngleSDK;
|
|
|
|
friend class AngleSDKOMP;
|
2007-12-01 05:54:30 +08:00
|
|
|
friend class BondQuartic;
|
2011-10-25 04:28:02 +08:00
|
|
|
friend class BondQuarticOMP;
|
2007-12-01 05:54:30 +08:00
|
|
|
friend class DihedralCharmm;
|
2011-10-07 01:55:48 +08:00
|
|
|
friend class DihedralCharmmOMP;
|
2010-11-23 08:42:11 +08:00
|
|
|
friend class FixGPU;
|
2012-02-17 00:13:15 +08:00
|
|
|
friend class FixOMP;
|
2011-08-26 03:21:40 +08:00
|
|
|
friend class ThrOMP;
|
2007-12-01 05:54:30 +08:00
|
|
|
|
2006-09-28 03:51:33 +08:00
|
|
|
public:
|
2015-01-20 07:38:26 +08:00
|
|
|
static int instance_total; // # of Pair classes ever instantiated
|
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
double eng_vdwl,eng_coul; // accumulated energies
|
|
|
|
double virial[6]; // accumulated virial
|
2007-12-01 05:54:30 +08:00
|
|
|
double *eatom,**vatom; // accumulated per-atom energy/virial
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
double cutforce; // max cutoff for all atom pairs
|
2011-03-18 23:09:03 +08:00
|
|
|
double **cutsq; // cutoff sq for each atom pair
|
2007-01-30 08:22:05 +08:00
|
|
|
int **setflag; // 0/1 = whether each i,j has been set
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
int comm_forward; // size of forward communication (0 if none)
|
|
|
|
int comm_reverse; // size of reverse communication (0 if none)
|
2012-01-31 06:21:26 +08:00
|
|
|
int comm_reverse_off; // size of reverse comm even if newton off
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
int single_enable; // 1 if single() routine exists
|
2011-10-25 23:19:06 +08:00
|
|
|
int restartinfo; // 1 if pair style writes restart info
|
2007-01-30 08:22:05 +08:00
|
|
|
int respa_enable; // 1 if inner/middle/outer rRESPA routines
|
|
|
|
int one_coeff; // 1 if allows only one coeff * * call
|
2013-06-28 04:20:27 +08:00
|
|
|
int manybody_flag; // 1 if a manybody potential
|
2011-06-08 02:06:14 +08:00
|
|
|
int no_virial_fdotr_compute; // 1 if does not invoke virial_fdotr_compute()
|
2013-04-04 00:52:29 +08:00
|
|
|
int writedata; // 1 if writes coeffs to data file
|
2011-03-18 23:09:03 +08:00
|
|
|
int ghostneigh; // 1 if pair style needs neighbors of ghosts
|
|
|
|
double **cutghost; // cutoff for each ghost pair
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2012-10-03 04:11:58 +08:00
|
|
|
int ewaldflag; // 1 if compatible with Ewald solver
|
|
|
|
int pppmflag; // 1 if compatible with PPPM solver
|
|
|
|
int msmflag; // 1 if compatible with MSM solver
|
|
|
|
int dispersionflag; // 1 if compatible with LJ/dispersion solver
|
|
|
|
int tip4pflag; // 1 if compatible with TIP4P solver
|
2013-06-06 22:55:08 +08:00
|
|
|
int dipoleflag; // 1 if compatible with dipole solver
|
2014-06-15 03:34:09 +08:00
|
|
|
int reinitflag; // 1 if compatible with fix adapt and alike
|
2012-10-03 04:11:58 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
int tail_flag; // pair_modify flag for LJ tail correction
|
|
|
|
double etail,ptail; // energy/pressure tail corrections
|
|
|
|
double etail_ij,ptail_ij;
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2012-01-07 04:45:50 +08:00
|
|
|
int evflag; // energy,virial settings
|
|
|
|
int eflag_either,eflag_global,eflag_atom;
|
|
|
|
int vflag_either,vflag_global,vflag_atom;
|
2012-07-25 23:15:41 +08:00
|
|
|
|
2012-07-02 22:28:16 +08:00
|
|
|
int ncoultablebits; // size of Coulomb table, accessed by KSpace
|
2013-03-07 01:17:22 +08:00
|
|
|
int ndisptablebits; // size of dispersion table
|
2012-10-18 07:28:42 +08:00
|
|
|
double tabinnersq;
|
2013-03-07 01:17:22 +08:00
|
|
|
double tabinnerdispsq;
|
2012-10-18 07:28:42 +08:00
|
|
|
double *rtable,*drtable,*ftable,*dftable,*ctable,*dctable;
|
|
|
|
double *etable,*detable,*ptable,*dptable,*vtable,*dvtable;
|
2013-03-07 01:17:22 +08:00
|
|
|
double *rdisptable, *drdisptable, *fdisptable, *dfdisptable;
|
|
|
|
double *edisptable, *dedisptable;
|
2012-10-18 07:28:42 +08:00
|
|
|
int ncoulshiftbits,ncoulmask;
|
2013-03-07 01:17:22 +08:00
|
|
|
int ndispshiftbits, ndispmask;
|
2012-01-07 04:45:50 +08:00
|
|
|
|
2010-10-19 01:00:05 +08:00
|
|
|
int nextra; // # of extra quantities pair style calculates
|
|
|
|
double *pvector; // vector of extra pair quantities
|
|
|
|
|
2011-12-01 08:19:01 +08:00
|
|
|
int single_extra; // number of extra single values calculated
|
|
|
|
double *svector; // vector of extra single quantities
|
2012-06-07 06:47:51 +08:00
|
|
|
|
2007-10-04 00:22:30 +08:00
|
|
|
class NeighList *list; // standard neighbor list used by most pairs
|
|
|
|
class NeighList *listhalf; // half list used by some pairs
|
|
|
|
class NeighList *listfull; // full list used by some pairs
|
2009-01-06 06:26:08 +08:00
|
|
|
class NeighList *listgranhistory; // granular history list used by some pairs
|
2007-10-04 00:22:30 +08:00
|
|
|
class NeighList *listinner; // rRESPA lists used by some pairs
|
|
|
|
class NeighList *listmiddle;
|
|
|
|
class NeighList *listouter;
|
|
|
|
|
2012-08-28 22:21:55 +08:00
|
|
|
unsigned int datamask;
|
|
|
|
unsigned int datamask_ext;
|
|
|
|
|
2012-04-13 06:32:17 +08:00
|
|
|
int compute_flag; // 0 if skip compute()
|
|
|
|
|
2014-03-13 00:37:16 +08:00
|
|
|
// KOKKOS host/device flag and data masks
|
|
|
|
|
|
|
|
ExecutionSpace execution_space;
|
|
|
|
unsigned int datamask_read,datamask_modify;
|
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
Pair(class LAMMPS *);
|
2007-12-01 05:54:30 +08:00
|
|
|
virtual ~Pair();
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
// top-level Pair methods
|
|
|
|
|
2006-09-28 03:51:33 +08:00
|
|
|
void init();
|
2014-06-15 03:34:09 +08:00
|
|
|
virtual void reinit();
|
2006-09-28 03:51:33 +08:00
|
|
|
double mix_energy(double, double, double, double);
|
|
|
|
double mix_distance(double, double);
|
|
|
|
void write_file(int, char **);
|
|
|
|
void init_bitmap(double, double, int, int &, int &, int &, int &);
|
|
|
|
virtual void modify_params(int, char **);
|
2012-04-13 06:32:17 +08:00
|
|
|
void compute_dummy(int, int);
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2011-10-06 22:25:53 +08:00
|
|
|
// need to be public, so can be called by pair_style reaxc
|
|
|
|
|
2012-05-08 04:33:25 +08:00
|
|
|
void v_tally(int, double *, double *);
|
2011-10-06 22:25:53 +08:00
|
|
|
void ev_tally(int, int, int, int, double, double, double,
|
2012-06-07 06:47:51 +08:00
|
|
|
double, double, double);
|
2011-10-06 22:25:53 +08:00
|
|
|
void ev_tally3(int, int, int, double, double,
|
2012-06-07 06:47:51 +08:00
|
|
|
double *, double *, double *, double *);
|
2011-10-06 22:25:53 +08:00
|
|
|
void v_tally3(int, int, int, double *, double *, double *, double *);
|
|
|
|
void v_tally4(int, int, int, int, double *, double *, double *,
|
2012-06-07 06:47:51 +08:00
|
|
|
double *, double *, double *);
|
2012-03-21 22:33:49 +08:00
|
|
|
void ev_tally_xyz(int, int, int, int, double, double,
|
2012-06-07 06:47:51 +08:00
|
|
|
double, double, double, double, double, double);
|
2011-10-06 22:25:53 +08:00
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
// general child-class methods
|
|
|
|
|
2006-09-28 03:51:33 +08:00
|
|
|
virtual void compute(int, int) = 0;
|
|
|
|
virtual void compute_inner() {}
|
|
|
|
virtual void compute_middle() {}
|
|
|
|
virtual void compute_outer(int, int) {}
|
2007-10-04 00:22:30 +08:00
|
|
|
|
2008-01-03 03:24:46 +08:00
|
|
|
virtual double single(int, int, int, int,
|
2013-01-16 03:08:06 +08:00
|
|
|
double, double, double,
|
|
|
|
double& fforce) {
|
|
|
|
fforce = 0.0;
|
|
|
|
return 0.0;
|
|
|
|
}
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2007-10-04 00:22:30 +08:00
|
|
|
virtual void settings(int, char **) = 0;
|
|
|
|
virtual void coeff(int, char **) = 0;
|
|
|
|
|
|
|
|
virtual void init_style();
|
|
|
|
virtual void init_list(int, class NeighList *);
|
|
|
|
virtual double init_one(int, int) {return 0.0;}
|
|
|
|
|
2012-10-18 07:28:42 +08:00
|
|
|
virtual void init_tables(double, double *);
|
2013-03-07 01:17:22 +08:00
|
|
|
virtual void init_tables_disp(double);
|
2012-10-18 07:28:42 +08:00
|
|
|
virtual void free_tables();
|
2013-03-07 01:17:22 +08:00
|
|
|
virtual void free_disp_tables();
|
2012-10-18 07:28:42 +08:00
|
|
|
|
2006-09-28 03:51:33 +08:00
|
|
|
virtual void write_restart(FILE *) {}
|
|
|
|
virtual void read_restart(FILE *) {}
|
|
|
|
virtual void write_restart_settings(FILE *) {}
|
|
|
|
virtual void read_restart_settings(FILE *) {}
|
2013-04-04 00:52:29 +08:00
|
|
|
virtual void write_data(FILE *) {}
|
2013-04-24 04:35:26 +08:00
|
|
|
virtual void write_data_all(FILE *) {}
|
2006-09-28 03:51:33 +08:00
|
|
|
|
2014-08-07 00:07:54 +08:00
|
|
|
virtual int pack_forward_comm(int, int *, double *, int, int *) {return 0;}
|
|
|
|
virtual void unpack_forward_comm(int, int, double *) {}
|
2015-02-05 06:14:27 +08:00
|
|
|
virtual int pack_forward_comm_kokkos(int, DAT::tdual_int_2d, int, DAT::tdual_xfloat_1d&, int, int *) {return 0;};
|
|
|
|
virtual void unpack_forward_comm_kokkos(int, int, DAT::tdual_xfloat_1d&) {}
|
2006-09-28 03:51:33 +08:00
|
|
|
virtual int pack_reverse_comm(int, int, double *) {return 0;}
|
|
|
|
virtual void unpack_reverse_comm(int, int *, double *) {}
|
2007-12-01 05:54:30 +08:00
|
|
|
virtual double memory_usage();
|
2007-01-30 08:22:05 +08:00
|
|
|
|
|
|
|
// specific child-class methods for certain Pair styles
|
2012-06-07 06:47:51 +08:00
|
|
|
|
2011-12-17 05:15:49 +08:00
|
|
|
virtual void *extract(const char *, int &) {return NULL;}
|
2007-10-05 01:57:04 +08:00
|
|
|
virtual void swap_eam(double *, double **) {}
|
2007-10-11 06:22:16 +08:00
|
|
|
virtual void reset_dt() {}
|
2010-08-26 01:03:55 +08:00
|
|
|
virtual void min_xf_pointers(int, double **, double **) {}
|
|
|
|
virtual void min_xf_get(int) {}
|
|
|
|
virtual void min_x_set(int) {}
|
2007-01-30 08:22:05 +08:00
|
|
|
|
2012-08-28 22:21:55 +08:00
|
|
|
virtual unsigned int data_mask() {return datamask;}
|
|
|
|
virtual unsigned int data_mask_ext() {return datamask_ext;}
|
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
protected:
|
2015-01-20 07:38:26 +08:00
|
|
|
int instance_me; // which Pair class instantiation I am
|
|
|
|
|
2012-05-30 22:18:02 +08:00
|
|
|
enum{GEOMETRIC,ARITHMETIC,SIXTHPOWER}; // mixing options
|
|
|
|
|
2014-05-24 02:17:02 +08:00
|
|
|
int special_lj[4]; // copied from force->special_lj for Kokkos
|
|
|
|
|
2012-02-17 00:13:15 +08:00
|
|
|
int allocated; // 0/1 = whether arrays are allocated
|
|
|
|
int suffix_flag; // suffix compatibility flag
|
2007-01-30 08:22:05 +08:00
|
|
|
|
|
|
|
// pair_modify settings
|
|
|
|
int offset_flag,mix_flag; // flags for offset and mixing
|
|
|
|
double tabinner; // inner cutoff for Coulomb table
|
2013-03-07 01:17:22 +08:00
|
|
|
double tabinner_disp; // inner cutoff for dispersion table
|
2009-10-30 05:53:53 +08:00
|
|
|
|
|
|
|
// custom data type for accessing Coulomb tables
|
|
|
|
|
2009-10-30 06:03:02 +08:00
|
|
|
typedef union {int i; float f;} union_int_float_t;
|
2007-12-01 05:54:30 +08:00
|
|
|
|
|
|
|
double THIRD;
|
|
|
|
|
|
|
|
int vflag_fdotr;
|
|
|
|
int maxeatom,maxvatom;
|
|
|
|
|
2015-02-05 06:14:27 +08:00
|
|
|
int copymode; // if set, do not deallocate during destruction
|
|
|
|
// required when classes are used as functors by Kokkos
|
|
|
|
|
2011-08-01 22:06:52 +08:00
|
|
|
virtual void ev_setup(int, int);
|
2012-05-15 06:10:30 +08:00
|
|
|
void ev_unset();
|
2009-11-03 04:59:26 +08:00
|
|
|
void ev_tally_full(int, double, double, double, double, double, double);
|
2010-08-09 22:42:03 +08:00
|
|
|
void ev_tally_xyz_full(int, double, double,
|
2012-06-07 06:47:51 +08:00
|
|
|
double, double, double, double, double, double);
|
2008-01-18 01:01:57 +08:00
|
|
|
void ev_tally4(int, int, int, int, double,
|
2012-06-07 06:47:51 +08:00
|
|
|
double *, double *, double *, double *, double *, double *);
|
2012-09-19 22:31:22 +08:00
|
|
|
void ev_tally_tip4p(int, int *, double *, double, double);
|
2008-01-18 01:01:57 +08:00
|
|
|
void v_tally2(int, int, double, double *);
|
2009-06-09 02:29:00 +08:00
|
|
|
void v_tally_tensor(int, int, int, int,
|
2012-06-07 06:47:51 +08:00
|
|
|
double, double, double, double, double, double);
|
2011-06-08 02:06:14 +08:00
|
|
|
void virial_fdotr_compute();
|
2011-04-06 03:10:43 +08:00
|
|
|
|
|
|
|
inline int sbmask(int j) {
|
|
|
|
return j >> SBBITS & 3;
|
|
|
|
}
|
2006-09-28 03:51:33 +08:00
|
|
|
};
|
|
|
|
|
2007-01-30 08:22:05 +08:00
|
|
|
}
|
|
|
|
|
2006-09-28 03:51:33 +08:00
|
|
|
#endif
|
2011-12-16 09:37:13 +08:00
|
|
|
|
|
|
|
/* ERROR/WARNING messages:
|
|
|
|
|
|
|
|
E: Illegal ... command
|
|
|
|
|
|
|
|
Self-explanatory. Check the input script syntax and compare to the
|
|
|
|
documentation for the command. You can use -echo screen as a
|
|
|
|
command-line option when running LAMMPS to see the offending line.
|
|
|
|
|
|
|
|
E: Too many total bits for bitmapped lookup table
|
|
|
|
|
|
|
|
Table size specified via pair_modify command is too large. Note that
|
|
|
|
a value of N generates a 2^N size table.
|
|
|
|
|
|
|
|
E: Cannot have both pair_modify shift and tail set to yes
|
|
|
|
|
|
|
|
These 2 options are contradictory.
|
|
|
|
|
|
|
|
E: Cannot use pair tail corrections with 2d simulations
|
|
|
|
|
|
|
|
The correction factors are only currently defined for 3d systems.
|
|
|
|
|
|
|
|
W: Using pair tail corrections with nonperiodic system
|
|
|
|
|
|
|
|
This is probably a bogus thing to do, since tail corrections are
|
|
|
|
computed by integrating the density of a periodic system out to
|
|
|
|
infinity.
|
|
|
|
|
2013-06-30 05:20:42 +08:00
|
|
|
W: Using a manybody potential with bonds/angles/dihedrals and special_bond exclusions
|
|
|
|
|
2014-01-31 00:09:37 +08:00
|
|
|
This is likely not what you want to do. The exclusion settings will
|
|
|
|
eliminate neighbors in the neighbor list, which the manybody potential
|
|
|
|
needs to calculated its terms correctly.
|
2013-06-30 05:20:42 +08:00
|
|
|
|
2011-12-16 09:37:13 +08:00
|
|
|
E: All pair coeffs are not set
|
|
|
|
|
|
|
|
All pair coefficients must be set in the data file or by the
|
|
|
|
pair_coeff command before running a simulation.
|
|
|
|
|
2013-06-30 05:20:42 +08:00
|
|
|
E: Pair style requres a KSpace style
|
|
|
|
|
2014-01-31 00:09:37 +08:00
|
|
|
Self-explanatory.
|
2013-06-30 05:20:42 +08:00
|
|
|
|
2011-12-16 09:37:13 +08:00
|
|
|
E: Pair style does not support pair_write
|
|
|
|
|
|
|
|
The pair style does not have a single() function, so it can
|
|
|
|
not be invoked by pair write.
|
|
|
|
|
|
|
|
E: Invalid atom types in pair_write command
|
|
|
|
|
|
|
|
Atom types must range from 1 to Ntypes inclusive.
|
|
|
|
|
|
|
|
E: Invalid style in pair_write command
|
|
|
|
|
|
|
|
Self-explanatory. Check the input script.
|
|
|
|
|
|
|
|
E: Invalid cutoffs in pair_write command
|
|
|
|
|
|
|
|
Inner cutoff must be larger than 0.0 and less than outer cutoff.
|
|
|
|
|
|
|
|
E: Cannot open pair_write file
|
|
|
|
|
|
|
|
The specified output file for pair energies and forces cannot be
|
|
|
|
opened. Check that the path and name are correct.
|
|
|
|
|
|
|
|
E: Bitmapped lookup tables require int/float be same size
|
|
|
|
|
|
|
|
Cannot use pair tables on this machine, because of word sizes. Use
|
|
|
|
the pair_modify command with table 0 instead.
|
|
|
|
|
|
|
|
W: Table inner cutoff >= outer cutoff
|
|
|
|
|
|
|
|
You specified an inner cutoff for a Coulombic table that is longer
|
|
|
|
than the global cutoff. Probably not what you wanted.
|
|
|
|
|
|
|
|
E: Too many exponent bits for lookup table
|
|
|
|
|
|
|
|
Table size specified via pair_modify command does not work with your
|
|
|
|
machine's floating point representation.
|
|
|
|
|
|
|
|
E: Too many mantissa bits for lookup table
|
|
|
|
|
|
|
|
Table size specified via pair_modify command does not work with your
|
|
|
|
machine's floating point representation.
|
|
|
|
|
|
|
|
E: Too few bits for lookup table
|
|
|
|
|
|
|
|
Table size specified via pair_modify command does not work with your
|
|
|
|
machine's floating point representation.
|
|
|
|
|
|
|
|
*/
|