This repo provides FindMKL.cmake file, which can be used to configure a CMake project that needs Intel MKL. We basically took this extremely simple C++ example, modify the code to require MKL, provide CMake package finder for MKL and add all the Contineous Integration (CI) to test it against different scenarios.
Tests are run on Mac, Linux and Windows, using both static or dynamic libraries.
To find the correct libraries to use at compilation, FindMKL.cmake uses the mkl_link_tool command. On Linux, it means that you need to be able to execute 32bits binaries (see our Travis config file).
Actually you can use this project in whatever manner you like. But we think that there are two main ways to use this project:
-
Clone/Fork/Download the entire project and use it as your starting point. This has the advantage that travis and appveyor would be already configured, for you. The only step required to have CI up and running would be to activate your porject in those platforms.
-
Download
FindMKL.cmake
and place it wherever is needed in your project.
The best way to understand how to run a project (or install its dependencies) is always looking to CI's configuration (.travis.yml and .appveyor.yml). But as a summary, as this is an example of how to use MKL and CMake you'll need to install MKL and download CMake. If you are using an ubuntu, CMake can be install it via:
sudo apt-get install cmake
Once CMake and MKL have been installed navigate to the root of the project and issue the following commands:
mkdir build
cd build
cmake .. && cmake --build .