42
votes

I have been using Octave and MATLAB for a few projects, and I've come across a few questions. This question Why/when should I prefer MATLAB over Octave?) answered several, but there is still one lingering...

I've read a number of posts/other sources comparing performance of Octave and MATLAB, and I've run some of my own tests on standard scripts that confirm the general consensus that Octave is generally much slower than MATLAB for standard operations (iterated, of course, so that the comparison is meaningful).

The consensus also seems to suggest that most of MATLAB's performance boost is attributable to its JIT compiler, which compiles large loops at runtime. This makes sense, and the largest performance differences appear to occur in these cases (e.g Mathworks Matlab vs Gnu Octave)

My question is the following: why should it be the case that vectorized code also runs more slowly in Octave? It seems that in this case memory should be set aside before the loop and some native C/C++ loop should perform the operation, which would equate performance between Octave and MATLAB for vectorized code. Additionally, does this have broader implications, i.e. that Octave might perform more poorly for complex operations, even if code is written such that a JIT compiler is unneeded/unused?

2
A lot has been written about Matlab's JIT improving performance, Matlab's JIT is unable to inline function calls, and I am uncertain as to how well it can optimize FOR loops given the odd performance differentials between a FOR loop in Matlab and JAVA (which has a working JIT). All implementations of interpreted languages have a JIT, but Matlab's is on the rather weak end.Mikhail
“All implementations of interpreted languages have a JIT“ is simply not true.Cris Luengo

2 Answers

41
votes

There are four ways how Matlab code gets sped up:

  • JIT: compiling at runtime helps with loops but seems to speed up (or at least interact with) other parts of the code as well, according to my anecdotal observations.

  • Implementing functions in C/C++: There's a bunch of Matlab/Octave functions that are implemented in Matlab/Octave. At every release, there's a bunch more of them that get made into built-ins.

  • Multithreading: There's a list of functions that have multithreaded implementations, which will speed up function calls.

  • Generally more efficient implementations. For example the median filter got a massive speed boost for integer inputs a few releases ago.

All of these approaches need developers dedicated to make code faster. As far as I know, a major concern of Octave developers is to make sure (Matlab) functionality is there at all, whereas performance increase seems to have been a focus of Matlab development in the last few years.

19
votes

Matlab internally uses Intel Math Kernel Library (Intel MKL) for vector and matrix operations. This gives Matlab a significant advantage over Octave.

Try the commands 'version -lapack' and 'version -blas' in your Matlab to check the version of MKL your Matlab is using.

A quick link which discuss the usage of MKL by Matlab is http://stanford.edu/~echu508/matlab.html .

Intel MKL is proprietary. software.intel.com/en-us/intel-mkl . However, for non-commercial use, the Linux version is free. If Octave can somehow use the MKL installed on our machines, it should significantly speed up Octave.