add_custom_target(resources) add_custom_target(test-resources) set(STORM_3RDPARTY_SOURCE_DIR ${PROJECT_SOURCE_DIR}/resources/3rdparty) set(STORM_3RDPARTY_BINARY_DIR ${PROJECT_BINARY_DIR}/resources/3rdparty) ############################################################# ## ## l3pp ## ############################################################# # Do not take a branch, needs internet connection. ExternalProject_Add( l3pp_ext GIT_REPOSITORY https://github.com/hbruintjes/l3pp.git GIT_TAG e4f8d7fe6c328849aff34d2dfd6fd592c14070d5 SOURCE_DIR ${STORM_3RDPARTY_SOURCE_DIR}/l3pp UPDATE_COMMAND "" CONFIGURE_COMMAND "" BUILD_COMMAND "" INSTALL_COMMAND "" LOG_INSTALL ON ) ExternalProject_Get_Property(l3pp_ext source_dir) set(l3pp_INCLUDE "${source_dir}/") add_imported_library_interface(l3pp "${l3pp_INCLUDE}") list(APPEND STORM_DEP_TARGETS l3pp) add_dependencies(l3pp l3pp_ext) ############################################################# ## ## gmm ## ############################################################# add_imported_library_interface(gmm "${PROJECT_SOURCE_DIR}/resources/3rdparty/gmm-5.2/include") list(APPEND STORM_DEP_TARGETS gmm) ############################################################# ## ## Eigen ## ############################################################# add_imported_library_interface(StormEigen33 "${PROJECT_SOURCE_DIR}/resources/3rdparty/eigen-3.3-beta1") list(APPEND STORM_DEP_TARGETS StormEigen33) ############################################################# ## ## Boost ## ############################################################# # Boost Option variables set(Boost_USE_STATIC_LIBS ${USE_BOOST_STATIC_LIBRARIES}) set(Boost_USE_MULTITHREADED ON) set(Boost_USE_STATIC_RUNTIME OFF) set(Boost_NO_BOOST_CMAKE ON) find_package(Boost 1.61.0 QUIET REQUIRED COMPONENTS filesystem system) if (NOT Boost_FOUND) if (Boost_VERSION) message(FATAL_ERROR "The required Boost version is 1.61.0 or newer, however, only ${Boost_VERSION} was found.") else () message(FATAL_ERROR "Boost was not found.") endif () endif () if ((NOT Boost_LIBRARY_DIRS) OR ("${Boost_LIBRARY_DIRS}" STREQUAL "")) set(Boost_LIBRARY_DIRS "${Boost_INCLUDE_DIRS}/stage/lib") endif () set(CNTVAR 1) foreach(BOOSTLIB ${Boost_LIBRARIES}) add_imported_library(target-boost-${CNTVAR} SHARED ${BOOSTLIB} ${Boost_INCLUDE_DIRS}) list(APPEND STORM_DEP_TARGETS target-boost-${CNTVAR}_SHARED) MATH(EXPR CNTVAR "${CNTVAR}+1") endforeach() message(STATUS "Storm - Using boost ${Boost_VERSION} (library version ${Boost_LIB_VERSION}).") # set the information for the config header set(STORM_BOOST_INCLUDE_DIR "${Boost_INCLUDE_DIRS}") ############################################################# ## ## ExprTk ## ############################################################# # Use the shipped version of ExprTK message (STATUS "Storm - Including ExprTk.") add_imported_library_interface(ExprTk "${PROJECT_SOURCE_DIR}/resources/3rdparty/exprtk") list(APPEND STORM_DEP_TARGETS ExprTk) ############################################################# ## ## Sparsepp ## ############################################################# # Use the shipped version of Sparsepp message (STATUS "Storm - Including Sparsepp.") set(SPARSEPP_INCLUDE_DIR "${PROJECT_SOURCE_DIR}/resources/3rdparty/sparsepp/sparsepp") file(GLOB SPARSEPP_HEADERS "${SPARSEPP_INCLUDE_DIR}/*.h") # Add the sparsepp headers to the headers that are copied to the include directory in the build directory. set(SPARSEPP_BINDIR_DIR ${CMAKE_BINARY_DIR}/include/resources/3rdparty/sparsepp) include_directories("${SPARSEPP_BINDIR_DIR}") foreach(HEADER ${SPARSEPP_HEADERS}) string(REGEX REPLACE "${PROJECT_SOURCE_DIR}/src/?" "" RELATIVE_HEADER_PATH ${HEADER}) string(REGEX MATCH "(.*)[/\\]" RELATIVE_DIRECTORY ${RELATIVE_HEADER_PATH}) string(REGEX REPLACE "${RELATIVE_DIRECTORY}/?" "" HEADER_FILENAME ${RELATIVE_HEADER_PATH}) add_custom_command( OUTPUT ${SPARSEPP_BINDIR_DIR}/sparsepp/${HEADER_FILENAME} COMMAND ${CMAKE_COMMAND} -E make_directory ${SPARSEPP_BINDIR_DIR}/sparsepp COMMAND ${CMAKE_COMMAND} -E copy ${HEADER} ${SPARSEPP_BINDIR_DIR}/sparsepp/${HEADER_FILENAME} DEPENDS ${SPARSEPP_INCLUDE_DIR}/${HEADER_FILENAME} ) list(APPEND SPARSEPP_BINDIR_HEADERS ${SPARSEPP_BINDIR_DIR}/sparsepp/${HEADER_FILENAME}) endforeach() ############################################################# ## ## ModernJSON ## ############################################################# #use the shipped version of modernjson message (STATUS "Storm - Including ModernJSON.") add_imported_library_interface(ModernJSON "${PROJECT_SOURCE_DIR}/resources/3rdparty/modernjson/src/") list(APPEND STORM_DEP_TARGETS ModernJSON) ############################################################# ## ## Z3 (optional) ## ############################################################# find_package(Z3 QUIET) # Z3 Defines set(STORM_HAVE_Z3 ${Z3_FOUND}) if(Z3_FOUND) # Get the z3 version by compiling and running a simple program try_run(version_run_result version_compile_result "${STORM_3RDPARTY_BINARY_DIR}/z3/" "${PROJECT_SOURCE_DIR}/resources/3rdparty/z3/output_version.cpp" CMAKE_FLAGS "-DINCLUDE_DIRECTORIES=${Z3_INCLUDE_DIR}" LINK_LIBRARIES "${Z3_LIBRARIES}" RUN_OUTPUT_VARIABLE z3_version_output) if (version_compile_result AND version_run_result EQUAL 0) if (z3_version_output MATCHES "([0-9]*\\.[0-9]*\\.[0-9]*)") set(Z3_VERSION "${CMAKE_MATCH_1}") endif() endif() if(Z3_VERSION) # Split Z3 version into its components string(REPLACE "." ";" Z3_VERSION_LIST ${Z3_VERSION}) list(GET Z3_VERSION_LIST 0 STORM_Z3_VERSION_MAJOR) list(GET Z3_VERSION_LIST 1 STORM_Z3_VERSION_MINOR) list(GET Z3_VERSION_LIST 2 STORM_Z3_VERSION_PATCH) # Check whether the version of z3 supports optimization if(NOT "${Z3_VERSION}" VERSION_LESS "4.5.0") set(STORM_HAVE_Z3_OPTIMIZE ON) message (STATUS "Storm - Linking with Z3 (version ${Z3_VERSION}). (Z3 version supports optimization)") else() message (STATUS "Storm - Linking with Z3 (version ${Z3_VERSION}). (Z3 version does not support optimization)") endif() if (NOT "${Z3_VERSION}" VERSION_LESS "4.7.1") set(STORM_Z3_API_USES_STANDARD_INTEGERS ON) endif() add_imported_library(z3 SHARED ${Z3_LIBRARIES} ${Z3_INCLUDE_DIRS}) list(APPEND STORM_DEP_TARGETS z3_SHARED) else() message(WARNING "Storm - Could not obtain Z3 version. Building of Prism/JANI models will not be supported.") set(Z3_FOUND FALSE) endif() else() message (WARNING "Storm - Z3 not found. Building of Prism/JANI models will not be supported.") endif(Z3_FOUND) ############################################################# ## ## glpk ## ############################################################# include(${STORM_3RDPARTY_SOURCE_DIR}/include_glpk.cmake) ############################################################# ## ## Gurobi (optional) ## ############################################################# if (STORM_USE_GUROBI) find_package(Gurobi QUIET REQUIRED) set(STORM_HAVE_GUROBI ${GUROBI_FOUND}) if (GUROBI_FOUND) if (EXISTS ${GUROBI_LIBRARY}) message (STATUS "Storm - Linking with Gurobi (${GUROBI_CXX_LIBRARY}).") add_imported_library(Gurobi SHARED ${GUROBI_LIBRARY} ${GUROBI_INCLUDE_DIRS}) list(APPEND STORM_DEP_TARGETS Gurobi_SHARED) else() # The FindGurobi.cmake script needs to be updated every now and then as the library file contains the version number... message(FATAL_ERROR "Gurobi Library ${GUROBI_LIBRARY} not found. If your Gurobi Version is higher then 9.0.0, please contact the Storm developers.") endif() else() # The FindGurobi.cmake script needs to be updated every now and then as the library file contains the version number ... message(FATAL_ERROR "Gurobi Library requested but was not found. Make sure that GUROBI_ROOT points to the correct directory (containing include/ and lib/ subdirectories). If your Gurobi Version is higher then 9.0.0, please contact the Storm developers.") endif() else() set(STORM_HAVE_GUROBI OFF) endif() ############################################################# ## ## CUDD ## ############################################################# include(${STORM_3RDPARTY_SOURCE_DIR}/include_cudd.cmake) ############################################################# ## ## carl ## ############################################################# set(STORM_HAVE_CARL OFF) set(CARL_MINVERSION "17.12") set(CARL_C14VERSION "14") if (NOT STORM_FORCE_SHIPPED_CARL) if (NOT "${STORM_CARL_DIR_HINT}" STREQUAL "") find_package(carl QUIET PATHS ${STORM_CARL_DIR_HINT} NO_DEFAULT_PATH) endif() if (NOT carl_FOUND) find_package(carl QUIET) endif() endif() if(carl_FOUND AND NOT STORM_FORCE_SHIPPED_CARL) get_target_property(carlLOCATION lib_carl LOCATION) if("${carlLOCATION}" STREQUAL "carlLOCATION-NOTFOUND") message(FATAL_ERROR "Library location for carl is not found, did you build carl?") elseif(EXISTS ${carlLOCATION}) #empty on purpose else() message(FATAL_ERROR "File ${carlLOCATION} does not exist, did you build carl?") endif() if("${carl_VERSION_MAJOR}" STREQUAL "${CARL_C14VERSION}") message(STATUS "Storm - Found carl using master14 branch.") # empty on purpose. Maybe put a warning here? elseif("${carl_VERSION_MAJOR}.${carl_VERSION_MINOR}" VERSION_LESS "${CARL_MINVERSION}") message(FATAL_ERROR "Carl outdated, require ${CARL_MINVERSION}, have ${carl_VERSION}") endif() set(STORM_SHIPPED_CARL OFF) set(STORM_HAVE_CARL ON) message(STATUS "Storm - Use system version of carl.") message(STATUS "Storm - Linking with preinstalled carl ${carl_VERSION} (include: ${carl_INCLUDE_DIR}, library ${carl_LIBRARIES}, CARL_USE_CLN_NUMBERS: ${CARL_USE_CLN_NUMBERS}, CARL_USE_GINAC: ${CARL_USE_GINAC}).") set(STORM_HAVE_CLN ${CARL_USE_CLN_NUMBERS}) set(STORM_HAVE_GINAC ${CARL_USE_GINAC}) else() set(STORM_SHIPPED_CARL ON) # The first external project will be built at *configure stage* message(STATUS "Carl - Start of config process") file(MAKE_DIRECTORY ${STORM_3RDPARTY_BINARY_DIR}/carl_download) execute_process( COMMAND ${CMAKE_COMMAND} ${STORM_3RDPARTY_SOURCE_DIR}/carl "-DSTORM_3RDPARTY_BINARY_DIR=${STORM_3RDPARTY_BINARY_DIR}" "-DBoost_LIBRARY_DIRS=${Boost_LIBRARY_DIRS}" "-DBoost_INCLUDE_DIRS=${Boost_INCLUDE_DIRS}" WORKING_DIRECTORY ${STORM_3RDPARTY_BINARY_DIR}/carl_download OUTPUT_VARIABLE carlconfig_out RESULT_VARIABLE carlconfig_result) if(NOT carlconfig_result) message(STATUS "${carlconfig_out}") endif() execute_process( COMMAND ${CMAKE_COMMAND} --build . --target carl-config WORKING_DIRECTORY ${STORM_3RDPARTY_BINARY_DIR}/carl_download OUTPUT_VARIABLE carlconfig_out RESULT_VARIABLE carlconfig_result ) if(NOT carlconfig_result) message(STATUS "${carlconfig_out}") endif() message(STATUS "Carl - End of config process") message(STATUS "Storm - Using shipped version of carl.") ExternalProject_Add( carl SOURCE_DIR ${STORM_3RDPARTY_BINARY_DIR}/carl CONFIGURE_COMMAND "" BUILD_IN_SOURCE 1 BUILD_COMMAND make lib_carl INSTALL_COMMAND make install LOG_BUILD ON LOG_INSTALL ON BUILD_BYPRODUCTS ${STORM_3RDPARTY_BINARY_DIR}/carl/lib/libcarl${DYNAMIC_EXT} ) include(${STORM_3RDPARTY_BINARY_DIR}/carl/carlConfig.cmake) set(STORM_HAVE_CLN ${CARL_USE_CLN_NUMBERS}) set(STORM_HAVE_GINAC ${CARL_USE_GINAC}) add_dependencies(resources carl) set(carl_INCLUDE_DIR "${STORM_3RDPARTY_BINARY_DIR}/carl/include/") set(carl_DIR "${STORM_3RDPARTY_BINARY_DIR}/carl/") set(carl_LIBRARIES ${STORM_3RDPARTY_BINARY_DIR}/carl/lib/libcarl${DYNAMIC_EXT}) set(STORM_HAVE_CARL ON) message(STATUS "Storm - Linking with shipped carl ${carl_VERSION} (include: ${carl_INCLUDE_DIR}, library ${carl_LIBRARIES}, CARL_USE_CLN_NUMBERS: ${CARL_USE_CLN_NUMBERS}, CARL_USE_GINAC: ${CARL_USE_GINAC}).") # install the carl dynamic library if we built it install(FILES ${STORM_3RDPARTY_BINARY_DIR}/carl/lib/libcarl.${carl_VERSION}${DYNAMIC_EXT} DESTINATION lib) endif() if(STORM_USE_CLN_RF AND NOT STORM_HAVE_CLN) message(FATAL_ERROR "Cannot use CLN numbers if carl is build without.") endif() if(STORM_USE_CLN_RF AND NOT STORM_HAVE_GINAC) message(FATAL_ERROR "Cannot use CLN numbers if carl is build without ginac.") endif() # The library that needs symbols must be first, then the library that resolves the symbol. list(APPEND STORM_DEP_IMP_TARGETS lib_carl) if(STORM_USE_CLN_EA OR STORM_USE_CLN_RF) list(APPEND STORM_DEP_IMP_TARGETS GINAC_SHARED CLN_SHARED) endif() list(APPEND STORM_DEP_IMP_TARGETS GMPXX_SHARED GMP_SHARED) ############################################################# ## ## SMT-RAT ## ############################################################# set(STORM_HAVE_SMTRAT OFF) if(USE_SMTRAT) find_package(smtrat QUIET REQUIRED) if(smtrat_FOUND) set(STORM_HAVE_SMTRAT ON) message(STATUS "Storm - Linking with smtrat.") include_directories("${smtrat_INCLUDE_DIR}") list(APPEND STORM_LINK_LIBRARIES ${smtrat_LIBRARIES}) else() message(FATAL_ERROR "Storm - SMT-RAT was requested but not found") endif() endif() ############################################################# ## ## HyPro ## ############################################################# set(STORM_HAVE_HYPRO OFF) if(USE_HYPRO) find_package(hypro QUIET REQUIRED) if(hypro_FOUND) set(STORM_HAVE_HYPRO ON) message(STATUS "Storm - Linking with hypro.") include_directories("${hypro_INCLUDE_DIR}") list(APPEND STORM_LINK_LIBRARIES ${hypro_LIBRARIES}) else() message(FATAL_ERROR "Storm - HyPro was requested but not found") endif() endif() ############################################################# ## ## gmp ## ############################################################# get_target_property(GMPXX_LIB GMPXX_SHARED IMPORTED_LIB_LOCATION) get_target_property(GMP_LIB GMP_SHARED IMPORTED_LIB_LOCATION) get_target_property(GMPXX_INCLUDE_DIR GMPXX_SHARED INTERFACE_INCLUDE_DIRECTORIES) get_target_property(GMP_INCLUDE_DIR GMP_SHARED INTERFACE_INCLUDE_DIRECTORIES) get_filename_component(GMP_LIB_LOCATION ${GMP_LIB} DIRECTORY) get_filename_component(GMPXX_LIB_LOCATION ${GMPXX_LIB} DIRECTORY) ############################################################# ## ## cln ## ############################################################# if(STORM_USE_CLN_RF OR STORM_USE_CLN_EA) get_target_property(CLN_INCLUDE_DIR CLN_SHARED INTERFACE_INCLUDE_DIRECTORIES) endif() ############################################################# ## ## MathSAT (optional) ## ############################################################# if ("${MSAT_ROOT}" STREQUAL "") set(ENABLE_MSAT OFF) else() set(ENABLE_MSAT ON) endif() # MathSAT Defines set(STORM_HAVE_MSAT ${ENABLE_MSAT}) if (ENABLE_MSAT) message (STATUS "Storm - Linking with MathSAT.") if(${OPERATING_SYSTEM} MATCHES "Linux") find_library(MSAT_LIB mathsat PATHS "${MSAT_ROOT}/lib") add_imported_library(msat SHARED ${MSAT_LIB} "${MSAT_ROOT}/include") list(APPEND STORM_DEP_TARGETS msat_SHARED) else() # on macOS, the .dylib file has some hard coded path (Version 5.5.4). # we thus link statically find_library(MSAT_LIB NAMES libmathsat${STATIC_EXT} mathsat PATHS "${MSAT_ROOT}/lib") add_imported_library(msat STATIC ${MSAT_LIB} "${MSAT_ROOT}/include") list(APPEND STORM_DEP_TARGETS msat_STATIC) endif() endif(ENABLE_MSAT) ############################################################# ## ## QVBS (Quantitative verification benchmark set) ## ############################################################# set(STORM_HAVE_QVBS OFF) if (NOT "${STORM_QVBS_ROOT}" STREQUAL "") if( EXISTS "${STORM_QVBS_ROOT}/index.json") set(STORM_HAVE_QVBS ON) message (STATUS "Storm - Enabled inputs from QVBS located at ${STORM_QVBS_ROOT}") else() message(FATAL_ERROR "No file 'index.json' in provided QVBS root directory ${STORM_QVBS_ROOT}") endif() endif() ############################################################# ## ## Xerces ## ############################################################# include(${STORM_3RDPARTY_SOURCE_DIR}/include_xerces.cmake) ############################################################# ## ## Sylvan ## ############################################################# if(STORM_SHIPPED_CARL) set(sylvan_dep carl) else() set(sylvan_dep lib_carl) endif() if (STORM_DEBUG_SYLVAN) set(SYLVAN_BUILD_TYPE "Debug") else() set(SYLVAN_BUILD_TYPE "Release") endif() ExternalProject_Add( sylvan DOWNLOAD_COMMAND "" PREFIX "sylvan" SOURCE_DIR ${STORM_3RDPARTY_SOURCE_DIR}/sylvan CMAKE_ARGS -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER} -DGMP_LOCATION=${GMP_LIB_LOCATION} -DGMP_INCLUDE=${GMP_INCLUDE_DIR} -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER} -DSYLVAN_BUILD_DOCS=OFF -DSYLVAN_BUILD_EXAMPLES=OFF -DCMAKE_BUILD_TYPE=${SYLVAN_BUILD_TYPE} -DCMAKE_POSITION_INDEPENDENT_CODE=ON -DUSE_CARL=ON -Dcarl_DIR=${carl_DIR} -DSYLVAN_PORTABLE=${STORM_PORTABLE} -DBoost_INCLUDE_DIRS=${Boost_INCLUDE_DIRS} -DBUILD_SHARED_LIBS=OFF -DSYLVAN_BUILD_TESTS=OFF BINARY_DIR ${STORM_3RDPARTY_BINARY_DIR}/sylvan BUILD_IN_SOURCE 0 INSTALL_COMMAND "" INSTALL_DIR ${STORM_3RDPARTY_BINARY_DIR}/sylvan LOG_CONFIGURE ON LOG_BUILD ON DEPENDS ${sylvan_dep} BUILD_BYPRODUCTS ${STORM_3RDPARTY_BINARY_DIR}/sylvan/src/libsylvan${STATIC_EXT} BUILD_ALWAYS 1 ) # BUILD ALWAYS ON due to: https://stackoverflow.com/questions/46708124/cmake-doesnt-rebuild-externalproject-on-changes ExternalProject_Get_Property(sylvan source_dir) ExternalProject_Get_Property(sylvan binary_dir) set(Sylvan_INCLUDE_DIR "${source_dir}/src") set(Sylvan_LIBRARY "${binary_dir}/src/libsylvan${STATIC_EXT}") message(STATUS "Storm - Using shipped version of sylvan.") message(STATUS "Storm - Linking with sylvan.") add_imported_library(sylvan STATIC ${Sylvan_LIBRARY} ${Sylvan_INCLUDE_DIR}) add_dependencies(sylvan_STATIC sylvan) list(APPEND STORM_DEP_TARGETS sylvan_STATIC) find_package(Hwloc QUIET REQUIRED) if(HWLOC_FOUND) message(STATUS "Storm - Linking with hwloc ${HWLOC_VERSION}.") add_imported_library(hwloc STATIC ${HWLOC_LIBRARIES} "") list(APPEND STORM_DEP_TARGETS hwloc_STATIC) else() if(${OPERATING_SYSTEM} MATCHES "Linux") message(FATAL_ERROR "HWLOC is required on Linux but was not found.") endif() endif() ############################################################# ## ## cpptemplate ## ############################################################# add_imported_library_interface(CppTemplate "${STORM_3RDPARTY_SOURCE_DIR}/cpptemplate/") list(APPEND STORM_DEP_TARGETS CppTemplate) list(APPEND STORM_3RDPARTY_SOURCES ${STORM_3RDPARTY_SOURCE_DIR}/cpptemplate/cpptempl.cpp) ############################################################# ## ## Google Test gtest ## ############################################################# set(GOOGLETEST_LIB_DIR ${STORM_3RDPARTY_BINARY_DIR}/gtest-1.10.0) ExternalProject_Add( googletest #For downloads (may be useful later!) #SVN_REPOSITORY http://googletest.googlecode.com/svn/trunk/ #TIMEOUT 10 DOWNLOAD_COMMAND "" SOURCE_DIR "${STORM_3RDPARTY_SOURCE_DIR}/gtest-1.10.0" # Force the same output paths for debug and release builds so that # we know in which place the binaries end up when using the Xcode generator CMAKE_ARGS -Dgtest_force_shared_crt=ON -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER} -DCMAKE_ARCHIVE_OUTPUT_DIRECTORY_DEBUG:PATH=${GOOGLETEST_LIB_DIR} -DCMAKE_ARCHIVE_OUTPUT_DIRECTORY_RELEASE:PATH=${GOOGLETEST_LIB_DIR} # Disable install step INSTALL_COMMAND "" BINARY_DIR ${GOOGLETEST_LIB_DIR} INSTALL_DIR ${GOOGLETEST_LIB_DIR} # Wrap download, configure and build steps in a script to log output LOG_CONFIGURE ON LOG_BUILD ON BUILD_BYPRODUCTS ${GOOGLETEST_LIB_DIR}/lib/libgtest${STATIC_EXT} ${GOOGLETEST_LIB_DIR}/lib/libgtest_main${STATIC_EXT} ) # Specify include dir ExternalProject_Get_Property(googletest source_dir) set(GTEST_INCLUDE_DIR ${source_dir}/googletest/include) # Specify MainTest's link libraries ExternalProject_Get_Property(googletest binary_dir) set(GTEST_LIBRARIES ${binary_dir}/lib/libgtest${STATIC_EXT} ${binary_dir}/lib/libgtest_main${STATIC_EXT}) add_dependencies(test-resources googletest) list(APPEND STORM_TEST_LINK_LIBRARIES ${GTEST_LIBRARIES}) ############################################################# ## ## Intel Threading Building Blocks (optional) ## ############################################################# set(STORM_HAVE_INTELTBB OFF) if (STORM_USE_INTELTBB) find_package(TBB QUIET REQUIRED) if (TBB_FOUND) message(STATUS "Storm - Found Intel TBB with interface version ${TBB_INTERFACE_VERSION}.") message(STATUS "Storm - Linking with Intel TBB in ${TBB_LIBRARY_DIRS}.") set(STORM_HAVE_INTELTBB ON) # Under Linux libtbb.so contains a linker script to libtbb.so.2 instead of a symlink. # This breaks CMake. # As a workaround we manually try to add the necessary suffix ".2" to the so file and hope for the best. if (LINUX) # Check if the library is a linker script which only links to the correct library # Read first bytes of file file(READ "${TBB_LIBRARY}" TMPTXT LIMIT 128) # Check if file starts with "INPUT (libtbb.so.2)" if("${TMPTXT}" MATCHES "INPUT \\(libtbb\\.so\\.(.*)\\)") # Manually set library by adding the suffix from the linker script. # CMAKE_MATCH_1 contains the parsed suffix. set(TBB_LIB_LINUX "${TBB_LIBRARY}.${CMAKE_MATCH_1}") set(TBB_MALLOC_LIB_LINUX "${TBB_MALLOC_LIBRARY}.${CMAKE_MATCH_1}") if (EXISTS "${TBB_LIB_LINUX}") set(TBB_LIBRARY ${TBB_LIB_LINUX}) message(STATUS "Storm - Using Intel TBB library in manually set path ${TBB_LIBRARY}.") endif() if (EXISTS "${TBB_MALLOC_LIB_LINUX}") set(TBB_MALLOC_LIBRARY ${TBB_MALLOC_LIB_LINUX}) message(STATUS "Storm - Using Intel TBB malloc library in manually set path ${TBB_MALLOC_LIBRARY}.") endif() endif() endif() add_imported_library(tbb SHARED ${TBB_LIBRARY} ${TBB_INCLUDE_DIRS}) list(APPEND STORM_DEP_TARGETS tbb_SHARED) add_imported_library(tbb_malloc SHARED ${TBB_MALLOC_LIBRARY} ${TBB_INCLUDE_DIRS}) list(APPEND STORM_DEP_TARGETS tbb_malloc_SHARED) else(TBB_FOUND) message(FATAL_ERROR "Storm - TBB was requested, but not found.") endif(TBB_FOUND) endif(STORM_USE_INTELTBB) ############################################################# ## ## Threads ## ############################################################# find_package(Threads QUIET REQUIRED) if (NOT Threads_FOUND) message(FATAL_ERROR "Storm - Threads was requested, but not found.") endif() include_directories(${THREADS_INCLUDE_DIRS}) list(APPEND STORM_LINK_LIBRARIES ${CMAKE_THREAD_LIBS_INIT}) if (STORM_USE_COTIRE) target_link_libraries(storm_unity ${CMAKE_THREAD_LIBS_INIT}) endif(STORM_USE_COTIRE) ############################################################# ## ## CUDA Library generation ## ############################################################# if ("${CUDA_ROOT}" STREQUAL "") set(ENABLE_CUDA OFF) else() set(ENABLE_CUDA ON) endif() # CUDA Defines if (ENABLE_CUDA) set(STORM_CPP_CUDA_DEF "define") else() set(STORM_CPP_CUDA_DEF "undef") endif() # CUDA Defines set(STORM_CPP_CUDAFORSTORM_DEF "undef") if(ENABLE_CUDA) # Test for type alignment try_run(STORM_CUDA_RUN_RESULT_TYPEALIGNMENT STORM_CUDA_COMPILE_RESULT_TYPEALIGNMENT ${PROJECT_BINARY_DIR} "${PROJECT_SOURCE_DIR}/cuda/CMakeAlignmentCheck.cpp" COMPILE_OUTPUT_VARIABLE OUTPUT_TEST_VAR ) if(NOT STORM_CUDA_COMPILE_RESULT_TYPEALIGNMENT) message(FATAL_ERROR "Storm (CudaPlugin) - Could not test type alignment, there was an Error while compiling the file ${PROJECT_SOURCE_DIR}/cuda/CMakeAlignmentCheck.cpp: ${OUTPUT_TEST_VAR}") elseif(STORM_CUDA_RUN_RESULT_TYPEALIGNMENT EQUAL 0) message(STATUS "Storm (CudaPlugin) - Result of Type Alignment Check: OK.") else() message(FATAL_ERROR "Storm (CudaPlugin) - Result of Type Alignment Check: FAILED (Code ${STORM_CUDA_RUN_RESULT_TYPEALIGNMENT})") endif() # Test for Float 64bit Alignment try_run(STORM_CUDA_RUN_RESULT_FLOATALIGNMENT STORM_CUDA_COMPILE_RESULT_FLOATALIGNMENT ${PROJECT_BINARY_DIR} "${PROJECT_SOURCE_DIR}/cuda/CMakeFloatAlignmentCheck.cpp" COMPILE_OUTPUT_VARIABLE OUTPUT_TEST_VAR ) if(NOT STORM_CUDA_COMPILE_RESULT_FLOATALIGNMENT) message(FATAL_ERROR "Storm (CudaPlugin) - Could not test float type alignment, there was an Error while compiling the file ${PROJECT_SOURCE_DIR}/cuda/CMakeFloatAlignmentCheck.cpp: ${OUTPUT_TEST_VAR}") elseif(STORM_CUDA_RUN_RESULT_FLOATALIGNMENT EQUAL 2) message(STATUS "Storm (CudaPlugin) - Result of Float Type Alignment Check: 64bit alignment active.") set(STORM_CUDAPLUGIN_FLOAT_64BIT_ALIGN_DEF "define") elseif(STORM_CUDA_RUN_RESULT_FLOATALIGNMENT EQUAL 3) message(STATUS "Storm (CudaPlugin) - Result of Float Type Alignment Check: 64bit alignment disabled.") set(STORM_CUDAPLUGIN_FLOAT_64BIT_ALIGN_DEF "undef") else() message(FATAL_ERROR "Storm (CudaPlugin) - Result of Float Type Alignment Check: FAILED (Code ${STORM_CUDA_RUN_RESULT_FLOATALIGNMENT})") endif() # # Make a version file containing the current version from git. # include(GetGitRevisionDescription) git_describe_checkout(STORM_GIT_VERSION_STRING) # Parse the git Tag into variables string(REGEX REPLACE "^([0-9]+)\\..*" "\\1" STORM_CUDAPLUGIN_VERSION_MAJOR "${STORM_GIT_VERSION_STRING}") string(REGEX REPLACE "^[0-9]+\\.([0-9]+).*" "\\1" STORM_CUDAPLUGIN_VERSION_MINOR "${STORM_GIT_VERSION_STRING}") string(REGEX REPLACE "^[0-9]+\\.[0-9]+\\.([0-9]+).*" "\\1" STORM_CUDAPLUGIN_VERSION_PATCH "${STORM_GIT_VERSION_STRING}") string(REGEX REPLACE "^[0-9]+\\.[0-9]+\\.[0-9]+\\-([0-9]+)\\-.*" "\\1" STORM_CUDAPLUGIN_VERSION_COMMITS_AHEAD "${STORM_GIT_VERSION_STRING}") string(REGEX REPLACE "^[0-9]+\\.[0-9]+\\.[0-9]+\\-[0-9]+\\-([a-z0-9]+).*" "\\1" STORM_CUDAPLUGIN_VERSION_HASH "${STORM_GIT_VERSION_STRING}") string(REGEX REPLACE "^[0-9]+\\.[0-9]+\\.[0-9]+\\-[0-9]+\\-[a-z0-9]+\\-(.*)" "\\1" STORM_CUDAPLUGIN_VERSION_APPENDIX "${STORM_GIT_VERSION_STRING}") if ("${STORM_CUDAPLUGIN_VERSION_APPENDIX}" MATCHES "^.*dirty.*$") set(STORM_CUDAPLUGIN_VERSION_DIRTY 1) else() set(STORM_CUDAPLUGIN_VERSION_DIRTY 0) endif() message(STATUS "Storm (CudaPlugin) - Version information: ${STORM_CUDAPLUGIN_VERSION_MAJOR}.${STORM_CUDAPLUGIN_VERSION_MINOR}.${STORM_CUDAPLUGIN_VERSION_PATCH} (${STORM_CUDAPLUGIN_VERSION_COMMITS_AHEAD} commits ahead of Tag) build from ${STORM_CUDAPLUGIN_VERSION_HASH} (Dirty: ${STORM_CUDAPLUGIN_VERSION_DIRTY})") # Configure a header file to pass some of the CMake settings to the source code configure_file ( "${PROJECT_SOURCE_DIR}/cuda/storm-cudaplugin-config.h.in" "${PROJECT_BINARY_DIR}/include/storm-cudaplugin-config.h" ) #create library find_package(CUDA REQUIRED) set(CUSP_INCLUDE_DIRS "${PROJECT_SOURCE_DIR}/resources/3rdparty/cusplibrary") find_package(Cusp REQUIRED) find_package(Thrust REQUIRED) set(STORM_CUDA_LIB_NAME "storm-cuda") file(GLOB_RECURSE STORM_CUDA_KERNEL_FILES ${PROJECT_SOURCE_DIR}/cuda/kernels/*.cu) file(GLOB_RECURSE STORM_CUDA_HEADER_FILES ${PROJECT_SOURCE_DIR}/cuda/kernels/*.h) source_group(kernels FILES ${STORM_CUDA_KERNEL_FILES} ${STORM_CUDA_HEADER_FILES}) include_directories(${PROJECT_SOURCE_DIR}/cuda/kernels/) #set(CUDA_PROPAGATE_HOST_FLAGS OFF) set(CUDA_NVCC_FLAGS "-arch=sm_30") ############################################################# ## ## CUSP ## ############################################################# if(CUSP_FOUND) include_directories(${CUSP_INCLUDE_DIR}) cuda_include_directories(${CUSP_INCLUDE_DIR}) message(STATUS "Storm (CudaPlugin) - Found CUSP Version ${CUSP_VERSION} in location ${CUSP_INCLUDE_DIR}.") else() message(FATAL_ERROR "Storm (CudaPlugin) - Could not find CUSP.") endif() ############################################################# ## ## Thrust ## ############################################################# if(THRUST_FOUND) include_directories(${THRUST_INCLUDE_DIR}) cuda_include_directories(${THRUST_INCLUDE_DIR}) message(STATUS "Storm (CudaPlugin) - Found Thrust Version ${THRUST_VERSION} in location ${THRUST_INCLUDE_DIR}.") else() message(FATAL_ERROR "Storm (CudaPlugin) - Could not find Thrust. Check your CUDA installation.") endif() include_directories(${CUDA_INCLUDE_DIRS}) include_directories(${ADDITIONAL_INCLUDE_DIRS}) cuda_add_library(${STORM_CUDA_LIB_NAME} ${STORM_CUDA_KERNEL_FILES} ${STORM_CUDA_HEADER_FILES} ) message (STATUS "Storm - Linking with CUDA.") list(APPEND STORM_LINK_LIBRARIES ${STORM_CUDA_LIB_NAME}) include_directories("${PROJECT_SOURCE_DIR}/cuda/kernels/") endif() add_custom_target(copy_resources_headers DEPENDS ${SPARSEPP_BINDIR_HEADERS})