FindMatlab¶
Finds Matlab or Matlab Compiler Runtime (MCR) and provides Matlab tools, libraries and compilers to CMake.
This package primary purpose is to find the libraries associated with Matlab or the MCR in order to be able to build Matlab extensions (mex files). It can also be used:
- to run specific commands in Matlab in case Matlab is available 
- for declaring Matlab unit test 
- to retrieve various information from Matlab (mex extensions, versions and release queries, ...) 
Added in version 3.12: Added Matlab Compiler Runtime (MCR) support.
The module supports the following components:
- ENG_LIBRARYand- MAT_LIBRARY: respectively the- ENGand- MATlibraries of Matlab
- MAIN_PROGRAMthe Matlab binary program. Note that this component is not available on the MCR version, and will yield an error if the MCR is found instead of the regular Matlab installation.
- MEX_COMPILERthe MEX compiler.
- MCC_COMPILERthe MCC compiler, included with the Matlab Compiler add-on.
- SIMULINKthe Simulink environment.
Added in version 3.7: Added the MAT_LIBRARY component.
Added in version 3.13: Added the ENGINE_LIBRARY, DATAARRAY_LIBRARY and MCC_COMPILER
components.
Changed in version 3.14: Removed the MX_LIBRARY, ENGINE_LIBRARY and DATAARRAY_LIBRARY
components.  These libraries are found unconditionally.
Added in version 3.30: Added support for specifying a version range to find_package() and
added support for specifying REGISTRY_VIEW to find_package(),
matlab_extract_all_installed_versions_from_registry() and
matlab_get_all_valid_matlab_roots_from_registry(). The default
behavior remained unchanged, by using the registry view TARGET.
Note
The version given to the find_package() directive is the Matlab
version, which should not be confused with the Matlab release name
(e.g. R2023b).
The matlab_get_version_from_release_name() and
matlab_get_release_name_from_version() provide a mapping
between the release name and the version.
The variable Matlab_ROOT_DIR may be specified in order to give
the path of the desired Matlab version. Otherwise, the behavior is platform
specific:
- Windows: The installed versions of Matlab/MCR are retrieved from the Windows registry. The - REGISTRY_VIEWargument may optionally be specified to manually control whether 32bit or 64bit versions shall be searched for.
- macOS: The installed versions of Matlab/MCR are given by the MATLAB default installation paths under - $HOME/Applicationsand- /Applications. If no such application is found, it falls back to the one that might be accessible from the- PATH.
- Unix: The desired Matlab should be accessible from the - PATH. This does not work for MCR installation and- Matlab_ROOT_DIRshould be specified on this platform.
Additional information is provided when MATLAB_FIND_DEBUG is set.
When a Matlab/MCR installation is found automatically and the MATLAB_VERSION
is not given, the version is queried from Matlab directly (on Windows this
may pop up a Matlab window) or from the MCR installation.
The mapping of the release names and the version of Matlab is performed by
defining pairs (name, version).  The variable
MATLAB_ADDITIONAL_VERSIONS may be provided before the call to
the find_package() in order to handle additional versions.
A Matlab scripts can be added to the set of tests using the
matlab_add_unit_test(). By default, the Matlab unit test framework
will be used (>= 2013a) to run this script, but regular .m files
returning an exit code can be used as well (0 indicating a success).
Module Input Variables¶
Users or projects may set the following variables to configure the module behavior:
- Matlab_ROOT
- Added in version 3.25. - Default value for - Matlab_ROOT_DIR, the root of the Matlab installation.
- Matlab_ROOT_DIR
- The root of the Matlab installation. 
- MATLAB_FIND_DEBUG
- outputs debug information 
- MATLAB_ADDITIONAL_VERSIONS
- additional versions of Matlab for the automatic retrieval of the installed versions. 
Imported targets¶
Added in version 3.22.
This module defines the following IMPORTED targets:
- Matlab::mex
- The - mexlibrary, always available for MATLAB installations. Available for MCR installations if provided by MCR.
- Matlab::mx
- The mx library of Matlab (arrays), always available for MATLAB installations. Available for MCR installations if provided by MCR. 
- Matlab::eng
- Matlab engine library. Available only if the - ENG_LIBRARYcomponent is requested.
- Matlab::mat
- Matlab matrix library. Available only if the - MAT_LIBRARYcomponent is requested.
- Matlab::MatlabEngine
- Matlab C++ engine library, always available for MATLAB R2018a and newer. Available for MCR installations if provided by MCR. 
- Matlab::MatlabDataArray
- Matlab C++ data array library, always available for MATLAB R2018a and newer. Available for MCR installations if provided by MCR. 
Variables defined by the module¶
Result variables¶
- Matlab_FOUND
- TRUEif the Matlab installation is found,- FALSEotherwise. All variable below are defined if Matlab is found.
- Matlab_VERSION
- Added in version 3.27. - the numerical version (e.g. 23.2.0) of Matlab found. Not to be confused with Matlab release name (e.g. R2023b) that can be obtained with - matlab_get_release_name_from_version().
- Matlab_ROOT_DIR
- the final root of the Matlab installation determined by the FindMatlab module. 
- Matlab_MAIN_PROGRAM
- the Matlab binary program. Available only if the component - MAIN_PROGRAMis given in the- find_package()directive.
- Matlab_INCLUDE_DIRS
- the path of the Matlab libraries headers 
- Matlab_MEX_LIBRARY
- library for mex, always available for MATLAB installations. Available for MCR installations if provided by MCR. 
- Matlab_MX_LIBRARY
- mx library of Matlab (arrays), always available for MATLAB installations. Available for MCR installations if provided by MCR. 
- Matlab_ENG_LIBRARY
- Matlab engine library. Available only if the component - ENG_LIBRARYis requested.
- Matlab_MAT_LIBRARY
- Matlab matrix library. Available only if the component - MAT_LIBRARYis requested.
- Matlab_ENGINE_LIBRARY
- Added in version 3.13. - Matlab C++ engine library, always available for MATLAB R2018a and newer. Available for MCR installations if provided by MCR. 
- Matlab_DATAARRAY_LIBRARY
- Added in version 3.13. - Matlab C++ data array library, always available for MATLAB R2018a and newer. Available for MCR installations if provided by MCR. 
- Matlab_LIBRARIES
- the whole set of libraries of Matlab 
- Matlab_MEX_COMPILER
- the mex compiler of Matlab. Currently not used. Available only if the component - MEX_COMPILERis requested.
- Matlab_MCC_COMPILER
- Added in version 3.13. - the mcc compiler of Matlab. Included with the Matlab Compiler add-on. Available only if the component - MCC_COMPILERis requested.
Cached variables¶
- Matlab_MEX_EXTENSION
- the extension of the mex files for the current platform (given by Matlab). 
- Matlab_ROOT_DIR
- the location of the root of the Matlab installation found. If this value is changed by the user, the result variables are recomputed. 
Provided commands¶
- matlab_get_version_from_release_name()
- returns the version from the Matlab release name 
- matlab_get_release_name_from_version()
- returns the release name from the Matlab version 
- matlab_add_mex()
- adds a target compiling a MEX file. 
- matlab_add_unit_test()
- adds a Matlab unit test file as a test to the project. 
- matlab_extract_all_installed_versions_from_registry()
- parses the registry for all Matlab versions. Available on Windows only. The part of the registry parsed is dependent on the host processor 
- matlab_get_all_valid_matlab_roots_from_registry()
- returns all the possible Matlab or MCR paths, according to a previously given list. Only the existing/accessible paths are kept. This is mainly useful for the searching all possible Matlab installation. 
- matlab_get_mex_suffix()
- returns the suffix to be used for the mex files (platform/architecture dependent) 
- matlab_get_version_from_matlab_run()
- returns the version of Matlab/MCR, given the full directory of the Matlab/MCR installation path. 
Known issues¶
- Symbol clash in a MEX target
- By default, every symbols inside a MEX file defined with the command - matlab_add_mex()have hidden visibility, except for the entry point. This is the default behavior of the MEX compiler, which lowers the risk of symbol collision between the libraries shipped with Matlab, and the libraries to which the MEX file is linking to. This is also the default on Windows platforms.- However, this is not sufficient in certain case, where for instance your MEX file is linking against libraries that are already loaded by Matlab, even if those libraries have different SONAMES. A possible solution is to hide the symbols of the libraries to which the MEX target is linking to. This can be achieved in GNU GCC compilers with the linker option - -Wl,--exclude-libs,ALL.
- Tests using GPU resources
- in case your MEX file is using the GPU and in order to be able to run unit tests on this MEX file, the GPU resources should be properly released by Matlab. A possible solution is to make Matlab aware of the use of the GPU resources in the session, which can be performed by a command such as - D = gpuDevice()at the beginning of the test script (or via a fixture).
Reference¶
- Matlab_ROOT_DIR¶
- The root folder of the Matlab installation. If set before the call to - find_package(), the module will look for the components in that path. If not set, then an automatic search of Matlab will be performed. If set, it should point to a valid version of Matlab.
- MATLAB_FIND_DEBUG¶
- If set, the lookup of Matlab and the intermediate configuration steps are outputted to the console. 
- MATLAB_ADDITIONAL_VERSIONS¶
- If set, specifies additional versions of Matlab that may be looked for. The variable should be a list of strings, organized by pairs of release name and versions, such as follows: - set(MATLAB_ADDITIONAL_VERSIONS "release_name1=corresponding_version1" "release_name2=corresponding_version2" ... )- Example: - set(MATLAB_ADDITIONAL_VERSIONS "R2013b=8.2" "R2013a=8.1" "R2012b=8.0")- The order of entries in this list matters when several versions of Matlab are installed. The priority is set according to the ordering in this list. 
- matlab_get_version_from_release_name¶
- matlab_get_version_from_release_name(release version) - Input: - releaseis the release name (e.g. R2023b)
- Output: - versionis the version of Matlab (e.g. 23.2.0)
 - Returns the version of Matlab from a release name - Note - This command provides correct versions mappings for Matlab but not MCR. 
