lammps/lib/gpu
Michael Brown 9e412bb7a6 Fixing bug with GPU neighboring when using builds supporting CUDPP.
...introduced in Feb 2021 GPU package update. Manifests when GPU library is built with -DUSE_CUDPP and -DLAL_USE_OLD_NEIGHBOR (latter forced with CUDA 11.2).
2021-03-31 11:42:39 -07:00
..
cudpp_mini T2345: Replace instances of NULL with nullptr 2020-09-12 09:34:38 -06:00
geryon activate workaround for problems with new GPU code neighbor lists 2021-03-11 22:06:10 -05:00
.gitignore Update lib/gpu/.gitignore 2020-03-30 17:36:22 -04:00
Install.py synchronize settings with CMake support 2021-02-05 16:43:18 -05:00
Makefile.cuda disable GPU binning via CUDPP by default and describe why 2021-03-16 11:58:47 -04:00
Makefile.cuda_mps -fopenmp implies -fopenmp-simd 2021-02-17 18:30:02 -05:00
Makefile.hip -fopenmp implies -fopenmp-simd 2021-02-17 18:30:02 -05:00
Makefile.lammps.mac_ocl Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
Makefile.lammps.mingw-cross git-svn-id: svn://svn.icms.temple.edu/lammps-ro/trunk@15248 f3b2605a-c512-4ea7-a41b-209d697bcdaa 2016-07-01 23:27:26 +00:00
Makefile.lammps.opencl git-svn-id: svn://svn.icms.temple.edu/lammps-ro/trunk@10668 f3b2605a-c512-4ea7-a41b-209d697bcdaa 2013-08-23 14:46:18 +00:00
Makefile.lammps.standard Updated README and added -L$(CUDA_HOME)/lib64/stubs to the Makefile's 2019-12-11 16:29:42 -06:00
Makefile.linux disable GPU binning via CUDPP by default and describe why 2021-03-16 11:58:47 -04:00
Makefile.linux_multi disable GPU binning via CUDPP by default and describe why 2021-03-16 11:58:47 -04:00
Makefile.linux_opencl -fopenmp implies -fopenmp-simd 2021-02-17 18:30:02 -05:00
Makefile.mac_opencl Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
Makefile.mac_opencl_mpi Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
Makefile.oneapi Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
Makefile.serial disable GPU binning via CUDPP by default and describe why 2021-03-16 11:58:47 -04:00
Makefile.turing disable GPU binning via CUDPP by default and describe why 2021-03-16 11:58:47 -04:00
Nvidia.makefile Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
Nvidia.makefile_multi Made Nvidia.makefile and Opencl.makefile more compact, stored their older version 2021-01-13 22:52:01 -06:00
Opencl.makefile Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
README documentation corrections, spelling fixes and updates 2021-02-17 18:47:35 -05:00
lal_answer.cpp Fixing issue from recent GPU package update with OMP_NUM_THREADS env being overridden in GPU library. 2021-02-18 21:08:18 -08:00
lal_answer.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_atom.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_atom.cu do not mix c++ style and c-style comments 2020-04-26 22:50:24 -04:00
lal_atom.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_aux_fun1.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_balance.h convert gpu lib to use c++-style include files 2018-05-08 00:25:10 -04:00
lal_base_atomic.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_atomic.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_charge.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_charge.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_dipole.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_dipole.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_dpd.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_dpd.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_ellipsoid.cpp Fixing issue from recent GPU package update with OMP_NUM_THREADS env being overridden in GPU library. 2021-02-18 21:08:18 -08:00
lal_base_ellipsoid.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_three.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_base_three.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_beck.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_beck.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_beck.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_beck_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_long_cs.cpp make clang++ happy when trying to compile the GPU library 2019-07-12 15:42:16 -04:00
lal_born_coul_long_cs.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_long_cs.h Fix typo 2020-03-14 13:57:48 +09:00
lal_born_coul_long_cs_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_wolf.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_wolf.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_wolf.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_wolf_cs.cpp make clang++ happy when trying to compile the GPU library 2019-07-12 15:42:16 -04:00
lal_born_coul_wolf_cs.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_wolf_cs.h Fix typo 2020-03-14 13:57:48 +09:00
lal_born_coul_wolf_cs_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_coul_wolf_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_born_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_coul_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_buck_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm.cu Fix lal_charmm.cu to support HIP compilation 2021-02-23 09:51:27 -05:00
lal_charmm.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_charmm_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_colloid.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_colloid.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_colloid.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_colloid_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_debye.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_debye.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_debye.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_debye_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_dsf.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_dsf.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_dsf.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_dsf_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_long_cs.cpp make clang++ happy when trying to compile the GPU library 2019-07-12 15:42:16 -04:00
lal_coul_long_cs.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_long_cs.h Fix typo 2020-03-14 13:57:48 +09:00
lal_coul_long_cs_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_coul_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_device.cpp Fixing issue from recent GPU package update with OMP_NUM_THREADS env being overridden in GPU library. 2021-02-18 21:08:18 -08:00
lal_device.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_device.h Fixing issue from recent GPU package update with OMP_NUM_THREADS env being overridden in GPU library. 2021-02-18 21:08:18 -08:00
lal_dipole_lj.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj_sf.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj_sf.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj_sf.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_lj_sf_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_long_lj.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_long_lj.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_long_lj.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dipole_long_lj_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dpd.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dpd.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dpd.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dpd_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_dpd_tstat_ext.cpp Minor cleanup for dpd/tstat in the GPU library 2020-09-28 11:41:39 -05:00
lal_eam.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_eam.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_eam.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_eam_alloy_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_eam_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_eam_fs_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_ellipsoid_extra.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_ellipsoid_nbor.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gauss.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gauss.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gauss.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gauss_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gayberne.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gayberne.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gayberne.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_gayberne_ext.cpp convert gpu lib to use c++-style include files 2018-05-08 00:25:10 -04:00
lal_gayberne_lj.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj96.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj96.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj96.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj96_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_class2_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_class2_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_class2_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_class2_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_debye.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_debye.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_debye.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_debye_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_msm.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_msm.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_msm.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_coul_msm_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_cubic.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_cubic.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_cubic.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_cubic_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_dsf.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_dsf.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_dsf.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_dsf_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand_coul_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand_coul_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand_coul_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand_coul_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_expand_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_gromacs.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_gromacs.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_gromacs.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_gromacs_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_sdk_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_tip4p_long.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_tip4p_long.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_tip4p_long.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_lj_tip4p_long_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_mie.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_mie.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_mie.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_mie_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_morse.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_morse.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_morse.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_morse_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_neighbor.cpp Fixing bug with GPU neighboring when using builds supporting CUDPP. 2021-03-31 11:42:39 -07:00
lal_neighbor.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_neighbor_cpu.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_neighbor_gpu.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_neighbor_shared.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_neighbor_shared.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_pppm.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_pppm.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_pppm.h Merge branch 'master' into gpu_hip 2020-03-30 17:15:55 -04:00
lal_pppm_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_pre_cuda_hip.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_pre_ocl_config.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_precision.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_preprocessor.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_re_squared.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_re_squared.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_re_squared.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_re_squared_ext.cpp convert gpu lib to use c++-style include files 2018-05-08 00:25:10 -04:00
lal_re_squared_lj.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_soft.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_soft.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_soft.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_soft_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_sw.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_sw.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_sw.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_sw_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_table.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_table.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_table.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_table_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_extra.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_mod.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_mod.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_mod.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_mod_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_mod_extra.h Merge 'gpu_hip_port' into master 2020-01-28 20:35:08 +03:00
lal_tersoff_zbl.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_zbl.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_zbl.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_zbl_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_tersoff_zbl_extra.h Merge 'gpu_hip_port' into master 2020-01-28 20:35:08 +03:00
lal_ufm.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_ufm.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_ufm.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_ufm_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_vashishta.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_vashishta.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_vashishta.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_vashishta_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa_colloid.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa_colloid.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa_colloid.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa_colloid_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_yukawa_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_zbl.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_zbl.cu Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_zbl.h Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00
lal_zbl_ext.cpp Feb2021 GPU Package Update - GPU Package Files 2021-02-15 08:20:50 -08:00

