Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Eliminate deprecated find_package(CUDA) from qmcpack #3492

Merged
merged 19 commits into from
Oct 1, 2021

Conversation

quantumsteve
Copy link
Contributor

@quantumsteve quantumsteve commented Sep 29, 2021

Please review the developer documentation
on the wiki of this project that contains help and requirements.

Proposed changes

Describe what this PR changes and why. If it closes an issue, link to it here
with a supported keyword.

This replaces find_package(CUDA) with first-class language support and find_package(CUDAToolkit).

On Ubuntu 20.04 and CUDA HPC SDK 21.7, I have to manually set the math libraries and headers. This appears to be fixed in CMake master https://gitlab.kitware.com/cmake/cmake/-/merge_requests/6405

On sulfur, I am encountering ABI issues between the old copy-on-write and small string optimized std::string. I assume it's a configuration issue on my part, but haven't tracked down where this is coming from and would like to run the tests here to confirm.

What documentation needs to be changed?

Fixes #3460

What type(s) of changes does this code introduce?

Delete the items that do not apply

  • Build related changes

Does this introduce a breaking change?

  • No

What systems has this change been tested on?

Checklist

Update the following with a yes where the items apply. If you're unsure about any of them, don't hesitate to ask. This is
simply a reminder of what we are going to look for before merging your code.

  • Yes. This PR is up to date with current the current state of 'develop'
  • Yes/No. Documentation has been added (if appropriate)

Replace it with first-class language support and find_package(CUDAToolkit)

Signed-off-by: Steven Hahn <hahnse@ornl.gov>
@quantumsteve quantumsteve requested a review from ye-luo September 29, 2021 17:54
@qmc-robot
Copy link

Can one of the admins verify this patch?

Signed-off-by: Steven Hahn <hahnse@ornl.gov>
CMakeLists.txt Outdated Show resolved Hide resolved
CMakeLists.txt Outdated Show resolved Hide resolved
src/Platforms/CUDA/CMakeLists.txt Outdated Show resolved Hide resolved
src/Platforms/CUDA/CMakeLists.txt Outdated Show resolved Hide resolved
src/Platforms/CUDA_legacy/CMakeLists.txt Outdated Show resolved Hide resolved
CMakeLists.txt Outdated Show resolved Hide resolved
CMakeLists.txt Outdated Show resolved Hide resolved
Signed-off-by: Steven Hahn <hahnse@ornl.gov>
@ye-luo
Copy link
Contributor

ye-luo commented Sep 29, 2021

Test this please

@correaa correaa changed the title Eliminate depricated find_package(CUDA) from qmcpack Eliminate deprecated find_package(CUDA) from qmcpack Sep 29, 2021
@ye-luo
Copy link
Contributor

ye-luo commented Sep 29, 2021

Test this please

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

Test this please

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

Test this please

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

In the case of NVHPC, I used CUDAToolkit_ROOT pointing to an standalone installation.

@quantumsteve
Copy link
Contributor Author

In the case of NVHPC, I used CUDAToolkit_ROOT pointing to an standalone installation.

That worked well for CMake configuration/generation, but get errors about missing cublas headers.

