Skip to content

Latest commit

 

History

History
82 lines (69 loc) · 2.99 KB

README.md

File metadata and controls

82 lines (69 loc) · 2.99 KB

Morpheus-HPCG Benchmark

Morpheus-HPCG is a benchmark based on the HPCG benchmark application, implemented using Morpheus library, allowing for heterogeneous support across a variety of Sparse Matrix Storage Formats.

Requirements

  • Git
  • CMake (3.10 or later)
  • MPI
  • Morpheus

Quickstart Morpheus-HPCG build

You can build Morpheus-HPCG with MPI and serial backend and dynamic matrix support as follows:

# Setup the environment with the necessary paths
CXX_COMPILER=/path/to/c++/compiler
C_COMPILER=/path/to/c/compiler
MORPHEUS_INSTALL_DIR=/path/to/morpheus/installation
MPI_DIR=/path/to/mpi/installation
# Clone morpheus-hpcg repository using git
git clone https://github.com/morpheus-org/morpheus-hpcg.git
# Go to morpheus-hpcg directory
cd morpheus-hpcg
# Create and switch to the build directory
mkdir build-MPI-Morpheus-serial && cd build-MPI-Morpheus-serial
# Configure using CMake
cmake ..  -DCMAKE_CXX_COMPILER=$CXX_COMPILER \
          -DCMAKE_CXX_EXTENSIONS=Off \
          -DHPCG_ENABLE_MORPHEUS=ON \
          -DHPCG_ENABLE_KOKKOS_SERIAL=ON \
          -DHPCG_ENABLE_MORPHEUS_DYNAMIC=ON \
          -DHPCG_MPI_DIR=$MPI_DIR \
          -DMorpheus_ROOT=$MORPHEUS_INSTALL_DIR
# build using make
make

Running Morpheus HPCG benchmark application

You can run the Morpheus HPCG benchmark application by either using command line parameters or the hpcg.dat input file

morpheus-hpcg <nx> <ny> <nz> <runtime>
# where
# nx      - is the global problem size in x dimension
# ny      - is the global problem size in y dimension
# nz      - is the global problem size in z dimension
# runtime - is the desired benchmarking time in seconds (> 1800s for official runs)

Similarly, these parameters can be entered into an input file hpcg.dat in the working directory, e.g. nx = ny = nz = 280 and runtime = 1860.

HPCG benchmark input file
Sandia National Laboratories; University of Tennessee, Knoxville
280 280 280
1860

Support

Please use the issue tracker for bugs and feature requests.

License

The license file can be found in the main repository.