/*************************************************************************** ufm.cu ------------------- Rodolfo Paula Leite (Unicamp/Brazil) Maurice de Koning (Unicamp/Brazil) Device code for acceleration of the ufm pair style __________________________________________________________________________ This file is part of the LAMMPS Accelerator Library (LAMMPS_AL) __________________________________________________________________________ begin : email : pl.rodolfo@gmail.com dekoning@ifi.unicamp.br ***************************************************************************/ #ifdef NV_KERNEL #include "lal_aux_fun1.h" #ifndef _DOUBLE_DOUBLE texture pos_tex; #else texture pos_tex; #endif #else #define pos_tex x_ #endif __kernel void k_ufm(const __global numtyp4 *restrict x_, const __global numtyp4 *restrict uf1, const __global numtyp4 *restrict uf3, const int lj_types, const __global numtyp *restrict sp_lj, const __global int * dev_nbor, const __global int * dev_packed, __global acctyp4 *restrict ans, __global acctyp *restrict engv, const int eflag, const int vflag, const int inum, const int nbor_pitch, const int t_per_atom) { int tid, ii, offset; atom_info(t_per_atom,ii,tid,offset); acctyp energy=(acctyp)0; acctyp4 f; f.x=(acctyp)0; f.y=(acctyp)0; f.z=(acctyp)0; acctyp virial[6]; for (int i=0; i<6; i++) virial[i]=(acctyp)0; if (ii0) { energy += - factor_lj * uf3[mtype].x*log(1.0 - expuf) - uf3[mtype].z; } if (vflag>0) { virial[0] += delx*delx*force; virial[1] += dely*dely*force; virial[2] += delz*delz*force; virial[3] += delx*dely*force; virial[4] += delx*delz*force; virial[5] += dely*delz*force; } } } // for nbor store_answers(f,energy,virial,ii,inum,tid,t_per_atom,offset,eflag,vflag, ans,engv); } // if ii } __kernel void k_ufm_fast(const __global numtyp4 *restrict x_, const __global numtyp4 *restrict uf1_in, const __global numtyp4 *restrict uf3_in, const __global numtyp *restrict sp_lj_in, const __global int * dev_nbor, const __global int * dev_packed, __global acctyp4 *restrict ans, __global acctyp *restrict engv, const int eflag, const int vflag, const int inum, const int nbor_pitch, const int t_per_atom) { int tid, ii, offset; atom_info(t_per_atom,ii,tid,offset); __local numtyp4 uf1[MAX_SHARED_TYPES*MAX_SHARED_TYPES]; __local numtyp4 uf3[MAX_SHARED_TYPES*MAX_SHARED_TYPES]; __local numtyp sp_lj[4]; if (tid<4) sp_lj[tid]=sp_lj_in[tid]; if (tid0) uf3[tid]=uf3_in[tid]; } acctyp energy=(acctyp)0; acctyp4 f; f.x=(acctyp)0; f.y=(acctyp)0; f.z=(acctyp)0; acctyp virial[6]; for (int i=0; i<6; i++) virial[i]=(acctyp)0; __syncthreads(); if (ii0) { energy += - factor_lj * uf3[mtype].x * log(1.0 - expuf) - uf3[mtype].z; } if (vflag>0) { virial[0] += delx*delx*force; virial[1] += dely*dely*force; virial[2] += delz*delz*force; virial[3] += delx*dely*force; virial[4] += delx*delz*force; virial[5] += dely*delz*force; } } } // for nbor store_answers(f,energy,virial,ii,inum,tid,t_per_atom,offset,eflag,vflag, ans,engv); } // if ii }