MATLAB: Code ran by (C++ API call) engEvalString() is slower

apiMATLAB

I noticed something disturbing. Executing Matlab code from C++ with the API call to engEvalString() runs twice as slow than running it within matlab.
I profiled and also manually timed the code. It's just Matlab basic operations and it has nothing to do with the overhead calling it from outside.
To emphasize, I'm NOT talking about the overhead of the API call. I am measuring the time of the pure Matlab code itself (running within the engine), and it runs slower.
(I'm using Matlab R2016a.)

Best Answer

I found the problem. Before running eval, there was a separate eval of:
clear functions;
This cleared Yalmip's init, and there was a Yalmip overhead re-initializing.