Skip to content

Commit

Permalink
Merge branch 'master' into RemoteVerbose
Browse files Browse the repository at this point in the history
  • Loading branch information
eisenhauer authored Nov 15, 2023
2 parents 887eab6 + 3c21c37 commit 88727cb
Show file tree
Hide file tree
Showing 21 changed files with 268 additions and 83 deletions.
15 changes: 15 additions & 0 deletions .shellcheck_exclude_paths
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,18 @@ scripts/developer/setup.sh
scripts/docker/setup-user.sh
scripts/runconf/runconf.sh
scripts/runconf/runconf_olcf.sh
testing/contract/lammps/build.sh
testing/contract/lammps/config.sh
testing/contract/lammps/install.sh
testing/contract/lammps/setup.sh
testing/contract/lammps/test.sh
testing/contract/scorpio/build.sh
testing/contract/scorpio/config.sh
testing/contract/scorpio/install.sh
testing/contract/scorpio/setup.sh
testing/contract/scorpio/test.sh
testing/contract/tau/build.sh
testing/contract/tau/config.sh
testing/contract/tau/install.sh
testing/contract/tau/setup.sh
testing/contract/tau/test.sh
3 changes: 3 additions & 0 deletions examples/hello/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,9 @@ if(ADIOS2_HAVE_Kokkos_HIP)
endif()
if(ADIOS2_HAVE_Kokkos)
add_subdirectory(bpStepsWriteReadKokkos)
if(ADIOS2_HAVE_SST)
add_subdirectory(sstKokkos)
endif()
endif()

add_subdirectory(bpThreadWrite)
Expand Down
37 changes: 37 additions & 0 deletions examples/hello/sstKokkos/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
#-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- #
#Distributed under the OSI - approved Apache License, Version 2.0. See
#accompanying file Copyright.txt for details.
#-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- #

cmake_minimum_required(VERSION 3.12)
project(ADIOS2HelloSSTKokkosExample)

#CXX Compiler settings only in for this example
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

if (NOT TARGET adios2_core)
set(_components CXX)

find_package(Kokkos 3.7 QUIET)
if (Kokkos_FOUND AND DEFINED Kokkos_CXX_COMPILER)
set(CMAKE_CXX_COMPILER "${Kokkos_CXX_COMPILER}")
endif()

find_package(ADIOS2 REQUIRED COMPONENTS ${_components})
else()
if (DEFINED Kokkos_CXX_COMPILER)
set(CMAKE_CXX_COMPILER "${Kokkos_CXX_COMPILER}")
endif()
endif()

