MATLAB on AMD Ryzen Threadripper CPUs - hasselmonians/knowledge-base GitHub Wiki
Originally posted in r/matlab on Reddit
Matlab runs notoriously slow on AMD CPUs for operations that use the Intel Math Kernel Library (MKL). This is because the Intel MKL uses a discriminative CPU Dispatcher that does not use efficient codepath according to SIMD support by the CPU, but based on the result of a vendor string query. If the CPU is from AMD, the MKL does not use SSE3-SSE4 or AVX1/2 extensions but falls back to SSE1 no matter whether the AMD CPU supports more efficient SIMD extensions like AVX2 or not.
The method provided here does enforce AVX2 support by the MKL, independent of the vendor string result.
EDIT: Before you start I have a short request for you that you could help me with and serve your own interest. Matlab will not implement this fix as it is based on an unofficial debug mode of the MKL. If you think that Matlab should offer a permanent solution that serves all users independently of whether they use Intel or AMD CPUs, please make a feature request at Matlab to implement a nummeric library (e.g. OpenBLAS) that does not discriminate against non Intel CPUs. Mathworks will not make this change without people advocating for it. Thanks!
tl;dr:
WINDOWS:
You'll read below "How To" force the MKL to use AVX2 on AMD Ryzen or Threadripper CPUs. Performance gains on my 2600x are between 20% and 300% depending on the type of numeric operation.
Benchmark result comparison.
Benchmark taken from here Post image
Integrated benchmark results: Post image
Feedback is appreciated in the comments section.
Disclaimer: I OF COURSE DO NOT TAKE RESPONSIBILITY FOR ISSUES RESULTING IN USING THIS TWEAK. USE ON AMD RYZEN OR THREADRIPPER ONLY. DOES NOT WORK ON INTEL OR OLDER AMD CPUs.
Solution 1 (Windows - no admin rights needed):
Create a .bat file with the following lines to start Matlab in AVX2 Mode
@echo off set MKL_DEBUG_CPU_TYPE=5 matlab.exe
This is straight forward. You open Notepad, copy and paste the above three lines and save the file as Matlab-AVX2. Notepad will save the file as Matlab-AVX2.txt. Now replace the extension ".txt" with ".bat".
If you double-click that file, Matlab will start the MKL in AVX2 Mode. If you start it the normal way, it will remain as always.
You can also download the .bat file from my HiDrive if you trust me (which you of course should not, as I am a random guy in the Internet). If you delete the startup batch file provided in the download or the one you created yourself, its gone and your computer will be as it has been before.
(Optional Download: https://my.hidrive.com/lnk/EHAACFje )
Solution 2 (Windows - admin rights needed): If you are happy with the results (which you will be :-)), you should make the setting permanent by entering MKL_DEBUG_CPU_TYPE=5 into the System Environment Variables. This has several advantages, one of them being that it applies to all instances of Matlab and not just the one opened using the .bat file. Post image
Image courtesy, Dr. F. Haiss, and many thanks for testing on a Threadripper!
You can do this either by editing the Environmental Variables as shown above, or by opening a command prompt (CMD) with admin rights and typing in:
setx /M MKL_DEBUG_CPU_TYPE 5
Doing this will make the change permanent and available to ALL Programs using the MKL on your system until you delete the entry again from the variables.
LINUX: (Thanks to foreignrobot)
Simply type in a terminal:
export MKL_DEBUG_CPU_TYPE=5
and then run matlab from the same terminal.
For benchmarking, you can use this script:
https://www.reddit.com/r/matlab/comments/cdru43/update_performance_of_various_cpus_in_matrix/
Permanent solution for Linux:
echo 'export MKL_DEBUG_CPU_TYPE=5' >> ~/.profile
will apply the setting profile-wide, so you can launch it either through a terminal or the graphical launcher. (Thanks to incrazyboyy)