- matlab_get_release_name_from_version¶
- matlab_get_release_name_from_version(version release_name) - Input: - versionis the version of Matlab (e.g. 23.2.0)
- Output: - release_nameis the release name (R2023b)
 - Returns the release name from the version of Matlab - Note - This command provides correct version mappings for Matlab but not MCR. 
- matlab_extract_all_installed_versions_from_registry¶
- This function parses the Windows registry and finds the Matlab versions that are installed. The found versions are stored in a given - <versions-var>.- matlab_extract_all_installed_versions_from_registry(<versions-var> [REGISTRY_VIEW view])¶
- Added in version 3.30. - Output: - <versions-var>is a list of all the versions of Matlab found
- Input: - REGISTRY_VIEWOptional registry view to use for registry interaction. The argument is passed (or omitted) to- cmake_host_system_information()without further checks or modification.
 
 - matlab_extract_all_installed_versions_from_registry(<win64> <versions-var>)¶
- Input: - win64is a boolean to search for the 64 bit version of Matlab. Set to- ONto use the 64bit registry view or- OFFto use the 32bit registry view. If finer control is needed, see signature above.
- Output: - <versions-var>is a list of all the versions of Matlab found
 
 - The returned list contains all versions under - HKLM\SOFTWARE\Mathworks\MATLAB,- HKLM\SOFTWARE\Mathworks\MATLAB Runtimeand- HKLM\SOFTWARE\Mathworks\MATLAB Compiler Runtimeor an empty list in case an error occurred (or nothing found).- Note - Only the versions are provided. No check is made over the existence of the installation referenced in the registry, 
