# --------------------------------------------------------------- # Programmer(s): Slaven Peles and Cody J. Balos @ LLNL # --------------------------------------------------------------- # SUNDIALS Copyright Start # Copyright (c) 2002-2021, Lawrence Livermore National Security # and Southern Methodist University. # All rights reserved. # # See the top-level LICENSE and NOTICE files for details. # # SPDX-License-Identifier: BSD-3-Clause # SUNDIALS Copyright End # --------------------------------------------------------------- # CMakeLists.txt file for raja nvector examples # --------------------------------------------------------------- # Example lists are tuples "name\;args\;nodes\;tasks\;type" where the # type is develop for examples excluded from 'make test' in releases # Examples using SUNDIALS MPI+raja nvector set(nvector_raja_examples "test_nvector_mpiraja\;1000 0\;\;\;" # run sequentially "test_nvector_mpiraja\;1000 0\;1\;4\;" # run parallel on 4 procs ) # Dependencies for nvector examples set(nvector_examples_dependencies test_nvector test_mpinvector sundials_nvector sundials_math ) # Add source directory to include directories include_directories(. ..) if(SUNDIALS_RAJA_BACKENDS MATCHES "CUDA") set(_lang CUDA) else() set(_lang CXX) endif() # Add the build and install targets for each example foreach(example_tuple ${nvector_raja_examples}) # parse the example tuple list(GET example_tuple 0 example) list(GET example_tuple 1 example_args) list(GET example_tuple 2 number_of_nodes) list(GET example_tuple 3 number_of_tasks) list(GET example_tuple 4 example_type) # check if this example has already been added, only need to add # example source files once for testing with different inputs if(NOT TARGET ${example}) set_source_files_properties(${example}.cpp PROPERTIES LANGUAGE ${_lang}) # example source files add_executable(${example} ${example}.cpp ../test_nvector.c ../test_mpinvector.c) set_target_properties(${example} PROPERTIES FOLDER "Examples") target_include_directories(${example} PUBLIC ${MPI_CXX_INCLUDE_DIRS}) target_link_libraries(${example} PRIVATE sundials_nvecmpiplusx sundials_nvecraja ${MPI_CXX_LIBRARIES} ${EXTRA_LINK_LIBS}) endif() # check if example args are provided and set the test name # check if example args are provided and set the test name if("${example_args}" STREQUAL "") if("${number_of_tasks}" STREQUAL "") set(test_name ${example}) else() string(REGEX REPLACE " " "_" test_name ${example}_${number_of_tasks}) endif() else() if("${number_of_tasks}" STREQUAL "") string(REGEX REPLACE " " "_" test_name ${example}_${example_args}) else() string(REGEX REPLACE " " "_" test_name ${example}_${number_of_tasks}_${example_args}) endif() endif() # add example to regression tests sundials_add_test(${test_name} ${example} TEST_ARGS ${example_args} MPI_NPROCS ${number_of_tasks} EXAMPLE_TYPE ${example_type} NODIFF) # install example source files if(EXAMPLES_INSTALL) install(FILES ${example}.cpp ../test_nvector.c ../test_mpinvector.c ../test_nvector.h ../../../src/sundials/sundials_nvector.c ../../../src/sundials/sundials_math.c DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/mpiraja) endif() endforeach(example_tuple ${nvector_raja_examples}) if(EXAMPLES_INSTALL) # Install the README file install(FILES DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/mpiraja) examples2string(nvector_raja_examples EXAMPLES) examples2string(nvector_examples_dependencies EXAMPLES_DEPENDENCIES) # Regardless of the platform we're on, we will generate and install # CMakeLists.txt file for building the examples. This file can then # be used as a template for the user's own programs. # generate CMakelists.txt in the binary directory configure_file( ${PROJECT_SOURCE_DIR}/examples/templates/cmakelists_parallel_RAJA_ex.in ${PROJECT_BINARY_DIR}/examples/nvector/mpiraja/CMakeLists.txt @ONLY ) # install CMakelists.txt install( FILES ${PROJECT_BINARY_DIR}/examples/nvector/mpiraja/CMakeLists.txt DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/mpiraja ) # On UNIX-type platforms, we also generate and install a makefile for # building the examples. This makefile can then be used as a template # for the user's own programs. if(UNIX) # generate Makefile and place it in the binary dir configure_file( ${PROJECT_SOURCE_DIR}/examples/templates/makefile_parallel_RAJA_ex.in ${PROJECT_BINARY_DIR}/examples/nvector/mpiraja/Makefile_ex @ONLY ) # install the configured Makefile_ex as Makefile install( FILES ${PROJECT_BINARY_DIR}/examples/nvector/mpiraja/Makefile_ex DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/mpiraja RENAME Makefile ) endif() endif()