diff options
Diffstat (limited to 'lammps/573.diff')
-rw-r--r-- | lammps/573.diff | 1073 |
1 files changed, 0 insertions, 1073 deletions
diff --git a/lammps/573.diff b/lammps/573.diff deleted file mode 100644 index 45ad3b4..0000000 --- a/lammps/573.diff +++ /dev/null @@ -1,1073 +0,0 @@ -diff --git a/.gitignore b/.gitignore -index 74e511515e..50b970249a 100644 ---- a/.gitignore -+++ b/.gitignore -@@ -32,3 +32,11 @@ log.cite - .Trashes - ehthumbs.db - Thumbs.db -+ -+#cmake -+/build* -+/CMakeCache.txt -+/CMakeFiles/ -+/Makefile -+/cmake_install.cmake -+/lmp -diff --git a/cmake/CMakeLists.txt b/cmake/CMakeLists.txt -new file mode 100644 -index 0000000000..15a87b7f6e ---- /dev/null -+++ b/cmake/CMakeLists.txt -@@ -0,0 +1,542 @@ -+######################################## -+# CMake build system -+# This file is part of LAMMPS -+# Created by Christoph Junghans and Richard Berger -+cmake_minimum_required(VERSION 3.1) -+ -+project(lammps) -+set(SOVERSION 0) -+set(LAMMPS_SOURCE_DIR ${CMAKE_SOURCE_DIR}/../src) -+set(LAMMPS_LIB_SOURCE_DIR ${CMAKE_SOURCE_DIR}/../lib) -+set(LAMMPS_LIB_BINARY_DIR ${CMAKE_BINARY_DIR}/lib) -+ -+#To not conflict with old Makefile build system, we build everything here -+file(GLOB LIB_SOURCES ${LAMMPS_SOURCE_DIR}/*.cpp) -+file(GLOB LMP_SOURCES ${LAMMPS_SOURCE_DIR}/main.cpp) -+list(REMOVE_ITEM LIB_SOURCES ${LMP_SOURCES}) -+ -+# Cmake modules/macros are in a subdirectory to keep this file cleaner -+set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/Modules) -+ -+if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_C_FLAGS) -+ #release comes with -O3 by default -+ set(CMAKE_BUILD_TYPE Release CACHE STRING "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel." FORCE) -+endif(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_C_FLAGS) -+ -+foreach(STYLE_FILE style_angle.h style_atom.h style_body.h style_bond.h style_command.h style_compute.h style_dihedral.h style_dump.h -+ style_fix.h style_improper.h style_integrate.h style_kspace.h style_minimize.h style_nbin.h style_npair.h style_nstencil.h -+ style_ntopo.h style_pair.h style_reader.h style_region.h) -+ if(EXISTS ${LAMMPS_SOURCE_DIR}/${STYLE_FILE}) -+ message(FATAL_ERROR "There is a ${STYLE_FILE} in ${LAMMPS_SOURCE_DIR}, please clean up the source directory first") -+ endif() -+endforeach() -+ -+enable_language(CXX) -+ -+###################################################################### -+# compiler tests -+# these need ot be done early (before further tests). -+##################################################################### -+include(CheckCCompilerFlag) -+ -+######################################################################## -+# User input options # -+######################################################################## -+option(BUILD_SHARED_LIBS "Build shared libs" OFF) -+option(INSTALL_LIB "Install lammps library and header" ON) -+include(GNUInstallDirs) -+ -+set(LAMMPS_LINK_LIBS) -+option(ENABLE_MPI "Build MPI version" OFF) -+if(ENABLE_MPI) -+ find_package(MPI REQUIRED) -+ include_directories(${MPI_C_INCLUDE_PATH}) -+ list(APPEND LAMMPS_LINK_LIBS ${MPI_CXX_LIBRARIES}) -+ option(LAMMPS_LONGLONG_TO_LONG "Workaround if your system or MPI version does not recognize 'long long' data types" OFF) -+ if(LAMMPS_LONGLONG_TO_LONG) -+ add_definitions(-DLAMMPS_LONGLONG_TO_LONG) -+ endif() -+else() -+ file(GLOB MPI_SOURCES ${LAMMPS_SOURCE_DIR}/STUBS/mpi.c) -+ list(APPEND LIB_SOURCES ${MPI_SOURCES}) -+ include_directories(${LAMMPS_SOURCE_DIR}/STUBS) -+endif() -+ -+set(LAMMPS_SIZE_LIMIT "LAMMPS_SMALLBIG" CACHE STRING "Lammps size limit") -+set_property(CACHE LAMMPS_SIZE_LIMIT PROPERTY STRINGS LAMMPS_SMALLBIG LAMMPS_BIGBIG LAMMPS_SMALLSMALL) -+add_definitions(-D${LAMMPS_SIZE_LIMIT}) -+ -+set(LAMMPS_MEMALIGN "64" CACHE STRING "enables the use of the posix_memalign() call instead of malloc() when large chunks or memory are allocated by LAMMPS") -+add_definitions(-DLAMMPS_MEMALIGN=${LAMMPS_MEMALIGN}) -+ -+option(CMAKE_VERBOSE_MAKEFILE "Verbose makefile" OFF) -+ -+option(ENABLE_TESTING "Enable testing" OFF) -+if(ENABLE_TESTING) -+ enable_testing() -+endif(ENABLE_TESTING) -+ -+option(ENABLE_ALL "Build all default packages" OFF) -+set(DEFAULT_PACKAGES ASPHERE BODY CLASS2 COLLOID COMPRESS CORESHELL DIPOLE GRANULAR -+ KSPACE MANYBODY MC MEAM MISC MOLECULE PERI QEQ -+ REAX REPLICA RIGID SHOCK SNAP SRD) -+set(OTHER_PACKAGES KIM PYTHON MSCG MPIIO VORONOI POEMS -+ USER-ATC USER-AWPMD USER-CGDNA -+ USER-CGSDK USER-COLVARS USER-DIFFRACTION USER-DPD USER-DRUDE USER-EFF -+ USER-FEP USER-H5MD USER-LB USER-MANIFOLD USER-MEAMC USER-MGPT USER-MISC -+ USER-MOLFILE USER-NETCDF USER-PHONON USER-QTB USER-REAXC USER-SMD -+ USER-SMTBQ USER-SPH USER-TALLY USER-VTK USER-QUIP USER-QMMM) -+set(ACCEL_PACKAGES USER-OMP KOKKOS OPT USER-INTEL GPU) -+foreach(PKG ${DEFAULT_PACKAGES}) -+ option(ENABLE_${PKG} "Build ${PKG} Package" ${ENABLE_ALL}) -+endforeach() -+foreach(PKG ${ACCEL_PACKAGES} ${OTHER_PACKAGES}) -+ option(ENABLE_${PKG} "Build ${PKG} Package" OFF) -+endforeach() -+ -+macro(pkg_depends PKG1 PKG2) -+ if(ENABLE_${PKG1} AND NOT ENABLE_${PKG2}) -+ message(FATAL_ERROR "${PKG1} package needs LAMMPS to be build with ${PKG2}") -+ endif() -+endmacro() -+ -+pkg_depends(MPIIO MPI) -+pkg_depends(QEQ MANYBODY) -+pkg_depends(USER-ATC MANYBODY) -+pkg_depends(USER-H5MD MPI) -+pkg_depends(USER-LB MPI) -+pkg_depends(USER-MISC MANYBODY) -+pkg_depends(USER-PHONON KSPACE) -+ -+if(ENABLE_BODY AND ENABLE_POEMS) -+ message(FATAL_ERROR "BODY and POEMS cannot be enabled at the same time") -+endif() -+ -+###################################################### -+# packages with special compiler needs or external libs -+###################################################### -+if(ENABLE_REAX OR ENABLE_MEAM OR ENABLE_USER-QUIP OR ENABLE_USER-QMMM) -+ enable_language(Fortran) -+endif() -+ -+if(ENABLE_KOKKOS OR ENABLE_MSCG) -+ # starting with CMake 3.1 this is all you have to do to enforce C++11 -+ set(CMAKE_CXX_STANDARD 11) # C++11... -+ set(CMAKE_CXX_STANDARD_REQUIRED ON) #...is required... -+ set(CMAKE_CXX_EXTENSIONS OFF) #...without compiler extensions like gnu++11 -+endif() -+ -+if(ENABLE_USER-OMP OR ENABLE_KOKKOS OR ENABLE_USER-INTEL) -+ find_package(OpenMP REQUIRED) -+ set (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${OpenMP_C_FLAGS}") -+ set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OpenMP_CXX_FLAGS}") -+endif() -+ -+if(ENABLE_KSPACE) -+ set(FFT "KISSFFT" CACHE STRING "FFT library for KSPACE package") -+ set_property(CACHE FFT PROPERTY STRINGS KISSFFT FFTW3 MKL FFTW2) -+ if(NOT FFT STREQUAL "KISSFFT") -+ find_package(${FFT} REQUIRED) -+ add_definitions(-DFFT_${FFT}) -+ include_directories(${${FFT}_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS ${${FFT}_LIBRARIES}) -+ endif() -+ set(PACK_OPTIMIZATION "PACK_ARRAY" CACHE STRING "Optimization for FFT") -+ set_property(CACHE PACK_OPTIMIZATION PROPERTY STRINGS PACK_ARRAY PACK_POINTER PACK_MEMCPY) -+ if(NOT PACK_OPTIMIZATION STREQUAL "PACK_ARRAY") -+ add_definitions(-D${PACK_OPTIMIZATION}) -+ endif() -+endif() -+ -+if(ENABLE_MISC) -+ option(LAMMPS_XDR "include XDR compatibility files for doing particle dumps in XTC format" OFF) -+ if(LAMMPS_XDR) -+ add_definitions(-DLAMMPS_XDR) -+ endif() -+endif() -+ -+if(ENABLE_MSCG OR ENABLE_USER-ATC OR ENABLE_USER-AWPMD OR ENABLE_USER-QUIP) -+ find_package(LAPACK) -+ if(LAPACK_FOUND) -+ list(APPEND LAMMPS_LINK_LIBS ${LAPACK_LIBRARIES}) -+ else() -+ enable_language(Fortran) -+ file(GLOB LAPACK_SOURCES ${LAMMPS_LIB_SOURCE_DIR}/linalg/*.f) -+ list(APPEND LIB_SOURCES ${LAPACK_SOURCES}) -+ endif() -+endif() -+ -+if(ENABLE_PYTHON) -+ find_package(PythonInterp REQUIRED) -+ find_package(PythonLibs REQUIRED) -+ add_definitions(-DLMP_PYTHON) -+ include_directories(${PYTHON_INCLUDE_DIR}) -+ list(APPEND LAMMPS_LINK_LIBS ${PYTHON_LIBRARY}) -+ if(NOT PYTHON_INSTDIR) -+ execute_process(COMMAND ${PYTHON_EXECUTABLE} -+ -c "import distutils.sysconfig as cg; print(cg.get_python_lib(1,0,prefix='${CMAKE_INSTALL_PREFIX}'))" -+ OUTPUT_VARIABLE PYTHON_INSTDIR OUTPUT_STRIP_TRAILING_WHITESPACE) -+ endif() -+ install(FILES ${CMAKE_SOURCE_DIR}/../python/lammps.py DESTINATION ${PYTHON_INSTDIR}) -+ if(NOT BUILD_SHARED_LIBS) -+ message(FATAL_ERROR "Python package need lammps to be build shared, -DBUILD_SHARED_LIBS=ON") -+ endif() -+endif() -+ -+find_package(JPEG) -+if(JPEG_FOUND) -+ add_definitions(-DLAMMPS_JPEG) -+ include_directories(${JPEG_INCLUDE_DIR}) -+ list(APPEND LAMMPS_LINK_LIBS ${JPEG_LIBRARIES}) -+endif() -+ -+find_package(PNG) -+find_package(ZLIB) -+if(PNG_FOUND AND ZLIB_FOUND) -+ include_directories(${PNG_INCLUDE_DIRS} ${ZLIB_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS ${PNG_LIBRARIES} ${ZLIB_LIBRARIES}) -+ add_definitions(-DLAMMPS_PNG) -+endif() -+ -+find_program(GZIP_EXECUTABLE gzip) -+find_package_handle_standard_args(GZIP REQUIRED_VARS GZIP_EXECUTABLE) -+if(GZIP_FOUND) -+ add_definitions(-DLAMMPS_GZIP) -+endif() -+ -+find_program(FFMPEG_EXECUTABLE ffmpeg) -+find_package_handle_standard_args(FFMPEG REQUIRED_VARS FFMPEG_EXECUTABLE) -+if(FFMPEG_FOUND) -+ add_definitions(-DLAMMPS_FFMPEG) -+endif() -+ -+if(ENABLE_VORONOI) -+ find_package(VORO REQUIRED) #some distros -+ include_directories(${VORO_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS ${VORO_LIBRARIES}) -+endif() -+ -+if(ENABLE_USER-MOLFILE) -+ list(APPEND LAMMPS_LINK_LIBS ${CMAKE_DL_LIBS}) -+endif() -+ -+if(ENABLE_USER-NETCDF) -+ find_package(NetCDF REQUIRED) -+ include_directories(NETCDF_INCLUDE_DIR) -+ list(APPEND LAMMPS_LINK_LIBS ${NETCDF_LIBRARY}) -+ add_definitions(-DLMP_HAS_NETCDF -DNC_64BIT_DATA=0x0020) -+endif() -+ -+if(ENABLE_USER-SMD) -+ find_package(Eigen3 REQUIRED) -+ include_directories(${EIGEN3_INCLUDE_DIR}) -+endif() -+ -+if(ENABLE_USER-QUIP) -+ find_package(QUIP REQUIRED) -+ list(APPEND LAMMPS_LINK_LIBS ${QUIP_LIBRARIES} ${CMAKE_Fortran_IMPLICIT_LINK_LIBRARIES}) -+endif() -+ -+if(ENABLE_USER-QMMM) -+ find_package(QE REQUIRED) -+ include_directories(${QE_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS ${QE_LIBRARIES} ${CMAKE_Fortran_IMPLICIT_LINK_LIBRARIES}) -+endif() -+ -+if(ENABLE_USER-AWPMD) -+ include_directories(${LAMMPS_LIB_SOURCE_DIR}/awpmd/systems/interact -+ ${LAMMPS_LIB_SOURCE_DIR}/awpmd/ivutils/include) -+endif() -+ -+if(ENABLE_USER-H5MD) -+ find_package(HDF5 REQUIRED) -+ list(APPEND LAMMPS_LINK_LIBS ${HDF5_LIBRARIES}) -+ include_directories(${HDF5_INCLUDE_DIRS} ${LAMMPS_LIB_SOURCE_DIR}/h5md/include) -+endif() -+ -+if(ENABLE_USER-VTK) -+ find_package(VTK REQUIRED NO_MODULE) -+ include(${VTK_USE_FILE}) -+ add_definitions(-DLAMMPS_VTK) -+ list(APPEND LAMMPS_LINK_LIBS ${VTK_LIBRARIES}) -+endif() -+ -+if(ENABLE_KIM) -+ find_package(KIM REQUIRED) -+ list(APPEND LAMMPS_LINK_LIBS ${KIM_LIBRARIES}) -+ include_directories(${KIM_INCLUDE_DIRS}) -+endif() -+ -+if(ENABLE_MSCG) -+ find_package(GSL REQUIRED) -+ set(LAMMPS_LIB_MSCG_BIN_DIR ${LAMMPS_LIB_BINARY_DIR}/mscg) -+ set(MSCG_TARBALL ${LAMMPS_LIB_MSCG_BIN_DIR}/MS-CG-master.zip) -+ set(LAMMPS_LIB_MSCG_BIN_DIR ${LAMMPS_LIB_MSCG_BIN_DIR}/MSCG-release-master/src) -+ if(NOT EXISTS ${LAMMPS_LIB_MSCG_BIN_DIR}) -+ if(NOT EXISTS ${MSCG_TARBALL}) -+ message(STATUS "Downloading ${MSCG_TARBALL}") -+ file(DOWNLOAD -+ https://github.com/uchicago-voth/MSCG-release/archive/master.zip -+ ${MSCG_TARBALL} SHOW_PROGRESS) #EXPECTED_MD5 cannot be due due to master -+ endif() -+ message(STATUS "Unpacking ${MSCG_TARBALL}") -+ execute_process(COMMAND ${CMAKE_COMMAND} -E tar xvf ${MSCG_TARBALL} -+ WORKING_DIRECTORY ${LAMMPS_LIB_BINARY_DIR}/mscg) -+ endif() -+ file(GLOB MSCG_SOURCES ${LAMMPS_LIB_MSCG_BIN_DIR}/*.cpp) -+ list(APPEND LIB_SOURCES ${MSCG_SOURCES}) -+ foreach(MSCG_SOURCE ${MSCG_SOURCES}) -+ set_property(SOURCE ${MSCG_SOURCE} APPEND PROPERTY COMPILE_DEFINITIONS -+ DIMENSION=3 _exclude_gromacs=1) -+ endforeach() -+ include_directories(${LAMMPS_LIB_MSCG_BIN_DIR} ${GSL_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS ${GSL_LIBRARIES}) -+endif() -+ -+######################################################################## -+# Basic system tests (standard libraries, headers, functions, types) # -+######################################################################## -+include(CheckIncludeFile) -+foreach(HEADER math.h) -+ check_include_file(${HEADER} FOUND_${HEADER}) -+ if(NOT FOUND_${HEADER}) -+ message(FATAL_ERROR "Could not find needed header - ${HEADER}") -+ endif(NOT FOUND_${HEADER}) -+endforeach(HEADER) -+ -+set(MATH_LIBRARIES "m" CACHE STRING "math library") -+mark_as_advanced( MATH_LIBRARIES ) -+include(CheckLibraryExists) -+foreach(FUNC sin cos) -+ check_library_exists(${MATH_LIBRARIES} ${FUNC} "" FOUND_${FUNC}_${MATH_LIBRARIES}) -+ if(NOT FOUND_${FUNC}_${MATH_LIBRARIES}) -+ message(FATAL_ERROR "Could not find needed math function - ${FUNC}") -+ endif(NOT FOUND_${FUNC}_${MATH_LIBRARIES}) -+endforeach(FUNC) -+list(APPEND LAMMPS_LINK_LIBS ${MATH_LIBRARIES}) -+ -+###################################### -+# Generate Basic Style files -+###################################### -+include(StyleHeaderUtils) -+RegisterStyles(${LAMMPS_SOURCE_DIR}) -+ -+############################################## -+# add sources of enabled packages -+############################################ -+foreach(PKG ${DEFAULT_PACKAGES} ${OTHER_PACKAGES}) -+ if(ENABLE_${PKG}) -+ set(${PKG}_SOURCES_DIR ${LAMMPS_SOURCE_DIR}/${PKG}) -+ -+ # detects styles in package and adds them to global list -+ RegisterStyles(${${PKG}_SOURCES_DIR}) -+ -+ file(GLOB ${PKG}_SOURCES ${${PKG}_SOURCES_DIR}/*.cpp) -+ list(APPEND LIB_SOURCES ${${PKG}_SOURCES}) -+ include_directories(${${PKG}_SOURCES_DIR}) -+ endif() -+endforeach() -+ -+############################################## -+# add lib sources of (simple) enabled packages -+############################################ -+foreach(SIMPLE_LIB REAX MEAM POEMS USER-ATC USER-AWPMD USER-COLVARS USER-H5MD -+ USER-MOLFILE USER-QMMM) -+ if(ENABLE_${SIMPLE_LIB}) -+ string(REGEX REPLACE "^USER-" "" SIMPLE_LIB "${SIMPLE_LIB}") -+ string(TOLOWER "${SIMPLE_LIB}" INC_DIR) -+ file(GLOB_RECURSE ${SIMPLE_LIB}_SOURCES ${LAMMPS_LIB_SOURCE_DIR}/${INC_DIR}/*.F -+ ${LAMMPS_LIB_SOURCE_DIR}/${INC_DIR}/*.c ${LAMMPS_LIB_SOURCE_DIR}/${INC_DIR}/*.cpp) -+ list(APPEND LIB_SOURCES ${${SIMPLE_LIB}_SOURCES}) -+ include_directories(${LAMMPS_LIB_SOURCE_DIR}/${INC_DIR}) -+ endif() -+endforeach() -+ -+###################################################################### -+# packages which selectively include variants based on enabled styles -+# e.g. accelerator packages -+###################################################################### -+if(ENABLE_USER-OMP) -+ set(USER-OMP_SOURCES_DIR ${LAMMPS_SOURCE_DIR}/USER-OMP) -+ set(USER-OMP_SOURCES ${USER-OMP_SOURCES_DIR}/thr_data.cpp -+ ${USER-OMP_SOURCES_DIR}/thr_omp.cpp -+ ${USER-OMP_SOURCES_DIR}/fix_nh_omp.cpp -+ ${USER-OMP_SOURCES_DIR}/fix_nh_sphere_omp.cpp) -+ set_property(GLOBAL PROPERTY "OMP_SOURCES" "${USER-OMP_SOURCES}") -+ -+ # detects styles which have USER-OMP version -+ RegisterStylesExt(${USER-OMP_SOURCES_DIR} omp OMP_SOURCES) -+ -+ get_property(USER-OMP_SOURCES GLOBAL PROPERTY OMP_SOURCES) -+ -+ list(APPEND LIB_SOURCES ${USER-OMP_SOURCES}) -+ include_directories(${USER-OMP_SOURCES_DIR}) -+endif() -+ -+if(ENABLE_KOKKOS) -+ set(LAMMPS_LIB_KOKKOS_SRC_DIR ${LAMMPS_LIB_SOURCE_DIR}/kokkos) -+ set(LAMMPS_LIB_KOKKOS_BIN_DIR ${LAMMPS_LIB_BINARY_DIR}/kokkos) -+ add_definitions(-DLMP_KOKKOS) -+ add_subdirectory(${LAMMPS_LIB_KOKKOS_SRC_DIR} ${LAMMPS_LIB_KOKKOS_BIN_DIR}) -+ -+ set(Kokkos_INCLUDE_DIRS ${LAMMPS_LIB_KOKKOS_SRC_DIR}/core/src -+ ${LAMMPS_LIB_KOKKOS_SRC_DIR}/containers/src -+ ${LAMMPS_LIB_KOKKOS_SRC_DIR}/algorithms/src -+ ${LAMMPS_LIB_KOKKOS_BIN_DIR}) -+ include_directories(${Kokkos_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS kokkos) -+ -+ set(KOKKOS_PKG_SOURCES_DIR ${LAMMPS_SOURCE_DIR}/KOKKOS) -+ set(KOKKOS_PKG_SOURCES ${KOKKOS_PKG_SOURCES_DIR}/kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/atom_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/atom_vec_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/comm_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/comm_tiled_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/neighbor_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/neigh_list_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/neigh_bond_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/fix_nh_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/domain_kokkos.cpp -+ ${KOKKOS_PKG_SOURCES_DIR}/modify_kokkos.cpp) -+ set_property(GLOBAL PROPERTY "KOKKOS_PKG_SOURCES" "${KOKKOS_PKG_SOURCES}") -+ -+ # detects styles which have KOKKOS version -+ RegisterStylesExt(${KOKKOS_PKG_SOURCES_DIR} kokkos KOKKOS_PKG_SOURCES) -+ -+ get_property(KOKKOS_PKG_SOURCES GLOBAL PROPERTY KOKKOS_PKG_SOURCES) -+ -+ list(APPEND LIB_SOURCES ${KOKKOS_PKG_SOURCES}) -+ include_directories(${KOKKOS_PKG_SOURCES_DIR}) -+endif() -+ -+if(ENABLE_OPT) -+ set(OPT_SOURCES_DIR ${LAMMPS_SOURCE_DIR}/OPT) -+ set(OPT_SOURCES) -+ set_property(GLOBAL PROPERTY "OPT_SOURCES" "${OPT_SOURCES}") -+ -+ # detects styles which have OPT version -+ RegisterStylesExt(${OPT_SOURCES_DIR} opt OPT_SOURCES) -+ -+ get_property(OPT_SOURCES GLOBAL PROPERTY OPT_SOURCES) -+ -+ list(APPEND LIB_SOURCES ${OPT_SOURCES}) -+ include_directories(${OPT_SOURCES_DIR}) -+endif() -+ -+if(ENABLE_USER-INTEL) -+ set(USER-INTEL_SOURCES_DIR ${LAMMPS_SOURCE_DIR}/USER-INTEL) -+ set(USER-INTEL_SOURCES ${USER-INTEL_SOURCES_DIR}/intel_preprocess.h -+ ${USER-INTEL_SOURCES_DIR}/intel_buffers.h -+ ${USER-INTEL_SOURCES_DIR}/intel_buffers.cpp -+ ${USER-INTEL_SOURCES_DIR}/math_extra_intel.h -+ ${USER-INTEL_SOURCES_DIR}/nbin_intel.h -+ ${USER-INTEL_SOURCES_DIR}/nbin_intel.cpp -+ ${USER-INTEL_SOURCES_DIR}/npair_intel.h -+ ${USER-INTEL_SOURCES_DIR}/npair_intel.cpp -+ ${USER-INTEL_SOURCES_DIR}/intel_simd.h -+ ${USER-INTEL_SOURCES_DIR}/intel_intrinsics.h) -+ -+ set_property(GLOBAL PROPERTY "USER-INTEL_SOURCES" "${USER-INTEL_SOURCES}") -+ -+ # detects styles which have USER-INTEL version -+ RegisterStylesExt(${USER-INTEL_SOURCES_DIR} opt USER-INTEL_SOURCES) -+ -+ get_property(USER-INTEL_SOURCES GLOBAL PROPERTY USER-INTEL_SOURCES) -+ -+ list(APPEND LIB_SOURCES ${USER-INTEL_SOURCES}) -+ include_directories(${USER-INTEL_SOURCES_DIR}) -+endif() -+ -+if(ENABLE_GPU) -+ find_package(CUDA REQUIRED) -+ find_program(BIN2C bin2c) -+ if(NOT BIN2C) -+ message(FATAL_ERROR "Couldn't find bin2c") -+ endif() -+ include_directories(${CUDA_INCLUDE_DIRS}) -+ list(APPEND LAMMPS_LINK_LIBS ${CUDA_LIBRARIES} ${CUDA_CUDA_LIBRARY}) -+ set(GPU_PREC "SINGLE_DOUBLE" CACHE STRING "Lammps gpu precision size") -+ set_property(CACHE GPU_PREC PROPERTY STRINGS SINGLE_DOUBLE SINGLE_SINGLE DOUBLE_DOUBLE) -+ add_definitions(-D_${GPU_PREC}) -+ add_definitions(-DNV_KERNEL -DUCL_CUDADR) -+ option(CUDPP_OPT "Enable CUDPP_OPT" ON) -+ -+ set(GPU_SOURCES_DIR ${LAMMPS_SOURCE_DIR}/GPU) -+ set(GPU_SOURCES ${GPU_SOURCES_DIR}/gpu_extra.h) -+ -+ set_property(GLOBAL PROPERTY "GPU_SOURCES" "${GPU_SOURCES}") -+ -+ # detects styles which have GPU version -+ RegisterStylesExt(${GPU_SOURCES_DIR} opt GPU_SOURCES) -+ -+ get_property(GPU_SOURCES GLOBAL PROPERTY GPU_SOURCES) -+ -+ file(GLOB GPU_LIB_SOURCES ${LAMMPS_LIB_SOURCE_DIR}/gpu/*.cpp) -+ file(GLOB GPU_LIB_CU ${LAMMPS_LIB_SOURCE_DIR}/gpu/*.cu ${CMAKE_SOURCE_DIR}/gpu/*.cu) -+ file(GLOB_RECURSE GPU_NOT_LIB_CU ${LAMMPS_LIB_SOURCE_DIR}/gpu/lal_pppm.cu) -+ list(REMOVE_ITEM GPU_LIB_CU ${GPU_NOT_LIB_CU}) -+ include_directories(${GPU_SOURCES_DIR} ${LAMMPS_LIB_SOURCE_DIR}/gpu ${LAMMPS_LIB_BINARY_DIR}/gpu) -+ if(CUDPP_OPT) -+ include_directories(${LAMMPS_LIB_SOURCE_DIR}/gpu/cudpp_mini) -+ add_definitions(-DCUDPP_OPT) -+ file(GLOB GPU_LIB_CUDPP_SOURCES ${LAMMPS_LIB_SOURCE_DIR}/gpu/cudpp_mini/*.cpp) -+ file(GLOB GPU_LIB_CUDPP_CU ${LAMMPS_LIB_SOURCE_DIR}/gpu/cudpp_mini/*.cu) -+ endif() -+ cuda_compile(GPU_OBJS ${GPU_LIB_CU} ${GPU_LIB_CUDPP_CU} OPTIONS $<$<BOOL:${BUILD_SHARED_LIBS}>:-Xcompiler=-fPIC>) -+ file(MAKE_DIRECTORY ${LAMMPS_LIB_BINARY_DIR}/gpu) -+ foreach(CU_OBJ ${GPU_OBJS}) -+ get_filename_component(CU_NAME ${CU_OBJ} NAME_WE) -+ string(REGEX REPLACE "^.*_lal_" "" CU_NAME "${CU_NAME}") -+ add_custom_command(OUTPUT ${LAMMPS_LIB_BINARY_DIR}/gpu/${CU_NAME}_cubin.h -+ COMMAND ${BIN2C} -c -n ${CU_NAME} ${CU_OBJ} > ${LAMMPS_LIB_BINARY_DIR}/gpu/${CU_NAME}_cubin.h -+ DEPENDS ${CU_OBJ} -+ COMMENT "Generating ${CU_NAME}_cubin.h") -+ list(APPEND LIB_SOURCES ${LAMMPS_LIB_BINARY_DIR}/gpu/${CU_NAME}_cubin.h) -+ if(${CU_NAME} STREQUAL "pppm_d") #pppm_d doesn't get linked into the lib -+ set(CU_FORBIDDEN_OBJ "${CU_OBJ}") -+ endif() -+ endforeach() -+ list(REMOVE_ITEM GPU_OBJS "${CU_FORBIDDEN_OBJ}") -+ list(APPEND LIB_SOURCES ${GPU_SOURCES} ${GPU_LIB_SOURCES} ${GPU_LIB_CUDPP_SOURCES} ${GPU_OBJS}) -+ set_directory_properties(PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES "${AMMPS_LIB_BINARY_DIR}/gpu/*_cubin.h") -+endif() -+ -+###################################################### -+# Generate style headers based on global list of -+# styles registered during package selection -+###################################################### -+set(LAMMPS_STYLE_HEADERS_DIR ${CMAKE_CURRENT_BINARY_DIR}/styles) -+ -+GenerateStyleHeaders(${LAMMPS_STYLE_HEADERS_DIR}) -+ -+include_directories(${LAMMPS_SOURCE_DIR}) -+include_directories(${LAMMPS_STYLE_HEADERS_DIR}) -+ -+########################################### -+# Actually add executable and lib to build -+############################################ -+add_library(lammps ${LIB_SOURCES}) -+target_link_libraries(lammps ${LAMMPS_LINK_LIBS}) -+set_target_properties(lammps PROPERTIES SOVERSION ${SOVERSION}) -+if(INSTALL_LIB) -+ install(TARGETS lammps LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}) -+ install(FILES ${LAMMPS_SOURCE_DIR}/lammps.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}) -+elseif(BUILD_SHARED_LIBS) -+ message(FATAL_ERROR "Shared library has to be installed, use -DBUILD_SHARED_LIBS=ON to install lammps with a library") -+endif() -+ -+add_executable(lmp ${LMP_SOURCES}) -+target_link_libraries(lmp lammps) -+install(TARGETS lmp DESTINATION ${CMAKE_INSTALL_BINDIR}) -+if(ENABLE_TESTING) -+ add_test(ShowHelp lmp -help) -+endif() -+ -+################################## -+# Print package summary -+################################## -+foreach(PKG ${DEFAULT_PACKAGES} ${OTHER_PACKAGES} ${ACCEL_PACKAGES}) -+ if(ENABLE_${PKG}) -+ message(STATUS "Building package: ${PKG}") -+ endif() -+endforeach() -diff --git a/cmake/Modules/FindFFTW2.cmake b/cmake/Modules/FindFFTW2.cmake -new file mode 100644 -index 0000000000..c77e6cf8e9 ---- /dev/null -+++ b/cmake/Modules/FindFFTW2.cmake -@@ -0,0 +1,22 @@ -+# - Find fftw2 -+# Find the native FFTW2 headers and libraries. -+# -+# FFTW2_INCLUDE_DIRS - where to find fftw2.h, etc. -+# FFTW2_LIBRARIES - List of libraries when using fftw2. -+# FFTW2_FOUND - True if fftw2 found. -+# -+ -+find_path(FFTW2_INCLUDE_DIR fftw.h) -+ -+find_library(FFTW2_LIBRARY NAMES fftw) -+ -+set(FFTW2_LIBRARIES ${FFTW2_LIBRARY}) -+set(FFTW2_INCLUDE_DIRS ${FFTW2_INCLUDE_DIR}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set FFTW2_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(FFTW2 DEFAULT_MSG FFTW2_LIBRARY FFTW2_INCLUDE_DIR) -+ -+mark_as_advanced(FFTW2_INCLUDE_DIR FFTW2_LIBRARY ) -diff --git a/cmake/Modules/FindFFTW3.cmake b/cmake/Modules/FindFFTW3.cmake -new file mode 100644 -index 0000000000..552bcc4257 ---- /dev/null -+++ b/cmake/Modules/FindFFTW3.cmake -@@ -0,0 +1,25 @@ -+# - Find fftw3 -+# Find the native FFTW3 headers and libraries. -+# -+# FFTW3_INCLUDE_DIRS - where to find fftw3.h, etc. -+# FFTW3_LIBRARIES - List of libraries when using fftw3. -+# FFTW3_FOUND - True if fftw3 found. -+# -+ -+find_package(PkgConfig) -+ -+pkg_check_modules(PC_FFTW3 fftw3) -+find_path(FFTW3_INCLUDE_DIR fftw3.h HINTS ${PC_FFTW3_INCLUDE_DIRS}) -+ -+find_library(FFTW3_LIBRARY NAMES fftw3 HINTS ${PC_FFTW3_LIBRARY_DIRS}) -+ -+set(FFTW3_LIBRARIES ${FFTW3_LIBRARY}) -+set(FFTW3_INCLUDE_DIRS ${FFTW3_INCLUDE_DIR}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set FFTW3_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(FFTW3 DEFAULT_MSG FFTW3_LIBRARY FFTW3_INCLUDE_DIR) -+ -+mark_as_advanced(FFTW3_INCLUDE_DIR FFTW3_LIBRARY ) -diff --git a/cmake/Modules/FindKIM.cmake b/cmake/Modules/FindKIM.cmake -new file mode 100644 -index 0000000000..a01f817cf6 ---- /dev/null -+++ b/cmake/Modules/FindKIM.cmake -@@ -0,0 +1,22 @@ -+# - Find kim -+# Find the native KIM headers and libraries. -+# -+# KIM_INCLUDE_DIRS - where to find kim.h, etc. -+# KIM_LIBRARIES - List of libraries when using kim. -+# KIM_FOUND - True if kim found. -+# -+ -+find_path(KIM_INCLUDE_DIR KIM_API.h PATH_SUFFIXES kim-api-v1) -+ -+find_library(KIM_LIBRARY NAMES kim-api-v1) -+ -+set(KIM_LIBRARIES ${KIM_LIBRARY}) -+set(KIM_INCLUDE_DIRS ${KIM_INCLUDE_DIR}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set KIM_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(KIM DEFAULT_MSG KIM_LIBRARY KIM_INCLUDE_DIR) -+ -+mark_as_advanced(KIM_INCLUDE_DIR KIM_LIBRARY ) -diff --git a/cmake/Modules/FindMKL.cmake b/cmake/Modules/FindMKL.cmake -new file mode 100644 -index 0000000000..4246062103 ---- /dev/null -+++ b/cmake/Modules/FindMKL.cmake -@@ -0,0 +1,22 @@ -+# - Find mkl -+# Find the native MKL headers and libraries. -+# -+# MKL_INCLUDE_DIRS - where to find mkl.h, etc. -+# MKL_LIBRARIES - List of libraries when using mkl. -+# MKL_FOUND - True if mkl found. -+# -+ -+find_path(MKL_INCLUDE_DIR mkl_dfti.h HINTS $ENV{MKLROOT}/include) -+ -+find_library(MKL_LIBRARY NAMES mkl_rt HINTS $ENV{MKLROOT}/lib $ENV{MKLROOT}/lib/intel64) -+ -+set(MKL_LIBRARIES ${MKL_LIBRARY}) -+set(MKL_INCLUDE_DIRS ${MKL_INCLUDE_DIR}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set MKL_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(MKL DEFAULT_MSG MKL_LIBRARY MKL_INCLUDE_DIR) -+ -+mark_as_advanced(MKL_INCLUDE_DIR MKL_LIBRARY ) -diff --git a/cmake/Modules/FindNetCDF.cmake b/cmake/Modules/FindNetCDF.cmake -new file mode 100644 -index 0000000000..a28c959acf ---- /dev/null -+++ b/cmake/Modules/FindNetCDF.cmake -@@ -0,0 +1,118 @@ -+# - Find NetCDF -+# Find the native NetCDF includes and library -+# -+# NETCDF_INCLUDE_DIR - user modifiable choice of where netcdf headers are -+# NETCDF_LIBRARY - user modifiable choice of where netcdf libraries are -+# -+# Your package can require certain interfaces to be FOUND by setting these -+# -+# NETCDF_CXX - require the C++ interface and link the C++ library -+# NETCDF_F77 - require the F77 interface and link the fortran library -+# NETCDF_F90 - require the F90 interface and link the fortran library -+# -+# Or equivalently by calling FindNetCDF with a COMPONENTS argument containing one or -+# more of "CXX;F77;F90". -+# -+# When interfaces are requested the user has access to interface specific hints: -+# -+# NETCDF_${LANG}_INCLUDE_DIR - where to search for interface header files -+# NETCDF_${LANG}_LIBRARY - where to search for interface libraries -+# -+# This module returns these variables for the rest of the project to use. -+# -+# NETCDF_FOUND - True if NetCDF found including required interfaces (see below) -+# NETCDF_LIBRARIES - All netcdf related libraries. -+# NETCDF_INCLUDE_DIRS - All directories to include. -+# NETCDF_HAS_INTERFACES - Whether requested interfaces were found or not. -+# NETCDF_${LANG}_INCLUDE_DIRS/NETCDF_${LANG}_LIBRARIES - C/C++/F70/F90 only interface -+# -+# Normal usage would be: -+# set (NETCDF_F90 "YES") -+# find_package (NetCDF REQUIRED) -+# target_link_libraries (uses_everthing ${NETCDF_LIBRARIES}) -+# target_link_libraries (only_uses_f90 ${NETCDF_F90_LIBRARIES}) -+ -+#search starting from user editable cache var -+if (NETCDF_INCLUDE_DIR AND NETCDF_LIBRARY) -+ # Already in cache, be silent -+ set (NETCDF_FIND_QUIETLY TRUE) -+endif () -+ -+set(USE_DEFAULT_PATHS "NO_DEFAULT_PATH") -+if(NETCDF_USE_DEFAULT_PATHS) -+ set(USE_DEFAULT_PATHS "") -+endif() -+ -+find_path (NETCDF_INCLUDE_DIR netcdf.h -+ HINTS "${NETCDF_DIR}/include") -+mark_as_advanced (NETCDF_INCLUDE_DIR) -+set (NETCDF_C_INCLUDE_DIRS ${NETCDF_INCLUDE_DIR}) -+ -+find_library (NETCDF_LIBRARY NAMES netcdf -+ HINTS "${NETCDF_DIR}/lib") -+mark_as_advanced (NETCDF_LIBRARY) -+ -+set (NETCDF_C_LIBRARIES ${NETCDF_LIBRARY}) -+ -+#start finding requested language components -+set (NetCDF_libs "") -+set (NetCDF_includes "${NETCDF_INCLUDE_DIR}") -+ -+get_filename_component (NetCDF_lib_dirs "${NETCDF_LIBRARY}" PATH) -+set (NETCDF_HAS_INTERFACES "YES") # will be set to NO if we're missing any interfaces -+ -+macro (NetCDF_check_interface lang header libs) -+ if (NETCDF_${lang}) -+ #search starting from user modifiable cache var -+ find_path (NETCDF_${lang}_INCLUDE_DIR NAMES ${header} -+ HINTS "${NETCDF_INCLUDE_DIR}" -+ HINTS "${NETCDF_${lang}_ROOT}/include" -+ ${USE_DEFAULT_PATHS}) -+ -+ find_library (NETCDF_${lang}_LIBRARY NAMES ${libs} -+ HINTS "${NetCDF_lib_dirs}" -+ HINTS "${NETCDF_${lang}_ROOT}/lib" -+ ${USE_DEFAULT_PATHS}) -+ -+ mark_as_advanced (NETCDF_${lang}_INCLUDE_DIR NETCDF_${lang}_LIBRARY) -+ -+ #export to internal varS that rest of project can use directly -+ set (NETCDF_${lang}_LIBRARIES ${NETCDF_${lang}_LIBRARY}) -+ set (NETCDF_${lang}_INCLUDE_DIRS ${NETCDF_${lang}_INCLUDE_DIR}) -+ -+ if (NETCDF_${lang}_INCLUDE_DIR AND NETCDF_${lang}_LIBRARY) -+ list (APPEND NetCDF_libs ${NETCDF_${lang}_LIBRARY}) -+ list (APPEND NetCDF_includes ${NETCDF_${lang}_INCLUDE_DIR}) -+ else () -+ set (NETCDF_HAS_INTERFACES "NO") -+ message (STATUS "Failed to find NetCDF interface for ${lang}") -+ endif () -+ endif () -+endmacro () -+ -+list (FIND NetCDF_FIND_COMPONENTS "CXX" _nextcomp) -+if (_nextcomp GREATER -1) -+ set (NETCDF_CXX 1) -+endif () -+list (FIND NetCDF_FIND_COMPONENTS "F77" _nextcomp) -+if (_nextcomp GREATER -1) -+ set (NETCDF_F77 1) -+endif () -+list (FIND NetCDF_FIND_COMPONENTS "F90" _nextcomp) -+if (_nextcomp GREATER -1) -+ set (NETCDF_F90 1) -+endif () -+NetCDF_check_interface (CXX netcdfcpp.h netcdf_c++) -+NetCDF_check_interface (F77 netcdf.inc netcdff) -+NetCDF_check_interface (F90 netcdf.mod netcdff) -+ -+#export accumulated results to internal varS that rest of project can depend on -+list (APPEND NetCDF_libs "${NETCDF_C_LIBRARIES}") -+set (NETCDF_LIBRARIES ${NetCDF_libs}) -+set (NETCDF_INCLUDE_DIRS ${NetCDF_includes}) -+ -+# handle the QUIETLY and REQUIRED arguments and set NETCDF_FOUND to TRUE if -+# all listed variables are TRUE -+include (FindPackageHandleStandardArgs) -+find_package_handle_standard_args (NetCDF -+ DEFAULT_MSG NETCDF_LIBRARIES NETCDF_INCLUDE_DIRS NETCDF_HAS_INTERFACES) -diff --git a/cmake/Modules/FindQE.cmake b/cmake/Modules/FindQE.cmake -new file mode 100644 -index 0000000000..4484bd4db2 ---- /dev/null -+++ b/cmake/Modules/FindQE.cmake -@@ -0,0 +1,29 @@ -+# - Find quantum-espresso -+# Find the native QE headers and libraries. -+# -+# QE_INCLUDE_DIRS - where to find quantum-espresso.h, etc. -+# QE_LIBRARIES - List of libraries when using quantum-espresso. -+# QE_FOUND - True if quantum-espresso found. -+# -+ -+find_path(QE_INCLUDE_DIR libqecouple.h PATH_SUFFIXES COUPLE/include) -+ -+find_library(QECOUPLE_LIBRARY NAMES qecouple) -+find_library(PW_LIBRARY NAMES pw) -+find_library(QEMOD_LIBRARY NAMES qemod) -+find_library(QEFFT_LIBRARY NAMES qefft) -+find_library(QELA_LIBRARY NAMES qela) -+find_library(CLIB_LIBRARY NAMES clib) -+find_library(IOTK_LIBRARY NAMES iotk) -+ -+ -+set(QE_LIBRARIES ${QECOUPLE_LIBRARY} ${PW_LIBRARY} ${QEMOD_LIBRARY} ${QEFFT_LIBRARY} ${QELA_LIBRARY} ${CLIB_LIBRARY} ${IOTK_LIBRARY}) -+set(QE_INCLUDE_DIRS ${QE_INCLUDE_DIR}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set QE_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(QE DEFAULT_MSG QECOUPLE_LIBRARY PW_LIBRARY QEMOD_LIBRARY QEFFT_LIBRARY QELA_LIBRARY CLIB_LIBRARY IOTK_LIBRARY QE_INCLUDE_DIR) -+ -+mark_as_advanced(QE_INCLUDE_DIR QECOUPLE_LIBRARY PW_LIBRARY QEMOD_LIBRARY QEFFT_LIBRARY QELA_LIBRARY CLIB_LIBRARY IOTK_LIBRARY) -diff --git a/cmake/Modules/FindQUIP.cmake b/cmake/Modules/FindQUIP.cmake -new file mode 100644 -index 0000000000..4ee1baf4f8 ---- /dev/null -+++ b/cmake/Modules/FindQUIP.cmake -@@ -0,0 +1,18 @@ -+# - Find quip -+# Find the native QUIP libraries. -+# -+# QUIP_LIBRARIES - List of libraries when using fftw3. -+# QUIP_FOUND - True if fftw3 found. -+# -+ -+find_library(QUIP_LIBRARY NAMES quip) -+ -+set(QUIP_LIBRARIES ${QUIP_LIBRARY}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set QUIP_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(QUIP DEFAULT_MSG QUIP_LIBRARY) -+ -+mark_as_advanced(QUIP_LIBRARY) -diff --git a/cmake/Modules/FindVORO.cmake b/cmake/Modules/FindVORO.cmake -new file mode 100644 -index 0000000000..b0cccbcd1d ---- /dev/null -+++ b/cmake/Modules/FindVORO.cmake -@@ -0,0 +1,22 @@ -+# - Find voro++ -+# Find the native VORO headers and libraries. -+# -+# VORO_INCLUDE_DIRS - where to find voro++.hh, etc. -+# VORO_LIBRARIES - List of libraries when using voro++. -+# VORO_FOUND - True if voro++ found. -+# -+ -+find_path(VORO_INCLUDE_DIR voro++.hh PATH_SUFFIXES voro++) -+ -+find_library(VORO_LIBRARY NAMES voro++) -+ -+set(VORO_LIBRARIES ${VORO_LIBRARY}) -+set(VORO_INCLUDE_DIRS ${VORO_INCLUDE_DIR}) -+ -+include(FindPackageHandleStandardArgs) -+# handle the QUIETLY and REQUIRED arguments and set VORO_FOUND to TRUE -+# if all listed variables are TRUE -+ -+find_package_handle_standard_args(VORO DEFAULT_MSG VORO_LIBRARY VORO_INCLUDE_DIR) -+ -+mark_as_advanced(VORO_INCLUDE_DIR VORO_LIBRARY ) -diff --git a/cmake/Modules/StyleHeaderUtils.cmake b/cmake/Modules/StyleHeaderUtils.cmake -new file mode 100644 -index 0000000000..9939a7505a ---- /dev/null -+++ b/cmake/Modules/StyleHeaderUtils.cmake -@@ -0,0 +1,132 @@ -+function(FindStyleHeaders path style_class file_pattern headers) -+ file(GLOB files "${path}/${file_pattern}*.h") -+ get_property(hlist GLOBAL PROPERTY ${headers}) -+ -+ foreach(file_name ${files}) -+ file(STRINGS ${file_name} is_style LIMIT_COUNT 1 REGEX ${style_class}) -+ if(is_style) -+ list(APPEND hlist ${file_name}) -+ endif() -+ endforeach() -+ set_property(GLOBAL PROPERTY ${headers} "${hlist}") -+endfunction(FindStyleHeaders) -+ -+function(FindStyleHeadersExt path style_class extension headers sources) -+ get_property(hlist GLOBAL PROPERTY ${headers}) -+ get_property(slist GLOBAL PROPERTY ${sources}) -+ set(ext_list) -+ get_filename_component(abs_path "${path}" ABSOLUTE) -+ -+ foreach(file_name ${hlist}) -+ get_filename_component(basename ${file_name} NAME_WE) -+ set(ext_file_name "${abs_path}/${basename}_${extension}.h") -+ if(EXISTS "${ext_file_name}") -+ file(STRINGS ${ext_file_name} is_style LIMIT_COUNT 1 REGEX ${style_class}) -+ if(is_style) -+ list(APPEND ext_list ${ext_file_name}) -+ -+ set(source_file_name "${abs_path}/${basename}_${extension}.cpp") -+ if(EXISTS "${source_file_name}") -+ list(APPEND slist ${source_file_name}) -+ endif() -+ endif() -+ endif() -+ endforeach() -+ -+ list(APPEND hlist ${ext_list}) -+ set_property(GLOBAL PROPERTY ${headers} "${hlist}") -+ set_property(GLOBAL PROPERTY ${sources} "${slist}") -+endfunction(FindStyleHeadersExt) -+ -+function(CreateStyleHeader path filename) -+ math(EXPR N "${ARGC}-2") -+ -+ set(temp "") -+ if(N GREATER 0) -+ math(EXPR ARG_END "${ARGC}-1") -+ -+ foreach(IDX RANGE 2 ${ARG_END}) -+ list(GET ARGV ${IDX} FNAME) -+ get_filename_component(FNAME ${FNAME} NAME) -+ set(temp "${temp}#include \"${FNAME}\"\n") -+ endforeach() -+ endif() -+ message(STATUS "Generating ${filename}...") -+ file(WRITE "${path}/${filename}.tmp" "${temp}" ) -+ execute_process(COMMAND ${CMAKE_COMMAND} -E copy_if_different "${path}/${filename}.tmp" "${path}/${filename}") -+endfunction(CreateStyleHeader) -+ -+function(GenerateStyleHeader path property style) -+ get_property(files GLOBAL PROPERTY ${property}) -+ #message("${property} = ${files}") -+ CreateStyleHeader("${path}" "style_${style}.h" ${files}) -+endfunction(GenerateStyleHeader) -+ -+function(RegisterStyles search_path) -+ FindStyleHeaders(${search_path} ANGLE_CLASS angle_ ANGLE ) # angle ) # force -+ FindStyleHeaders(${search_path} ATOM_CLASS atom_vec_ ATOM_VEC ) # atom ) # atom atom_vec_hybrid -+ FindStyleHeaders(${search_path} BODY_CLASS body_ BODY ) # body ) # atom_vec_body -+ FindStyleHeaders(${search_path} BOND_CLASS bond_ BOND ) # bond ) # force -+ FindStyleHeaders(${search_path} COMMAND_CLASS "" COMMAND ) # command ) # input -+ FindStyleHeaders(${search_path} COMPUTE_CLASS compute_ COMPUTE ) # compute ) # modify -+ FindStyleHeaders(${search_path} DIHEDRAL_CLASS dihedral_ DIHEDRAL ) # dihedral ) # force -+ FindStyleHeaders(${search_path} DUMP_CLASS dump_ DUMP ) # dump ) # output write_dump -+ FindStyleHeaders(${search_path} FIX_CLASS fix_ FIX ) # fix ) # modify -+ FindStyleHeaders(${search_path} IMPROPER_CLASS improper_ IMPROPER ) # improper ) # force -+ FindStyleHeaders(${search_path} INTEGRATE_CLASS "" INTEGRATE ) # integrate ) # update -+ FindStyleHeaders(${search_path} KSPACE_CLASS "" KSPACE ) # kspace ) # force -+ FindStyleHeaders(${search_path} MINIMIZE_CLASS min_ MINIMIZE ) # minimize ) # update -+ FindStyleHeaders(${search_path} NBIN_CLASS nbin_ NBIN ) # nbin ) # neighbor -+ FindStyleHeaders(${search_path} NPAIR_CLASS npair_ NPAIR ) # npair ) # neighbor -+ FindStyleHeaders(${search_path} NSTENCIL_CLASS nstencil_ NSTENCIL ) # nstencil ) # neighbor -+ FindStyleHeaders(${search_path} NTOPO_CLASS ntopo_ NTOPO ) # ntopo ) # neighbor -+ FindStyleHeaders(${search_path} PAIR_CLASS pair_ PAIR ) # pair ) # force -+ FindStyleHeaders(${search_path} READER_CLASS reader_ READER ) # reader ) # read_dump -+ FindStyleHeaders(${search_path} REGION_CLASS region_ REGION ) # region ) # domain -+endfunction(RegisterStyles) -+ -+function(RegisterStylesExt search_path extension sources) -+ FindStyleHeadersExt(${search_path} ANGLE_CLASS ${extension} ANGLE ${sources}) -+ FindStyleHeadersExt(${search_path} ATOM_CLASS ${extension} ATOM_VEC ${sources}) -+ FindStyleHeadersExt(${search_path} BODY_CLASS ${extension} BODY ${sources}) -+ FindStyleHeadersExt(${search_path} BOND_CLASS ${extension} BOND ${sources}) -+ FindStyleHeadersExt(${search_path} COMMAND_CLASS ${extension} COMMAND ${sources}) -+ FindStyleHeadersExt(${search_path} COMPUTE_CLASS ${extension} COMPUTE ${sources}) -+ FindStyleHeadersExt(${search_path} DIHEDRAL_CLASS ${extension} DIHEDRAL ${sources}) -+ FindStyleHeadersExt(${search_path} DUMP_CLASS ${extension} DUMP ${sources}) -+ FindStyleHeadersExt(${search_path} FIX_CLASS ${extension} FIX ${sources}) -+ FindStyleHeadersExt(${search_path} IMPROPER_CLASS ${extension} IMPROPER ${sources}) -+ FindStyleHeadersExt(${search_path} INTEGRATE_CLASS ${extension} INTEGRATE ${sources}) -+ FindStyleHeadersExt(${search_path} KSPACE_CLASS ${extension} KSPACE ${sources}) -+ FindStyleHeadersExt(${search_path} MINIMIZE_CLASS ${extension} MINIMIZE ${sources}) -+ FindStyleHeadersExt(${search_path} NBIN_CLASS ${extension} NBIN ${sources}) -+ FindStyleHeadersExt(${search_path} NPAIR_CLASS ${extension} NPAIR ${sources}) -+ FindStyleHeadersExt(${search_path} NSTENCIL_CLASS ${extension} NSTENCIL ${sources}) -+ FindStyleHeadersExt(${search_path} NTOPO_CLASS ${extension} NTOPO ${sources}) -+ FindStyleHeadersExt(${search_path} PAIR_CLASS ${extension} PAIR ${sources}) -+ FindStyleHeadersExt(${search_path} READER_CLASS ${extension} READER ${sources}) -+ FindStyleHeadersExt(${search_path} REGION_CLASS ${extension} REGION ${sources}) -+endfunction(RegisterStylesExt) -+ -+function(GenerateStyleHeaders output_path) -+ GenerateStyleHeader(${output_path} ANGLE angle ) # force -+ GenerateStyleHeader(${output_path} ATOM_VEC atom ) # atom atom_vec_hybrid -+ GenerateStyleHeader(${output_path} BODY body ) # atom_vec_body -+ GenerateStyleHeader(${output_path} BOND bond ) # force -+ GenerateStyleHeader(${output_path} COMMAND command ) # input -+ GenerateStyleHeader(${output_path} COMPUTE compute ) # modify -+ GenerateStyleHeader(${output_path} DIHEDRAL dihedral ) # force -+ GenerateStyleHeader(${output_path} DUMP dump ) # output write_dump -+ GenerateStyleHeader(${output_path} FIX fix ) # modify -+ GenerateStyleHeader(${output_path} IMPROPER improper ) # force -+ GenerateStyleHeader(${output_path} INTEGRATE integrate ) # update -+ GenerateStyleHeader(${output_path} KSPACE kspace ) # force -+ GenerateStyleHeader(${output_path} MINIMIZE minimize ) # update -+ GenerateStyleHeader(${output_path} NBIN nbin ) # neighbor -+ GenerateStyleHeader(${output_path} NPAIR npair ) # neighbor -+ GenerateStyleHeader(${output_path} NSTENCIL nstencil ) # neighbor -+ GenerateStyleHeader(${output_path} NTOPO ntopo ) # neighbor -+ GenerateStyleHeader(${output_path} PAIR pair ) # force -+ GenerateStyleHeader(${output_path} READER reader ) # read_dump -+ GenerateStyleHeader(${output_path} REGION region ) # domain -+endfunction(GenerateStyleHeaders) -diff --git a/cmake/README b/cmake/README -new file mode 100644 -index 0000000000..cc67cceb52 ---- /dev/null -+++ b/cmake/README -@@ -0,0 +1,19 @@ -+cmake-buildsystem -+----------------- -+ -+To use the cmake build system instead of the make-driven one, do: -+``` -+cmake /path/to/lammps/source/cmake -+``` -+(please note the cmake directory as the very end) -+ -+To enable package, e.g. GPU do -+``` -+cmake /path/to/lammps/source/cmake -DENABLE_GPU=ON -+``` -+ -+cmake has many many options, do get an overview use the curses-based cmake interface, ccmake: -+``` -+ccmake /path/to/lammps/source/cmake -+``` -+(Don't forget to press "g" for generate once you are done with configuring) -diff --git a/cmake/gpu/lal_pppm_d.cu b/cmake/gpu/lal_pppm_d.cu -new file mode 100644 -index 0000000000..a49a535013 ---- /dev/null -+++ b/cmake/gpu/lal_pppm_d.cu -@@ -0,0 +1,4 @@ -+#define grdtyp double -+#define grdtyp4 double4 -+ -+#include "lal_pppm.cu" -diff --git a/cmake/gpu/lal_pppm_f.cu b/cmake/gpu/lal_pppm_f.cu -new file mode 100644 -index 0000000000..e7f5116fa0 ---- /dev/null -+++ b/cmake/gpu/lal_pppm_f.cu -@@ -0,0 +1,4 @@ -+#define grdtyp float -+#define grdtyp4 float4 -+ -+#include "lal_pppm.cu" |