README

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

                  --------------------------------
                     LAMMPS ACCELERATOR LIBRARY
                  --------------------------------

                       W. Michael Brown (ORNL)
                        Trung Dac Nguyen (ORNL/Northwestern)
                        Nitin Dhamankar (Intel)
                       Axel Kohlmeyer (Temple)
                          Peng Wang (NVIDIA)
                        Anders Hafreager (UiO)
                          V. Nikolskiy (HSE)
                   Maurice de Koning (Unicamp/Brazil)
                  Rodolfo Paula Leite (Unicamp/Brazil)
                         Steve Plimpton (SNL)
                        Inderaj Bains (NVIDIA)


------------------------------------------------------------------------------

This directory has source files to build a library that LAMMPS links against
when using the GPU package.

This library must be built with a C++ compiler along with CUDA, HIP, or OpenCL
before LAMMPS is built, so LAMMPS can link against it.

This library, libgpu.a, provides routines for acceleration of certain
LAMMPS styles and neighbor list builds using CUDA, OpenCL, or ROCm HIP.

Pair styles supported by this library are marked in the list of Pair style
potentials with a "g". See the online version at:

https://lammps.sandia.gov/doc/Commands_pair.html

In addition the (plain) pppm kspace style is supported as well.

------------------------------------------------------------------------------
                              DEVICE QUERY