if (ADIOS2_HAVE_Kokkos)
add_executable(adios2_hello_sstWriterKokkos sstWriterKokkos.cpp)
add_executable(adios2_hello_sstReaderKokkos sstReaderKokkos.cpp)
kokkos_compilation(SOURCE sstWriterKokkos.cpp)
kokkos_compilation(SOURCE sstReaderKokkos.cpp)
target_link_libraries(adios2_hello_sstWriterKokkos adios2::cxx11 Kokkos::kokkos)
install(TARGETS adios2_hello_sstWriterKokkos RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
target_link_libraries(adios2_hello_sstReaderKokkos adios2::cxx11 Kokkos::kokkos)
install(TARGETS adios2_hello_sstReaderKokkos RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
88 changes: 88 additions & 0 deletions examples/hello/sstKokkos/sstReaderKokkos.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
/*
* Distributed under the OSI-approved Apache License, Version 2.0. See
* accompanying file Copyright.txt for details.
*
* sstReaderKokkos.cpp Simple example of reading bpFloats through ADIOS2 SST
* engine with multiple simulations steps for every IO step using Kokkos
*/
#include <ios>
#include <iostream>
#include <vector>

#include <adios2.h>
#include <adios2/cxx11/KokkosView.h>

#include <Kokkos_Core.hpp>

template <class MemSpace, class ExecSpace>
int BPRead(adios2::ADIOS &adios, const std::string fname, const size_t Nx, const size_t Ny,
const size_t nSteps, const std::string engine)
{
adios2::IO io = adios.DeclareIO("ReadIO");
io.SetEngine(engine);

ExecSpace exe_space;
std::cout << "Read on memory space: " << exe_space.name() << std::endl;

adios2::Engine bpReader = io.Open(fname, adios2::Mode::Read);

unsigned int step = 0;
bool correctValues = true;
Kokkos::View<float **, MemSpace> gpuSimData("simBuffer", Nx, Ny);
for (; bpReader.BeginStep() == adios2::StepStatus::OK; ++step)
{
auto data = io.InquireVariable<float>("bpFloats");
const adios2::Dims start{0, 0};
const adios2::Dims count{Nx, Ny};
const adios2::Box<adios2::Dims> sel(start, count);
data.SetSelection(sel);

// var.SetMemorySpace(adios2::MemorySpace::GPU);
bpReader.Get(data, gpuSimData);
bpReader.EndStep();

auto cpuData = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace{}, gpuSimData);
if (cpuData(0, 0) != step * 10)
{
std::cout << "Value mismatch at step " << step << std::endl;
correctValues = false;
break;
}
}
if (correctValues)
std::cout << "Read " << step << " steps successfully" << std::endl;

bpReader.Close();
return 0;
}

int main(int argc, char **argv)
{
const std::string engine = argv[1] ? argv[1] : "SST";
std::cout << "Using engine " << engine << std::endl;
const size_t Nx = 600, Ny = 100, nSteps = 2;
const std::string memorySpace = "Device";

const std::string filename = engine + "StepsWriteReadKokkos";
Kokkos::initialize(argc, argv);
{
adios2::ADIOS adios;

std::cout << "Using engine " << engine << std::endl;
if (memorySpace == "Device")
{
using mem_space = Kokkos::DefaultExecutionSpace::memory_space;
std::cout << "Memory space: DefaultMemorySpace" << std::endl;
BPRead<mem_space, Kokkos::DefaultExecutionSpace>(adios, filename + "_DD.bp", Nx, Ny,
nSteps, engine);
}
else
{
std::cout << "Memory space: HostSpace" << std::endl;
BPRead<Kokkos::HostSpace, Kokkos::Serial>(adios, filename + "_HH.bp", Nx, Ny, nSteps,
engine);
}
}
Kokkos::finalize();
return 0;
}
96 changes: 96 additions & 0 deletions examples/hello/sstKokkos/sstWriterKokkos.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
/*
* Distributed under the OSI-approved Apache License, Version 2.0. See
* accompanying file Copyright.txt for details.
*
* sstWriterKokkos.cpp Simple example of writing bpFloats through ADIOS2 SST
* engine with multiple simulations steps for every IO step using Kokkos
*/
#include <ios>
#include <iostream>
#include <vector>

#include <adios2.h>
#include <adios2/cxx11/KokkosView.h>

#include <Kokkos_Core.hpp>

template <class MemSpace, class ExecSpace>
int BPWrite(adios2::ADIOS &adios, const std::string fname, const size_t Nx, const size_t Ny,
const size_t nSteps, const std::string engine)
{
// Initialize the simulation data
Kokkos::View<float **, MemSpace> gpuSimData("simBuffer", Nx, Ny);
static_assert(Kokkos::SpaceAccessibility<ExecSpace, MemSpace>::accessible, "");
Kokkos::parallel_for(
"initBuffer", Kokkos::RangePolicy<ExecSpace>(0, Nx), KOKKOS_LAMBDA(int i) {
for (int j = 0; j < Ny; j++)
gpuSimData(i, j) = static_cast<float>(i);
});
Kokkos::fence();

adios2::IO io = adios.DeclareIO("WriteIO");
io.SetEngine(engine);

const adios2::Dims shape{Nx, Ny};
const adios2::Dims start{0, 0};
const adios2::Dims count{Nx, Ny};
auto data = io.DefineVariable<float>("bpFloats", shape, start, count);

adios2::Engine bpWriter = io.Open(fname, adios2::Mode::Write);

// Simulation steps
for (int step = 0; step < nSteps; ++step)
{
adios2::Box<adios2::Dims> sel({0, 0}, {Nx, Ny});
data.SetSelection(sel);

bpWriter.BeginStep();
// var.SetMemorySpace(adios2::MemorySpace::GPU);
bpWriter.Put(data, gpuSimData);
bpWriter.EndStep();

// Update values in the simulation data
Kokkos::parallel_for(
"updateBuffer", Kokkos::RangePolicy<ExecSpace>(0, Nx), KOKKOS_LAMBDA(int i) {
for (int j = 0; j < Ny; j++)
gpuSimData(i, j) += 10;
});
Kokkos::fence();
}

bpWriter.Close();
ExecSpace exe_space;
std::cout << "Done writing on memory space: " << exe_space.name() << std::endl;
return 0;
}

int main(int argc, char **argv)
{
const std::string engine = argv[1] ? argv[1] : "SST";
std::cout << "Using engine " << engine << std::endl;
const size_t Nx = 600, Ny = 100, nSteps = 2;
const std::string memorySpace = "Device";

const std::string filename = engine + "StepsWriteReadKokkos";
Kokkos::initialize(argc, argv);
{
adios2::ADIOS adios;

std::cout << "Using engine " << engine << std::endl;
if (memorySpace == "Device")
{
using mem_space = Kokkos::DefaultExecutionSpace::memory_space;
std::cout << "Memory space: DefaultMemorySpace" << std::endl;
BPWrite<mem_space, Kokkos::DefaultExecutionSpace>(adios, filename + "_DD.bp", Nx, Ny,
nSteps, engine);
}
else
{
std::cout << "Memory space: HostSpace" << std::endl;
BPWrite<Kokkos::HostSpace, Kokkos::Serial>(adios, filename + "_HH.bp", Nx, Ny, nSteps,
engine);
}
}
Kokkos::finalize();
return 0;
}
6 changes: 3 additions & 3 deletions examples/simulations/gray-scott-struct/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -43,11 +43,11 @@ if(ADIOS2_HAVE_MPI)
"simulation/settings-inline.json"
"plot/decomp.py" "plot/gsplot.py" "plot/pdfplot.py"
"ReadMe.md"
DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/examples/simulations/gray-scott-struct)
DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/gray-scott-struct)