- matlab_get_all_valid_matlab_roots_from_registry¶
- Populates the Matlab root with valid versions of Matlab or Matlab Runtime (MCR). The returned matlab_roots is organized in triplets - (type,version_number,matlab_root_path), where- typeindicates either- MATLABor- MCR.- matlab_get_all_valid_matlab_roots_from_registry(matlab_versions matlab_roots [REGISTRY_VIEW view]) - Input: - matlab_versionsof each of the Matlab or MCR installations
- Output: - matlab_rootslocation of each of the Matlab or MCR installations
- Input: - REGISTRY_VIEWOptional registry view to use for registry interaction. The argument is passed (or omitted) to- cmake_host_system_information()without further checks or modification.
 - Added in version 3.30: The optional - REGISTRY_VIEWargument was added to provide a more precise interface on how to interact with the Windows Registry.
- matlab_get_mex_suffix¶
- Returns the extension of the mex files (the suffixes). This function should not be called before the appropriate Matlab root has been found. - matlab_get_mex_suffix(matlab_root mex_suffix) - Input: - matlab_rootroot of Matlab/MCR install e.g.- Matlab_ROOT_DIR
- Output: - mex_suffixvariable name in which the suffix will be returned.
 
- matlab_get_version_from_matlab_run¶
- This function runs Matlab program specified on arguments and extracts its version. If the path provided for the Matlab installation points to an MCR installation, the version is extracted from the installed files. - matlab_get_version_from_matlab_run(matlab_binary_path matlab_list_versions) - Input: - matlab_binary_pathpath of the matlab binary executable
- Output: - matlab_list_versionsthe version extracted from Matlab
 