------------------------------------------------------------------------------
The gpu library includes binaries to check for available GPUs and their
properties. It is a good idea to run this on first use to make sure the
system and build is setup properly. Additionally, the GPU numbering for
specific selection of devices should be taking from this output. The GPU
library may split some accelerators into separate virtual accelerators for
efficient use with MPI.

After building the GPU library, for OpenCL:
  ./ocl_get_devices
for CUDA:
  ./nvc_get_devices
and for ROCm HIP:
  ./hip_get_devices

------------------------------------------------------------------------------
                              QUICK START
------------------------------------------------------------------------------
OpenCL: Mac without MPI:
  make -f Makefile.mac_opencl -j; cd ../../src/; make mpi-stubs
  make g++_serial -j
  ./lmp_g++_serial -in ../bench/in.lj -log none -sf gpu

OpenCL: Mac with MPI:
  make -f Makefile.mac_opencl_mpi -j; cd ../../src/; make g++_openmpi -j
  mpirun -np $NUM_MPI ./lmp_g++_openmpi -in ../bench/in.lj -log none -sf gpu

OpenCL: Linux with Intel oneAPI:
  make -f Makefile.oneapi -j; cd ../../src; make oneapi -j
  export OMP_NUM_THREADS=$NUM_THREADS
  mpirun -np $NUM_MPI ./lmp_oneapi -in ../bench/in.lj -log none -sf gpu

OpenCL: Linux with MPI:
  make -f Makefile.linux_opencl -j; cd ../../src; make omp -j
  export OMP_NUM_THREADS=$NUM_THREADS
  mpirun -np $NUM_MPI ./lmp_omp -in ../bench/in.lj -log none -sf gpu

NVIDIA CUDA:
  make -f Makefile.cuda_mps -j; cd ../../src; make omp -j
  export CUDA_MPS_LOG_DIRECTORY=/tmp; export CUDA_MPS_PIPE_DIRECTORY=/tmp
  nvidia-smi -i 0 -c EXCLUSIVE_PROCESS
  export OMP_NUM_THREADS=$NUM_THREADS
  mpirun -np $NUM_MPI ./lmp_omp -in ../bench/in.lj -log none -sf gpu
  echo quit | /usr/bin/nvidia-cuda-mps-control

AMD HIP:
  make -f Makefile.hip -j; cd ../../src; make omp -j
  export OMP_NUM_THREADS=$NUM_THREADS
  mpirun -np $NUM_MPI ./lmp_omp -in ../bench/in.lj -log none -sf gpu

------------------------------------------------------------------------------
                 Installing oneAPI, OpenCl, CUDA, or ROCm
------------------------------------------------------------------------------
The easiest approach is to use the linux package manger to perform the
installation from Intel, NVIDIA, etc. repositories. All are available for
free. The oneAPI installation includes Intel optimized MPI and C++ compilers,
along with many libraries. Alternatively, Intel OpenCL can also be installed
separately from the Intel repository.

NOTE: Installation of the CUDA SDK is not required, only the CUDA toolkit.

See:

https://software.intel.com/content/www/us/en/develop/tools/oneapi/hpc-toolkit.html

https://docs.nvidia.com/cuda/cuda-installation-guide-linux/index.html

https://github.com/RadeonOpenCompute/ROCm

------------------------------------------------------------------------------
                              Build Intro
------------------------------------------------------------------------------

