# --------------------------------------------------------------- # Programmer(s): Steven Smith @ 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 MPI 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 nvector set(nvector_parallel_examples "test_nvector_mpi\;1000 0\;\;\;" # run sequentially "test_nvector_mpi\;1000 0\;1\;4\;" # run parallel on 4 procs ) # Dependencies for nvector examples set(nvector_examples_dependencies test_nvector test_mpinvector sundials_nvector ) # If building F2003 tests if (BUILD_FORTRAN_MODULE_INTERFACE) set(nvector_parallel_fortran_examples "test_fnvector_parallel_mod\;\;1\;4\;") endif() # Add source directory to include directories include_directories(. ..) # Specify libraries to link against set(NVECS_LIB sundials_nvecparallel) if (BUILD_FORTRAN_MODULE_INTERFACE) list(APPEND NVECS_LIB sundials_fnvecparallel_mod) endif() # Set-up linker flags and link libraries set(SUNDIALS_LIBS ${NVECS_LIB} ${EXTRA_LINK_LIBS}) if(MPI_C_COMPILER) # use MPI wrapper as the compiler set(CMAKE_C_COMPILER ${MPI_C_COMPILER}) else() # add MPI_INCLUDE_PATH to include directories include_directories(${MPI_INCLUDE_PATH}) endif() if (BUILD_FORTRAN_MODULE_INTERFACE) if(MPI_Fortran_COMPILER) # use MPI wrapper as the compiler set(CMAKE_Fortran_COMPILER ${MPI_Fortran_COMPILER}) else() # add MPI_INCLUDE_PATH to include directories include_directories(${MPI_INCLUDE_PATH}) endif() endif() # Add the build and install targets for each example foreach(example_tuple ${nvector_parallel_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}) # example source files add_executable(${example} ${example}.c ../test_nvector.c ../test_mpinvector.c) # folder to organize targets in an IDE set_target_properties(${example} PROPERTIES FOLDER "Examples") # libraries to link against target_link_libraries(${example} ${SUNDIALS_LIBS}) if(NOT MPI_C_COMPILER) target_link_libraries(${example} ${MPI_LIBRARIES}) endif() endif() # 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}.c ../test_nvector.c ../test_mpinvector.c ../test_nvector.h ${SUNDIALS_SOURCE_DIR}/src/sundials/sundials_nvector.c DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/parallel) endif() endforeach(example_tuple ${nvector_parallel_examples}) # Add the build and install targets for each example foreach(example_tuple ${nvector_parallel_fortran_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}) # example source files add_executable(${example} ${example}.f90 ${SUNDIALS_SOURCE_DIR}/examples/utilities/test_utilities.f90 ${SUNDIALS_SOURCE_DIR}/examples/nvector/test_nvector.f90) # folder to organize targets in an IDE set_target_properties(${example} PROPERTIES FOLDER "Examples") set_target_properties(${example} PROPERTIES Fortran_MODULE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}) # libraries to link against target_link_libraries(${example} ${SUNDIALS_LIBS}) if(NOT MPI_Fortran_COMPILER) target_link_libraries(${example} ${MPI_LIBRARIES}) endif() endif() # 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) endforeach(example_tuple ${nvector_parallel_fortran_examples}) if(EXAMPLES_INSTALL) # Install the README file install(FILES DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/parallel) # Prepare substitution variables for Makefile and/or CMakeLists templates set(SOLVER_LIB "sundials_nvecparallel") examples2string(nvector_parallel_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_C_ex.in ${PROJECT_BINARY_DIR}/examples/nvector/parallel/CMakeLists.txt @ONLY ) # install CMakelists.txt install( FILES ${PROJECT_BINARY_DIR}/examples/nvector/parallel/CMakeLists.txt DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/parallel ) # 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_C_ex.in ${PROJECT_BINARY_DIR}/examples/nvector/parallel/Makefile_ex @ONLY ) # install the configured Makefile_ex as Makefile install( FILES ${PROJECT_BINARY_DIR}/examples/nvector/parallel/Makefile_ex DESTINATION ${EXAMPLES_INSTALL_PATH}/nvector/parallel RENAME Makefile ) endif() endif()