MATLAB: MATLAB, Compiled MATLAB, Coder differences

matlab coderMATLAB Compilerspeed

Lets say I have a moderately complex calculation that is limited by the CPU, requires no "crap" (e.g., graphics, user input, symbolic math, and GPU processing) and is fully compliant with the limitations of the MATLAB compiler and the MATLAB coder. If I want to run this application on N machines (each with a license of MATLAB) do I run MATLAB, compile it and run the executable with MCR, or use the coder and run the executable?
My hunch is that the coder will produce slightly/significantly slower code, but then again, maybe the coder is really smart and it will produce faster code.
Maybe the questions are: If you have an abundance of MATLAB licenses is there any reason to use the compiler or coder? Are there disadvantages of using the compiler or coder?

Best Answer

I flipped through the list of supported Coder functions, and it appeared to me that except perhaps for some boundary conditions, they were routines that could be relatively readily implemented using the standard C library. As the resulting C code would not require any interpreter level, I would expect that the C code would usually be faster.
I would not expect that the C code would always be faster, however: the trade-off of using the standard C library is that one would not be calling upon highly tuned cpu-specific math libraries such as LAPACK -- routines which are usually not invoked until the problem is "sufficiently big" (due to the overhead of marshaling the data from MATLAB storage in to the form expected by the routines).