On my machine (Ubuntu 20.04, NVHPC 21.7) I had to add `"${CUDAToolkit_INCLUDE_DIRS}/../../../../../math_libs/include" as an additional include directory.

@prckent
Copy link
Contributor

prckent commented Sep 30, 2021

Please verify that this works with Summit's modules, software configuration etc.

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

@quantumsteve could you try again the current branch and paste what "errors about missing cublas headers." are. I'm afraid of missing/incorrect dependencies.

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

@prckent update to Summit build recipes has been included in the last commit.

@quantumsteve
Copy link
Contributor Author

@quantumsteve could you try again the current branch and paste what "errors about missing cublas headers." are. I'm afraid of missing/incorrect dependencies.

[125/663] Building CXX object src/QMCWaveFunctions/CMakeFiles/qmcwfs.dir/ElectronGas/ElectronGasOrbitalBuilder.cpp.o
FAILED: src/QMCWaveFunctions/CMakeFiles/qmcwfs.dir/ElectronGas/ElectronGasOrbitalBuilder.cpp.o 
/usr/bin/c++ -DADD_ -DH5_USE_16_API -DHAVE_CONFIG_H -DHAVE_EINSPLINE -DHAVE_LIBBOOST -DHAVE_LIBFFTW -DHAVE_LIBHDF5 -DOPENMP_NO_COMPLEX -DUSE_REAL_STRUCT_FACTOR -Drestrict=__restrict__ -I/home/svh/Documents/qmcpack/build/src -I/home/svh/Documents/qmcpack/src -I/home/svh/Documents/qmcpack/external_codes/boost_multi -I/home/svh/Documents/qmcpack/src/QMCWaveFunctions -I/home/svh/Documents/qmcpack/src/Particle -I/home/svh/Documents/qmcpack/src/Numerics -I/home/svh/Documents/qmcpack/src/io -I/home/svh/Documents/qmcpack/src/Containers -I/home/svh/Documents/qmcpack/src/Platforms -I/home/svh/Documents/qmcpack/src/Utilities -isystem /opt/nvidia/hpc_sdk/Linux_x86_64/21.7/cuda/11.4/include -isystem /usr/include/hdf5/serial -isystem /usr/include/libxml2 -fopenmp -finline-limit=1000 -fstrict-aliasing -funroll-all-loops -Wno-deprecated -Wvla -Wcomment -Wmisleading-indentation -Wmaybe-uninitialized -Wuninitialized -Wreorder -Wno-unknown-pragmas -Wno-sign-compare -Wsuggest-override -ffast-math -march=native -O3 -DNDEBUG -std=c++17 -MD -MT src/QMCWaveFunctions/CMakeFiles/qmcwfs.dir/ElectronGas/ElectronGasOrbitalBuilder.cpp.o -MF src/QMCWaveFunctions/CMakeFiles/qmcwfs.dir/ElectronGas/ElectronGasOrbitalBuilder.cpp.o.d -o src/QMCWaveFunctions/CMakeFiles/qmcwfs.dir/ElectronGas/ElectronGasOrbitalBuilder.cpp.o -c /home/svh/Documents/qmcpack/src/QMCWaveFunctions/ElectronGas/ElectronGasOrbitalBuilder.cpp
In file included from /home/svh/Documents/qmcpack/src/QMCWaveFunctions/Fermion/DelayedUpdateCUDA.h:19,
                 from /home/svh/Documents/qmcpack/src/QMCWaveFunctions/Fermion/DiracDeterminant.h:28,
                 from /home/svh/Documents/qmcpack/src/QMCWaveFunctions/Fermion/DiracDeterminantWithBackflow.h:24,
                 from /home/svh/Documents/qmcpack/src/QMCWaveFunctions/Fermion/SlaterDetWithBackflow.h:18,
                 from /home/svh/Documents/qmcpack/src/QMCWaveFunctions/ElectronGas/ElectronGasOrbitalBuilder.cpp:23:
/home/svh/Documents/qmcpack/src/Platforms/CUDA/cuBLAS.hpp:22:10: fatal error: cublas_v2.h: No such file or directory
   22 | #include <cublas_v2.h>
      |          ^~~~~~~~~~~~~
compilation terminated.

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

diff --git a/src/Platforms/CUDA/CMakeLists.txt b/src/Platforms/CUDA/CMakeLists.txt
index f84c63ee1..ca1dd0092 100644
--- a/src/Platforms/CUDA/CMakeLists.txt
+++ b/src/Platforms/CUDA/CMakeLists.txt
@@ -16,7 +16,7 @@ if(NOT QMC_CUDA2HIP)
   add_library(platform_cuda_runtime ${CUDA_RT_SRCS})
   target_link_libraries(platform_cuda_runtime PUBLIC CUDA::cudart)
   add_library(platform_cuda_LA ${CUDA_LA_SRCS})
-  target_link_libraries(platform_cuda_LA PRIVATE CUDA::cublas CUDA::cusolver)
+  target_link_libraries(platform_cuda_LA PUBLIC CUDA::cublas CUDA::cusolver)
 else()
   hip_add_library(platform_cuda_runtime ${CUDA_RT_SRCS})
   target_link_libraries(platform_cuda_LA PUBLIC platform_rocm_LA)
@@ -24,4 +24,4 @@ else()
   target_link_libraries(platform_cuda_runtime PUBLIC platform_rocm_runtime)
 endif()
 
-target_link_libraries(platform_cuda_LA PRIVATE platform_cuda_runtime)
+target_link_libraries(platform_cuda_LA PUBLIC platform_cuda_runtime)
yeluo@epyc-server:~/opt/cleanup/qmcpack$ 

Try this.

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

Regarding docs. CUDA_ARCH to CMAKE_CUDA_ARCHITECTURES is the most notable change.

@prckent
Copy link
Contributor

prckent commented Sep 30, 2021

Thanks @ye-luo Re: Summit. I was expecting more weirdness.

The manual might need updating.

The scripts for the nightlies presumably will as well, but we (I) can fix those after this is in.

@quantumsteve
Copy link
Contributor Author

diff --git a/src/Platforms/CUDA/CMakeLists.txt b/src/Platforms/CUDA/CMakeLists.txt
index f84c63ee1..ca1dd0092 100644
--- a/src/Platforms/CUDA/CMakeLists.txt
+++ b/src/Platforms/CUDA/CMakeLists.txt
@@ -16,7 +16,7 @@ if(NOT QMC_CUDA2HIP)
   add_library(platform_cuda_runtime ${CUDA_RT_SRCS})
   target_link_libraries(platform_cuda_runtime PUBLIC CUDA::cudart)
   add_library(platform_cuda_LA ${CUDA_LA_SRCS})
-  target_link_libraries(platform_cuda_LA PRIVATE CUDA::cublas CUDA::cusolver)
+  target_link_libraries(platform_cuda_LA PUBLIC CUDA::cublas CUDA::cusolver)
 else()
   hip_add_library(platform_cuda_runtime ${CUDA_RT_SRCS})
   target_link_libraries(platform_cuda_LA PUBLIC platform_rocm_LA)
@@ -24,4 +24,4 @@ else()
   target_link_libraries(platform_cuda_runtime PUBLIC platform_rocm_runtime)
 endif()
 
-target_link_libraries(platform_cuda_LA PRIVATE platform_cuda_runtime)
+target_link_libraries(platform_cuda_LA PUBLIC platform_cuda_runtime)
yeluo@epyc-server:~/opt/cleanup/qmcpack$ 

Try this.

No change. I was able to build with the following change to FindCUDAToolkit.cmake

diff --git a/Modules/FindCUDAToolkit.cmake b/Modules/FindCUDAToolkit.cmake
index 92042d23c4..6f0fa47666 100644
--- a/Modules/FindCUDAToolkit.cmake
+++ b/Modules/FindCUDAToolkit.cmake
@@ -853,7 +853,7 @@ if(CUDAToolkit_FOUND)
 
     if (NOT TARGET CUDA::${lib_name} AND CUDA_${lib_name}_LIBRARY)
       add_library(CUDA::${lib_name} UNKNOWN IMPORTED)
-      target_include_directories(CUDA::${lib_name} SYSTEM INTERFACE "${CUDAToolkit_INCLUDE_DIRS}")
+      target_include_directories(CUDA::${lib_name} SYSTEM INTERFACE "${CUDAToolkit_INCLUDE_DIRS}" "${CUDAToolkit_INCLUDE_DIRS}/../../../../../math_libs/include")
       set_property(TARGET CUDA::${lib_name} PROPERTY IMPORTED_LOCATION "${CUDA_${lib_name}_LIBRARY}")
       foreach(dep ${arg_DEPS})
         if(TARGET CUDA::${dep})

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

I was confused by your earlier message. Here is my understanding.

With all the released CMake, CUDA accelerated math libraries shipped inside NVHPC are not well handled by FindCUDAToolkit. In this case, I recommend using CUDAToolkit_ROOT pointing to a standalone CUDA toolkit installation. It is not worth teaching FindCUDAToolkit how to use NVHPC internally shipped CUDA toolkit.
${CUDAToolkit_INCLUDE_DIRS}/../../../../../math_libs/include is only valid for NVHPC internally shipped CUDA toolkit. It should not be needed when CUDAToolkit_ROOT pointing to a standalone CUDA toolkit installation.

Once 3.22 is release, NVHPC shipped CUDA toolkit will be recognized by FindCUDAToolkit.

@quantumsteve
Copy link
Contributor Author

quantumsteve commented Sep 30, 2021

Once 3.22 is release, NVHPC shipped CUDA toolkit will be recognized by FindCUDAToolkit.

CMake master branch is still broken. I created an issue on CMake gitlab.

I'll reinstall the standalone toolkit locally so these NVHPC issues don't affect me.

edit: updating my PATH and LD_LIBRARY_PATH variables was sufficient.

before:

NVARCH=`uname -s`_`uname -m`; export NVARCH
NVCOMPILERS=/opt/nvidia/hpc_sdk; export NVCOMPILERS
MANPATH=$MANPATH:$NVCOMPILERS/$NVARCH/21.7/compilers/man; export MANPATH
PATH=$NVCOMPILERS/$NVARCH/21.7/compilers/bin:$PATH; export PATH

export PATH=$NVCOMPILERS/$NVARCH/21.7/comm_libs/mpi/bin:$PATH
export MANPATH=$MANPATH:$NVCOMPILERS/$NVARCH/21.7/comm_libs/mpi/man

after:

export PATH=/usr/local/cuda-11.4/bin${PATH:+:${PATH}}
export LD_LIBRARY_PATH=/usr/local/cuda-11.4/lib64${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}}

Signed-off-by: Steven Hahn <hahnse@ornl.gov>
Signed-off-by: Steven Hahn <hahnse@ornl.gov>
@markdewing
Copy link
Contributor

This change appears to require more effort to get the right CUDA binaries and include files.
My laptop is Ubuntu 18.04, and the default cuda install is 9.1. I have newer CUDA versions installed in /usr/local/cuda-*.*
I'm using a recent mainline build of llvm for the offload compiler.

Prior to this change, I used the configuration (just the CUDA relevant ones are shown):

-DCUDA_TOOLKIT_ROOT_DIR=/usr/local/cuda-11.3 \
-DCUDA_HOST_COMPILER=`which gcc` \
-DCMAKE_CXX_FLAGS="-I/usr/local/cuda-11.3/include" \
-DENABLE_OFFLOAD=1 \
-DENABLE_CUDA=1 \

To use this PR, the configuration options are

-DCMAKE_CUDA_ARCHITECTURES=61 \
-DCUDAToolkit_ROOT=/usr/local/cuda-11.3 \
-DCMAKE_CXX_FLAGS="-I/usr/local/cuda-11.3/include" \
-DENABLE_OFFLOAD=1 \
-DENABLE_CUDA=1 \

The first problem was it picked up the system nvcc. I changed the path to include /usr/local/cuda-11.3/bin, and it picked up the right nvcc.
But now it appears to be getting the wrong CUDA include file, as in the error below. The right cuda include directory is already given using CMAKE_CXX_FLAGS - I'm not sure how to get it to use the right one.

In file included from /home/mdewing/physics/codes/qmcpack/github/qmcpack/src/QMCWaveFunctions/tests/test_cuBLAS_LU.cpp:18:
/home/mdewing/physics/codes/qmcpack/github/qmcpack/src/Platforms/CUDA/cuBLAS.hpp:253:10: error: no matching function for call to 'cublasSgemmBatched'
  return cublasSgemmBatched(handle, transa, transb, m, n, k, alpha, A, lda, B, ldb, beta, C, ldc, batchCount);
         ^~~~~~~~~~~~~~~~~~
/usr/include/cublas_api.h:2308:39: note: candidate function not viable: 8th argument ('const float *const *') would lose const qualifier
CUBLASAPI cublasStatus_t CUBLASWINAPI cublasSgemmBatched (cublasHandle_t handle,
                                      ^

I'm not certain the previous configuration (develop) works because with the llvm build I have, it crashes in the compiler during compilation.

@PDoakORNL
Copy link
Contributor

I don't think we should have to set the cuda include path by hand, infact that breaks the way the CUDA::xxx targets should work. If a targets dependency on the CUDA targets is expressed properly through its target_link_libraries and possibly its link libaries target_link_libraries the include directory should match the version linked without fail.

@ye-luo
Copy link
Contributor

ye-luo commented Sep 30, 2021

@markdewing does patch #3492 (comment) work?
CUDAToolkit_ROOT not getting honored is the root of the issue. What is your cmake printout? It should say something about what CUDA being picked up.

@quantumsteve
Copy link
Contributor Author

@markdewing
What is the value of CUDAToolkit_INCLUDE_DIRS?

Does changing find_package(CUDAToolkit REQUIRED) to find_package(CUDAToolkit 11.3 REQUIRED) make any difference?

@markdewing
Copy link
Contributor

markdewing commented Oct 1, 2021

Turns out it was the added include directory that was causing the problem. (-DCMAKE_CXX_FLAGS="-I/usr/local/cuda-11.3/include") It was something I added sometime to fix some problem (NVTX api maybe?), and just left it there. It still seems odd that its presence would have such a large effect.

@ye-luo
Copy link
Contributor

ye-luo commented Oct 1, 2021

Test this please

@ye-luo
Copy link
Contributor

ye-luo commented Oct 1, 2021

This PR is ready to be merged except I need to fix a minor scripting issue. If there is no other concerns, I'd like to merge it this afternoon.

@ye-luo
Copy link
Contributor

ye-luo commented Oct 1, 2021

Test this please

@prckent prckent enabled auto-merge October 1, 2021 16:23
@prckent
Copy link
Contributor

prckent commented Oct 1, 2021

Is it expected that any changes will be needed to the nightly scripts?

@ye-luo
Copy link
Contributor

ye-luo commented Oct 1, 2021

Is it expected that any changes will be needed to the nightly scripts?

yeluo@ryzen-box:~/opt/qmcpack/tests/test_automation/nightly_test_scripts$ grep CUDA_ *
nightly_anl_bora.sh:    CTEST_FLAGS="$CTEST_FLAGS -DQMC_OPTIONS='-DENABLE_OFFLOAD=ON;-DUSE_OBJECT_TARGET=ON;-DCUDA_HOST_COMPILER=`which gcc`;-DCUDA_PROPAGATE_HOST_FLAGS=OFF;-DQMC_NIO_MAX_SIZE=16'"
nightly_anl_bora.sh:    CTEST_FLAGS="$CTEST_FLAGS -DENABLE_CUDA=1 -DCUDA_ARCH=sm_61"
nightly_anl_bora.sh:    CTEST_FLAGS="$CTEST_FLAGS -DENABLE_CUDA=1 -DCUDA_ARCH=sm_61 -DQMC_OPTIONS='-DQMC_NIO_MAX_SIZE=16'"
nightly_anl_bora.sh:    CTEST_FLAGS="$CTEST_FLAGS -DQMC_CUDA=1 -DCUDA_ARCH=sm_61 -DQMC_OPTIONS='-DQMC_NIO_MAX_SIZE=16'"
nightly_ornl.sh:        CTCFG="$CTCFG -DCMAKE_CXX_FLAGS=-Wno-unknown-cuda-version -DQMC_OPTIONS='-DENABLE_OFFLOAD=ON;-DUSE_OBJECT_TARGET=ON;-DENABLE_CUDA=ON;-DCUDA_ARCH=sm_70;-DCUDA_HOST_COMPILER=`which gcc`'"
nightly_ornl.sh:#export CUDA_VISIBLE_DEVICES=
weekly_ornl.sh:        CTCFG="$CTCFG -DCMAKE_CXX_FLAGS=-Wno-unknown-cuda-version -DQMC_OPTIONS='-DENABLE_OFFLOAD=ON;-DUSE_OBJECT_TARGET=ON;-DENABLE_CUDA=ON;-DCUDA_ARCH=sm_70;-DCUDA_HOST_COMPILER=`which gcc`'"
weekly_ornl.sh:#export CUDA_VISIBLE_DEVICES=

Needs update as
CUDA_ARCH -> CMAKE_CUDA_ARCHITECTURES
CUDA_HOST_COMPILER -> CMAKE_CUDA_HOST_COMPILER

@prckent
Copy link
Contributor

prckent commented Oct 1, 2021

Scripts are now updated. Tests that actually run will be limited due to the recent+unsolved by me cmake/ctest/scripting breakage.

@prckent prckent merged commit 7ee1a1d into QMCPACK:develop Oct 1, 2021
This was referenced Oct 1, 2021
PDoakORNL added a commit to PDoakORNL/qmcpack that referenced this pull request Oct 6, 2021
commit 22cc717
Author: Peter Doak <doakpw@ornl.gov>
Date:   Wed Oct 6 13:05:22 2021 -0400

    propagating mw_invertPsiM const API changes

commit fea01c4
Merge: 4e8b3f4 f7874e4
Author: Peter Doak <doakpw@ornl.gov>
Date:   Wed Oct 6 12:38:07 2021 -0400

    Merge branch 'develop' into matrix_update_engines_direct_2

commit f7874e4
Merge: 319938f 3a1fc75
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Oct 6 10:57:22 2021 -0500

    Merge pull request QMCPACK#3514 from ye-luo/fix-omp-nocuda

    Fix omp offload without cuda

commit 3a1fc75
Merge: 4b2ef72 319938f
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 21:49:12 2021 -0500

    Merge branch 'develop' into fix-omp-nocuda

commit 319938f
Merge: c093820 1a71e25
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 21:27:24 2021 -0500

    Merge pull request QMCPACK#3510 from camelto2/dirac_converter_msd

    Dirac converter with MSD wave functions

commit 4b2ef72
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 20:43:26 2021 -0500

    Mark all the RefVector const.

commit 3191d09
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 20:38:22 2021 -0500

    Revert integration with DiracMatrixComputeOMPTarget

commit 1a71e25
Merge: 9414af2 c093820
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 18:36:14 2021 -0500

    Merge branch 'develop' into dirac_converter_msd

commit 9414af2
Author: camelto2 <cmelton@sandia.gov>
Date:   Tue Oct 5 17:28:37 2021 -0600

    fix libxml leak

commit c093820
Merge: 132b560 309afa1
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 16:55:34 2021 -0500

    Merge pull request QMCPACK#3513 from quantumsteve/available_supported

    cif2cell_supported not set

commit 309afa1
Merge: 94b98f5 132b560
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 15:51:21 2021 -0500

    Merge branch 'develop' into available_supported

commit 132b560
Merge: 67490d9 486884f
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 15:28:08 2021 -0500

    Merge pull request QMCPACK#3512 from ye-luo/fix-StlPrettyPrint

    Collapsed style in StlPrettyPrint.

commit 94b98f5
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Tue Oct 5 15:02:00 2021 -0400

    copy/paste error

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit 486884f
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 13:47:02 2021 -0500

    Remove unused header inclusion.

commit a468c4a
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 01:12:10 2021 -0500

    Collapsed style in StlPrettyPrint.

commit 67490d9
Merge: aca1bf6 4ea1d47
Author: Ye Luo <yeluo@anl.gov>
Date:   Tue Oct 5 12:22:50 2021 -0500

    Merge pull request QMCPACK#3511 from quantumsteve/cif2cell_available

    Check if cif2cell is available before running ntest_nexus_structure

commit 4ea1d47
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Tue Oct 5 11:02:22 2021 -0400

    Add Python 3.10.0

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit 20d2e84
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Tue Oct 5 10:03:43 2021 -0400

    Check if cif2cell is available before running test

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit bbfe24f
Author: camelto2 <cmelton@sandia.gov>
Date:   Mon Oct 4 16:09:36 2021 -0600

    fix uninnitialized warning

commit ee35c16
Author: camelto2 <cmelton@sandia.gov>
Date:   Mon Oct 4 14:51:18 2021 -0600

    remove unused code in DiracParser

commit 0983b0a
Author: camelto2 <cmelton@sandia.gov>
Date:   Mon Oct 4 14:18:26 2021 -0600

    update manual entry for convert4qmc with DIRAC

commit 8e064a0
Author: camelto2 <cmelton@sandia.gov>
Date:   Mon Oct 4 14:11:11 2021 -0600

    clang formatting

commit 806d493
Author: camelto2 <cmelton@sandia.gov>
Date:   Mon Oct 4 14:04:21 2021 -0600

    update unit and converter tests to reflect changes in MSD for dirac

    I updated the gold.orbs.h5 to use convert4qmc -dirac df_Bi.out -TargetState 14 -prefix gold -nojastrow
    This tests the converter to make sure it can grab an arbitrary excited state to store in the hdf5.
    However, this change made it so that I needed to update the multi_slater unit tests, which relied
    on this gold.orbs.h5 file. Also, added to the unit test is reading the CI coeffs directly from the h5 file

commit 3c48afd
Merge: a4ebddb aca1bf6
Author: camelto2 <cmelton@sandia.gov>
Date:   Mon Oct 4 09:30:53 2021 -0600

    Merge remote-tracking branch 'upstream/develop' into dirac_converter_msd

commit aca1bf6
Merge: 618cdb2 2318723
Author: Paul R. C. Kent <kentpr@ornl.gov>
Date:   Sun Oct 3 13:02:42 2021 -0400

    Merge pull request QMCPACK#3505 from anbenali/Convert4qmcGuessH5Format

    Convert4qmc guess h5 format

commit 2318723
Author: Anouar Benali <abenali.sci@gmail.com>
Date:   Sun Oct 3 01:09:41 2021 -0500

    fixing passing an hdf5 file without the -orbitals tag. closing bug # QMCPACK#3503

commit 273ecb0
Author: Anouar Benali <abenali.sci@gmail.com>
Date:   Sat Oct 2 23:57:51 2021 -0500

    Change default behavior of convert4qmc: Will only generate inputs with Jastrows unless -nojastrow is specified, then only inputs with no jastrow will be generated

commit 618cdb2
Merge: c0ed5f1 0a13c01
Author: Paul R. C. Kent <kentpr@ornl.gov>
Date:   Sat Oct 2 13:32:16 2021 -0400

    Merge pull request QMCPACK#3502 from ye-luo/fix-nightly

    Fix and update nightly test scripts.

commit 0a13c01
Author: Ye Luo <yeluo@anl.gov>
Date:   Sat Oct 2 11:29:44 2021 -0500

    Fix and update nightly test scripts.

commit c0ed5f1
Merge: 4b9b609 b7ce2c8
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 18:33:06 2021 -0500

    Merge pull request QMCPACK#3501 from ye-luo/fix-hip

    Fix HIP CMake

commit b7ce2c8
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 17:27:49 2021 -0500

    Fix HIP CMake.

commit 4b9b609
Merge: 91fa888 4042431
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 15:37:41 2021 -0500

    Merge pull request QMCPACK#3489 from prckent/ppconvertcmakeclean

    Fix ppconvert memory bugs and enable in testing

commit 4042431
Merge: d48bd76 91fa888
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 14:37:23 2021 -0500

    Merge remote-tracking branch 'origin/develop' into ppconvertcmakeclean

commit d48bd76
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 14:37:06 2021 -0500

    Update README.md about CUDA_ARCH

commit 91fa888
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Wed Sep 29 11:10:37 2021 -0400

    Add docs for macOS CI

commit fe5aa2d
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Wed Sep 29 09:46:20 2021 -0400

    Add Python dependencies on macOS runner

commit 60724b9
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Tue Sep 28 17:06:13 2021 -0400

    Reduce brew dependencies

commit 72d4c01
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Tue Sep 28 16:39:07 2021 -0400

    Add macOS CI on GitHub Actions

    gcc-11 real build
    brew dependencies

commit 7ee1a1d
Merge: d008890 a4bb505
Author: Paul R. C. Kent <kentpr@ornl.gov>
Date:   Fri Oct 1 13:37:48 2021 -0400

    Merge pull request QMCPACK#3492 from quantumsteve/cudatoolkit

    Eliminate deprecated find_package(CUDA) from qmcpack

commit a4ebddb
Author: camelto2 <cmelton@sandia.gov>
Date:   Fri Oct 1 10:43:24 2021 -0600

    fix for spinors in h5 and xml for MSD

commit a4bb505
Merge: d947ca1 d008890
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 12:08:40 2021 -0400

    Merge remote-tracking branch 'origin/develop' into cudatoolkit

commit d947ca1
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 12:08:26 2021 -0400

    Update build_olcf_summit_Clang.sh

commit d008890
Merge: a556925 d546e4e
Author: Ye Luo <yeluo@anl.gov>
Date:   Fri Oct 1 11:08:04 2021 -0500

    Merge pull request QMCPACK#3498 from ye-luo/opt-J2

    Fix and optimize offload J2

commit 3884a95
Author: camelto2 <cmelton@sandia.gov>
Date:   Thu Sep 30 22:27:46 2021 -0600

    correct MSD xml generated

commit d546e4e
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 22:19:53 2021 -0500

    Minimize recompute in J2.

commit 517dea7
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 01:14:49 2021 -0500

    Cure non-determinisitic offload J2.

    Reproducer:
    NiO a64 batched_driver performance test. Run 1 VMC step with 1 thread over and over.
    The scalar.dat is not deterministic. Kinetic is different.
    mw_updateVGL. Inject print before and after the offload region. walker 13 and electron 741.
    Sometimes the value is not updated even if a walker is accepted.

commit 587634d
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 19:10:31 2021 -0500

    Update installation.rst

commit f8ed8db
Merge: fe7fba7 a556925
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 19:01:19 2021 -0500

    Merge remote-tracking branch 'origin/develop' into cudatoolkit

commit fe7fba7
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 19:00:23 2021 -0500

    Allow OFFLOAD_ARCH not being set for NVHPC.

commit a9e69a1
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 18:43:55 2021 -0500

    Make NVHPC support CMAKE_CUDA_ARCHITECTURES as a list.

commit be7893e
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 16:58:44 2021 -0500

    Our header only wrappers needs cuda include path.

commit 9b36461
Merge: 575ea73 34953ef
Author: camelto2 <cmelton@sandia.gov>
Date:   Thu Sep 30 14:38:47 2021 -0600

    Merge remote-tracking branch 'upstream/develop' into dirac_converter_msd

commit 575ea73
Author: camelto2 <cmelton@sandia.gov>
Date:   Thu Sep 30 14:37:43 2021 -0600

    enable complete open shell CI parsing for DIRAC converter

commit 8f1b5af
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Thu Sep 30 16:30:05 2021 -0400

    update documentation

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit afd2294
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Thu Sep 30 16:06:50 2021 -0400

    Check LLVM offload only contains one architecture

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit 3ca4e31
Merge: 3ba75e9 b5571ec
Author: Paul R. C. Kent <kentpr@ornl.gov>
Date:   Thu Sep 30 14:51:29 2021 -0400

    Merge pull request #1 from williamfgc/ppconvertcmakeclean-fix-leaks

    Ppconvertcmakeclean fix memory leaks

commit b5571ec
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Thu Sep 30 13:46:49 2021 -0400

    Revert clang-format related changes

commit 9b2e2fb
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Thu Sep 30 11:47:07 2021 -0400

    Fix leaks associated with Grid raw pointer

    Use std::shared_ptr to enable copy constructors

commit 216d9dd
Author: William F Godoy <williamfgc@yahoo.com>
Date:   Thu Sep 30 10:47:27 2021 -0400

    Address leaks in XMLWriterClass

    Use std::shared_ptr to allow for deep copy constructors

commit 058e446
Author: Ye Luo <yeluo@anl.gov>
Date:   Thu Sep 30 10:06:18 2021 -0400

    Update recipes under config for CUDA change.

commit b39aea6
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Sep 29 19:06:57 2021 -0500

    Set CMAKE_CUDA_ARCHITECTURES early.

commit ebf7849
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Sep 29 19:02:47 2021 -0500

    Make platform_cuda_legacy depend on CUDA::cudart

commit 81457ad
Merge: 57e55d3 ed14d86
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Sep 29 17:52:01 2021 -0500

    Merge remote-tracking branch 'origin/develop' into cudatoolkit

commit 57e55d3
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Sep 29 17:30:50 2021 -0500

    Set back CUDA default to C++14.

commit 734415c
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Sep 29 17:24:08 2021 -0500

    CMAKE_CUDA_ARCHITECTURES needs CMake 3.18.

commit 707977e
Author: Ye Luo <yeluo@anl.gov>
Date:   Wed Sep 29 17:22:44 2021 -0500

    More accurate stopper message.

commit 761745b
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Wed Sep 29 17:36:10 2021 -0400

    Apply changes recommended by @ye-lou.

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit b607510
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Wed Sep 29 15:06:19 2021 -0400

    Don't change required CMake version

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit ed13bd8
Author: Steven Hahn <hahnse@ornl.gov>
Date:   Fri Sep 24 10:47:26 2021 -0400

    Eliminate depricated find_package(CUDA) from qmcpack

    Replace it with first-class language support and find_package(CUDAToolkit)

    Signed-off-by: Steven Hahn <hahnse@ornl.gov>

commit 3ba75e9
Author: Paul Kent <kentpr@ornl.gov>
Date:   Tue Sep 28 22:04:05 2021 -0400

    Test label

commit dc39dba
Author: Paul Kent <kentpr@ornl.gov>
Date:   Tue Sep 28 21:55:32 2021 -0400

    Try public in cmake
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Transition CMake CUDA support to use FindCUDAToolkit
6 participants