install(DIRECTORY "catalyst" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/examples/simulations/gray-scott-struct)
install(DIRECTORY "catalyst" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/gray-scott-struct)

install(PROGRAMS "cleanup.sh" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/examples/simulations/gray-scott-struct)
install(PROGRAMS "cleanup.sh" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/gray-scott-struct)

find_package(VTK QUIET)
if(VTK_FOUND)
Expand Down
6 changes: 3 additions & 3 deletions examples/simulations/gray-scott/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -43,11 +43,11 @@ if(ADIOS2_HAVE_MPI)
"simulation/settings-inline.json"
"plot/decomp.py" "plot/gsplot.py" "plot/pdfplot.py"
"ReadMe.md"
DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/examples/simulations/gray-scott)
DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/gray-scott)

install(DIRECTORY "catalyst" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/examples/simulations/gray-scott)
install(DIRECTORY "catalyst" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/gray-scott)

install(PROGRAMS "cleanup.sh" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/examples/simulations/gray-scott)
install(PROGRAMS "cleanup.sh" DESTINATION ${CMAKE_INSTALL_PREFIX}/share/adios2/gray-scott)

find_package(VTK QUIET)
if(VTK_FOUND)
Expand Down
2 changes: 1 addition & 1 deletion examples/simulations/gray-scott/ReadMe.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ care of this aspect).
From a scratch directory copy the config files from your installation of adios2:

```
$ cp -r <adios2-install-prefix>/share/adios2/examples/simulations/gray-scott .
$ cp -r <adios2-install-prefix>/share/adios2/gray-scott .
$ cd gray-scott
$ mpirun -n 4 adios2_simulations_gray-scott settings-files.json
========================================
Expand Down
7 changes: 0 additions & 7 deletions scripts/ci/cmake/ci-el8-icc-ompi.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
include(ProcessorCount)
ProcessorCount(NCPUS)
math(EXPR N2CPUS "${NCPUS}*2")

set(ENV{CC} icc)
set(ENV{CXX} icpc)
set(ENV{FC} ifort)
Expand All @@ -28,9 +24,6 @@ CMAKE_C_FLAGS:STRING=-Wall -diag-disable=10441
CMAKE_C_FLAGS_DEBUG:STRING=-g -O0
CMAKE_CXX_FLAGS:STRING=-Wall -diag-disable=10441
CMAKE_CXX_FLAGS_DEBUG:STRING=-g -O0
MPIEXEC_EXTRA_FLAGS:STRING=--allow-run-as-root --oversubscribe
MPIEXEC_MAX_NUMPROCS:STRING=${N2CPUS}
")

set(CTEST_CMAKE_GENERATOR "Unix Makefiles")
Expand Down
7 changes: 0 additions & 7 deletions scripts/ci/cmake/ci-el8-oneapi-ompi.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
include(ProcessorCount)
ProcessorCount(NCPUS)
math(EXPR N2CPUS "${NCPUS}*2")

set(ENV{CC} icx)
set(ENV{CXX} icpx)
set(ENV{FC} ifort) # oneapi fortran compiler currently has issues
Expand Down Expand Up @@ -29,9 +25,6 @@ CMAKE_C_FLAGS_DEBUG:STRING=-g -O0
CMAKE_CXX_FLAGS:STRING=-Wall
CMAKE_CXX_FLAGS_DEBUG:STRING=-g -O0
CMAKE_Fortran_FLAGS:STRING=-W1
MPIEXEC_EXTRA_FLAGS:STRING=--allow-run-as-root --oversubscribe
MPIEXEC_MAX_NUMPROCS:STRING=${N2CPUS}
")

set(CTEST_CMAKE_GENERATOR "Unix Makefiles")
Expand Down
7 changes: 0 additions & 7 deletions scripts/ci/cmake/ci-ubuntu20.04-clang10-ompi.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
include(ProcessorCount)
ProcessorCount(NCPUS)
math(EXPR N2CPUS "${NCPUS}*2")

set(ENV{CC} clang-10)
set(ENV{CXX} clang++-10)
set(ENV{FC} gfortran-11)
Expand Down Expand Up @@ -35,9 +31,6 @@ CMAKE_CXX_COMPILER_LAUNCHER=ccache
CMAKE_C_FLAGS:STRING=-Wall
CMAKE_CXX_FLAGS:STRING=-Wall
CMAKE_Fortran_FLAGS:STRING=-Wall
MPIEXEC_EXTRA_FLAGS:STRING=--allow-run-as-root --oversubscribe
MPIEXEC_MAX_NUMPROCS:STRING=${N2CPUS}
")

set(CTEST_CMAKE_GENERATOR "Ninja")
Expand Down
7 changes: 0 additions & 7 deletions scripts/ci/cmake/ci-ubuntu20.04-clang6-ompi.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
include(ProcessorCount)
ProcessorCount(NCPUS)
math(EXPR N2CPUS "${NCPUS}*2")

set(ENV{CC} clang-6.0)
set(ENV{CXX} clang++-6.0)
set(ENV{FC} gfortran-11)
Expand Down Expand Up @@ -36,9 +32,6 @@ CMAKE_CXX_COMPILER_LAUNCHER=ccache
CMAKE_C_FLAGS:STRING=-Wall
CMAKE_CXX_FLAGS:STRING=-Wall
CMAKE_Fortran_FLAGS:STRING=-Wall
MPIEXEC_EXTRA_FLAGS:STRING=--allow-run-as-root --oversubscribe
MPIEXEC_MAX_NUMPROCS:STRING=${N2CPUS}
")

# We have a dedicated build for this setup without MPI
Expand Down
7 changes: 0 additions & 7 deletions scripts/ci/cmake/ci-ubuntu20.04-clang6-static-ompi.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
include(ProcessorCount)
ProcessorCount(NCPUS)
math(EXPR N2CPUS "${NCPUS}*2")

set(ENV{CC} clang-6.0)
set(ENV{CXX} clang++-6.0)
set(ENV{FC} gfortran-11)
Expand Down Expand Up @@ -37,9 +33,6 @@ CMAKE_CXX_COMPILER_LAUNCHER=ccache
CMAKE_C_FLAGS:STRING=-Wall
CMAKE_CXX_FLAGS:STRING=-Wall
CMAKE_Fortran_FLAGS:STRING=-Wall
MPIEXEC_EXTRA_FLAGS:STRING=--allow-run-as-root --oversubscribe
MPIEXEC_MAX_NUMPROCS:STRING=${N2CPUS}
")

set(CTEST_CMAKE_GENERATOR "Ninja")
Expand Down
7 changes: 0 additions & 7 deletions scripts/ci/cmake/ci-ubuntu20.04-gcc10-ompi.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
include(ProcessorCount)
ProcessorCount(NCPUS)
math(EXPR N2CPUS "${NCPUS}*2")

set(ENV{CC} gcc)
set(ENV{CXX} g++)
set(ENV{FC} gfortran)
Expand Down Expand Up @@ -35,9 +31,6 @@ CMAKE_CXX_COMPILER_LAUNCHER=ccache
CMAKE_C_FLAGS:STRING=-Wall
CMAKE_CXX_FLAGS:STRING=-Wall
CMAKE_Fortran_FLAGS:STRING=-Wall
MPIEXEC_EXTRA_FLAGS:STRING=--allow-run-as-root --oversubscribe
MPIEXEC_MAX_NUMPROCS:STRING=${N2CPUS}
")

# We have a dedicated build for this setup without MPI
Expand Down
Loading

0 comments on commit 88727cb

Please sign in to comment.