You can type "make lib-gpu" from the src directory to see help on how
to build this library via make commands, or you can do the same thing
by typing "python Install.py" from within this directory, or you can
do it manually by following the instructions below.

Build the library using one of the provided Makefile.* files or create
your own, specific to your compiler and system.  For example:

make -f Makefile.linux_opencl

When you are done building this library, two files should
exist in this directory:

libgpu.a                the library LAMMPS will link against
Makefile.lammps         settings the LAMMPS Makefile will import

Makefile.lammps is created by the make command, by copying one of the
Makefile.lammps.* files.  See the EXTRAMAKE setting at the top of the
Makefile.* files.

IMPORTANT: You should examine the final Makefile.lammps to insure it is
correct for your system, else the LAMMPS build can fail.

IMPORTANT: If you re-build the library, e.g. for a different precision
(see below), you should do a "make clean" first, e.g. make -f
Makefile.linux clean, to insure all previous derived files are removed
before the new build is done.

NOTE: The system-specific setting LAMMPS_SMALLBIG (default), LAMMPS_BIGBIG,
      or LAMMPS_SMALLSMALL if specified when building LAMMPS (i.e. in
      src/MAKE/Makefile.foo) should be consistent with that specified
      when building libgpu.a (i.e. by LMP_INC in the lib/gpu/Makefile.bar).


------------------------------------------------------------------------------
                             PRECISION MODES
------------------------------------------------------------------------------
The GPU library supports 3 precision modes: single, double, and mixed, with
the latter being the default for most Makefiles aside from Mac specific
Makefiles due to the more restrictive nature of the Apple OpenCL for some
devices.

To specify the precision mode (output to the screen before LAMMPS runs for
verification), set either CUDA_PRECISION, OCL_PREC, or HIP_PRECISION to one
of -D_SINGLE_SINGLE, -D_DOUBLE_DOUBLE, or -D_SINGLE_DOUBLE.

Some accelerators or OpenCL implementations only support single precision.
This mode should be used with care and appropriate validation as the errors
can scale with system size in this implementation. This can be useful for
accelerating test runs when setting up a simulation for production runs on
another machine. In the case where only single precision is supported, either
LAMMPS must be compiled with -DFFT_SINGLE to use PPPM with GPU acceleration
or GPU acceleration should be disabled for PPPM (e.g. suffix off or pair/only
as described in the LAMMPS documentation).


------------------------------------------------------------------------------
                             CUDA BUILD NOTES
------------------------------------------------------------------------------
NOTE: when compiling with CMake, all of the considerations listed below
are considered within the CMake configuration process, so no separate
compilation of the gpu library is required. Also this will build in support
for all compute architecture that are supported by the CUDA toolkit version
used to build the gpu library.

If you do not want to use a fat binary, that supports multiple CUDA
architectures, the CUDA_ARCH must be set to match the GPU architecture. This
is reported by nvc_get_devices executable created by the build process and
a detailed list of GPU architectures and CUDA compatible GPUs can be found
e.g. here: https://en.wikipedia.org/wiki/CUDA#GPUs_supported

The CUDA_HOME variable should be set to the location of the CUDA toolkit.

To build, edit the CUDA_ARCH, CUDA_PRECISION, CUDA_HOME variables in one of
the Makefiles. CUDA_ARCH should be set based on the compute capability of
your GPU. This can be verified by running the nvc_get_devices executable after
the build is complete. Additionally, the GPU package must be installed and
compiled for LAMMPS. This may require editing the gpu_SYSPATH variable in the
LAMMPS makefile.

Please note that the GPU library accesses the CUDA driver library directly,
so it needs to be linked with the CUDA driver library (libcuda.so) that ships
with the Nvidia driver. If you are compiling LAMMPS on the head node of a GPU
cluster, this library may not be installed, so you may need to copy it over
from one of the compute nodes (best into this directory). Recent CUDA toolkits
starting from CUDA 9 provide a dummy libcuda.so library (typically under
$(CUDA_HOME)/lib64/stubs), that can be used for linking.

Best performance with the GPU library is typically with multiple MPI processes
sharing the same GPU cards. For NVIDIA, this is most efficient with CUDA
MPS enabled. To prevent runtime errors for GPUs configured in exclusive process
mode with MPS, the GPU library should be build with either of the equivalent
-DCUDA_MPS_SUPPORT or -DCUDA_PROXY flags.

