| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 
 | /***************************************************************************
                               tersoff_zbl.h
                             -------------------
                              Trung Dac Nguyen
  Class for acceleration of the tersoff pair style.
 __________________________________________________________________________
    This file is part of the LAMMPS Accelerator Library (LAMMPS_AL)
 __________________________________________________________________________
    begin                :
    email                : ndactrung@gmail.com
 ***************************************************************************/
#ifndef LAL_TERSOFF_ZBL_H
#define LAL_TERSOFF_ZBL_H
#include "lal_base_three.h"
namespace LAMMPS_AL {
template <class numtyp, class acctyp>
class TersoffZBL : public BaseThree<numtyp, acctyp> {
 public:
  TersoffZBL();
  ~TersoffZBL();
  /// Clear any previous data and set up for a new LAMMPS run for generic systems
  /** \param max_nbors initial number of rows in the neighbor matrix
    * \param cell_size cutoff + skin
    * \param gpu_split fraction of particles handled by device
    *
    * Returns:
    * -  0 if successful
    * - -1 if fix gpu not found
    * - -3 if there is an out of memory error
    * - -4 if the GPU library was not compiled for GPU
    * - -5 Double precision is not supported on card **/
  int init(const int ntypes, const int nlocal, const int nall, const int max_nbors,
           const double cell_size, const double gpu_split, FILE *screen,
           int* host_map, const int nelements, int*** host_elem2param, const int nparams,
           const double* lam1, const double* lam2, const double* lam3,
           const double* powermint, const double* biga, const double* bigb,
           const double* bigr, const double* bigd, const double* c1, const double* c2,
           const double* c3, const double* c4, const double* c, const double* d,
           const double* h, const double* gamma, const double* beta,
           const double* powern, const double* Z_i, const double* Z_j,
           const double* ZBLcut, const double* ZBLexpscale, const double global_e,
           const double global_a_0, const double global_epsilon_0, const double* cutsq);
  /// Clear all host and device data
  /** \note This is called at the beginning of the init() routine **/
  void clear();
  /// Returns memory usage on device per atom
  int bytes_per_atom(const int max_nbors) const;
  /// Total host memory used by library for pair style
  double host_memory_usage() const;
  // --------------------------- TYPE DATA --------------------------
  /// If atom type constants fit in shared memory, use fast kernels
  bool shared_types;
  /// Number of atom types
  int _ntypes;
  /// ts1.x = lam1, ts1.y = lam2,  ts1.z = lam3, ts1.w = powermint
  UCL_D_Vec<numtyp4> ts1;
  /// ts2.x = biga, ts2.y = bigb,  ts2.z = bigr, ts2.w = bigd
  UCL_D_Vec<numtyp4> ts2;
  /// ts3.x = c1,   ts3.y = c2,    ts3.z = c3,   ts3.w = c4
  UCL_D_Vec<numtyp4> ts3;
  /// ts4.x = c,    ts4.y = d,     ts4.z = h,    ts4.w = gamma
  UCL_D_Vec<numtyp4> ts4;
  /// ts5.x = beta, ts5.y = powern
  UCL_D_Vec<numtyp4> ts5;
  /// ts6.x = Z_i, ts6.y = Z_j, ts6.z = ZBLcut, ts6.w = ZBLexpscale
  UCL_D_Vec<numtyp4> ts6;
  numtyp _cutsq_max;
  UCL_D_Vec<int> elem2param;
  UCL_D_Vec<int> map;
  int _nparams,_nelements;
  /// Per-atom arrays:
  /// zetaij.x = force, zetaij.y = prefactor, zetaij.z = evdwl,
  /// zetaij.w = zetaij
  UCL_D_Vec<acctyp4>   _zetaij;
  UCL_Kernel k_zeta, k_zeta_noev, *k_zeta_selt;
  numtyp _global_e,_global_a_0,_global_epsilon_0;
 private:
  bool _allocated;
  int loop(const int eflag, const int vflag, const int evatom, bool &success);
};
}
#endif
 |