- matlab_add_unit_test¶
- Adds a Matlab unit test to the test set of cmake/ctest. This command requires the component - MAIN_PROGRAMand hence is not available for an MCR installation.- The unit test uses the Matlab unittest framework (default, available starting Matlab 2013b+) except if the option - NO_UNITTEST_FRAMEWORKis given.- The function expects one Matlab test script file to be given. In the case - NO_UNITTEST_FRAMEWORKis given, the unittest script file should contain the script to be run, plus an exit command with the exit value. This exit value will be passed to the ctest framework (0 success, non 0 failure). Additional arguments accepted by- add_test()can be passed through- TEST_ARGS(eg.- CONFIGURATION <config> ...).- matlab_add_unit_test( NAME <name> UNITTEST_FILE matlab_file_containing_unittest.m [CUSTOM_TEST_COMMAND matlab_command_to_run_as_test] [UNITTEST_PRECOMMAND matlab_command_to_run] [TIMEOUT timeout] [ADDITIONAL_PATH path1 [path2 ...]] [MATLAB_ADDITIONAL_STARTUP_OPTIONS option1 [option2 ...]] [TEST_ARGS arg1 [arg2 ...]] [NO_UNITTEST_FRAMEWORK] ) - Function Parameters: - NAME
- name of the unittest in ctest. 
- UNITTEST_FILE
- the matlab unittest file. Its path will be automatically added to the Matlab path. 
- CUSTOM_TEST_COMMAND
- Matlab script command to run as the test. If this is not set, then the following is run: - runtests('matlab_file_name'), exit(max([ans(1,:).Failed]))where- matlab_file_nameis the- UNITTEST_FILEwithout the extension.
- UNITTEST_PRECOMMAND
- Matlab script command to be ran before the file containing the test (eg. GPU device initialization based on CMake variables). 
- TIMEOUT
- the test timeout in seconds. Defaults to 180 seconds as the Matlab unit test may hang. 
- ADDITIONAL_PATH
- a list of paths to add to the Matlab path prior to running the unit test. 
- MATLAB_ADDITIONAL_STARTUP_OPTIONS
- a list of additional option in order to run Matlab from the command line. - -nosplash -nodesktop -nodisplayare always added.
- TEST_ARGS
- Additional options provided to the add_test command. These options are added to the default options (eg. "CONFIGURATIONS Release") 
- NO_UNITTEST_FRAMEWORK
- when set, indicates that the test should not use the unittest framework of Matlab (available for versions >= R2013a). 
- WORKING_DIRECTORY
- This will be the working directory for the test. If specified it will also be the output directory used for the log file of the test run. If not specified the temporary directory - ${CMAKE_BINARY_DIR}/Matlabwill be used as the working directory and the log location.
 
- matlab_add_mex¶
- Adds a Matlab MEX target. This commands compiles the given sources with the current tool-chain in order to produce a MEX file. The final name of the produced output may be specified, as well as additional link libraries, and a documentation entry for the MEX file. Remaining arguments of the call are passed to the - add_library()or- add_executable()command.- matlab_add_mex( NAME <name> [EXECUTABLE | MODULE | SHARED] SRC src1 [src2 ...] [OUTPUT_NAME output_name] [DOCUMENTATION file.txt] [LINK_TO target1 target2 ...] [R2017b | R2018a] [EXCLUDE_FROM_ALL] [NO_IMPLICIT_LINK_TO_MATLAB_LIBRARIES] [...] ) - Function Parameters: - NAME
- name of the target. 
- SRC
- list of source files. 
- LINK_TO
- a list of additional link dependencies. The target links to - libmexand- libmxby default, unless the- NO_IMPLICIT_LINK_TO_MATLAB_LIBRARIESoption is passed.
- OUTPUT_NAME
- if given, overrides the default name. The default name is the name of the target without any prefix and with - Matlab_MEX_EXTENSIONsuffix.
- DOCUMENTATION
- if given, the file - file.txtwill be considered as being the documentation file for the MEX file. This file is copied into the same folder without any processing, with the same name as the final mex file, and with extension .m. In that case, typing- help <name>in Matlab prints the documentation contained in this file.
- R2017bor- R2018a
- Added in version 3.14. - May be given to specify the version of the C API to use: - R2017bspecifies the traditional (separate complex) C API, and corresponds to the- -R2017bflag for the mex command.- R2018aspecifies the new interleaved complex C API, and corresponds to the- -R2018aflag for the mex command. Ignored if MATLAB version prior to R2018a. Defaults to- R2017b.
- MODULEor- SHARED
- Added in version 3.7. - May be given to specify the type of library to be created. 
- EXECUTABLE
- Added in version 3.7. - May be given to create an executable instead of a library. If no type is given explicitly, the type is - SHARED.
- EXCLUDE_FROM_ALL
- This option has the same meaning as for - EXCLUDE_FROM_ALLand is forwarded to- add_library()or- add_executable()commands.
- NO_IMPLICIT_LINK_TO_MATLAB_LIBRARIES
- Added in version 3.24. - This option permits to disable the automatic linking of MATLAB libraries, so that only the libraries that are actually required can be linked via the - LINK_TOoption.
 - The documentation file is not processed and should be in the following format: - % This is the documentation function ret = mex_target_output_name(input1) 