------------------------------------------------------------------------------
                             HIP BUILD NOTES
------------------------------------------------------------------------------

1. GPU sorting requires installing hipcub
(https://github.com/ROCmSoftwarePlatform/hipCUB). The HIP CUDA-backend
additionally requires cub (https://nvlabs.github.io/cub). Download and
extract the cub directory to lammps/lib/gpu/ or specify an appropriate
path in lammps/lib/gpu/Makefile.hip.
2. In Makefile.hip it is possible to specify the target platform via
export HIP_PLATFORM=hcc or HIP_PLATFORM=nvcc as well as the target
architecture (gfx803, gfx900, gfx906 etc.)
3. If your MPI implementation does not support `mpicxx --showme` command,
it is required to specify the corresponding MPI compiler and linker flags
in lammps/lib/gpu/Makefile.hip and in lammps/src/MAKE/OPTIONS/Makefile.hip.

------------------------------------------------------------------------------
                             OPENCL BUILD NOTES
------------------------------------------------------------------------------
If GERYON_NUMA_FISSION is defined at build time, LAMMPS will consider separate
NUMA nodes on GPUs or accelerators as separate devices. For example, a 2-socket
CPU would appear as two separate devices for OpenCL (and LAMMPS would require
two MPI processes to use both sockets with the GPU library - each with its
own device ID as output by ocl_get_devices).

For a debug build, use "-DUCL_DEBUG -DGERYON_KERNEL_DUMP" and remove
"-DUCL_NO_EXIT" and "-DMPI_GERYON" from the build options.

------------------------------------------------------------------------------
                   ALL PREPROCESSOR OPTIONS (For Advanced Users)
------------------------------------------------------------------------------
_SINGLE_SINGLE          Build library for single precision mode
_SINGLE_DOUBLE          Build library for mixed precision mode
_DOUBLE_DOUBLE          Build library for double precision mode
CUDA_MPS_SUPPORT        Do not generate errors for exclusive mode for CUDA
CUDA_PROXY              Same as above
MPI_GERYON              Library should use MPI_Abort for unhandled errors
GERYON_NUMA_FISSION     Accelerators with main memory NUMA are split into
                        multiple virtual accelerators for each NUMA node
LAL_USE_OMP=0           Disable OpenMP in lib, regardless of compiler setting
LAL_USE_OMP_SIMD=0      Disable OpenMP SIMD in lib, regardless of compiler set
GERYON_OCL_FLUSH        For OpenCL, flush queue after every enqueue
LAL_NO_OCL_EV_JIT       Turn off JIT specialization for kernels in OpenCL
LAL_USE_OLD_NEIGHBOR    Use old neighbor list algorithm
USE_CUDPP               Enable GPU binning in neighbor builds (not recommended)
USE_HIP_DEVICE_SORT     Enable GPU binning for HIP builds
                        (only w/ LAL_USE_OLD_NEIGHBOR)
LAL_NO_BLOCK_REDUCE     Use host for energy/virial accumulation
LAL_OCL_EXTRA_ARGS      Supply extra args for OpenCL compiler delimited with :
UCL_NO_EXIT             LAMMPS should handle errors instead of Geryon lib
UCL_DEBUG               Debug build for Geryon
GERYON_KERNEL_DUMP      Dump all compiled OpenCL programs with compiler
                        flags and build logs
GPU_CAST                Casting performed on GPU, untested recently
THREE_CONCURRENT        Concurrent 3-body calcs in separate queues, untested


------------------------------------------------------------------------------
                           References for Details
------------------------------------------------------------------------------

Brown, W.M., Wang, P. Plimpton, S.J., Tharrington, A.N. Implementing
Molecular Dynamics on Hybrid High Performance Computers - Short Range
Forces. Computer Physics Communications. 2011. 182: p. 898-911.

and

Brown, W.M., Kohlmeyer, A. Plimpton, S.J., Tharrington, A.N. Implementing
Molecular Dynamics on Hybrid High Performance Computers - Particle-Particle
Particle-Mesh. Computer Physics Communications. 2012. 183: p. 449-459.

and

Brown, W.M., Masako, Y. Implementing Molecular Dynamics on Hybrid High
Performance Computers - Three-Body Potentials. Computer Physics Communications.
2013. 184: p. 27852793.