Effacer les filtres
Effacer les filtres

MATLAB Engine for Python is very slow

37 vues (au cours des 30 derniers jours)
serafeim loukas
serafeim loukas le 1 Nov 2021
Commenté : Alan Frankel le 12 Mar 2024
I have a main python script and I want to call a Matlab function (spm_filter.m) on an array.
I use something like the following in a jupyter notebook:
import matlab.engine
eng = matlab.engine.start_matlab()
y_filtered = np.asarray(eng.spm_filter(filter_kernel, matlab.double(data.tolist()) ,nargout=1))
This works fine but it is extremely slow compared to the case where I use only Matlab to do the same thing e.g. by doing:
y_filtered = spm_filter(filter_kernel, data)
Why is the matlab engine so slow? How can I make it faster?

Réponses (1)

Alan Frankel
Alan Frankel le 8 Juin 2022
The performance in R2022a is orders of magnitude better than in previous releases, as described in the release notes. See the item "MATLAB Engine API for Python: Improved performance with large multidimensional arrays in Python" under the "Performance" section. As mentioned there, converting a Python array of size 10^8 to a MATLAB double array is about 12x faster than in the previous release, and executing the sum() function (including data conversion between Python and MATLAB) is about 110x faster than in the previous release.
  4 commentaires
Mitchell Tillman
Mitchell Tillman le 11 Mar 2024
Modifié(e) : Mitchell Tillman le 11 Mar 2024
@Alan Frankel I was having some performance issues with sending a 30MB variable from Python to MATLAB and so just upgraded from R2021b to R2023b and performance was way worse - there's a memory leak now (RAM useage shot up over 20GB in just a minute or two, which did not happen before) and a function that used to take ~0.2 seconds now took 0.5 - 1.5 seconds to run (this is untenable because I need to run it many times).
Is there any reason to suspect that R2022a performs better than R2023b? Going to downgrade back to R2021b so I can benchmark the two versions.
Edit: the attached images shows memory useage over time running many iterations of the same function I mentioned above, in R2021b and R2023b. I also posted a question expanding on my issue.
Alan Frankel
Alan Frankel le 12 Mar 2024
As I posted on your question, I'm unable to reproduce your results.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Call MATLAB from Python dans Help Center et File Exchange

Produits


Version

R2021a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by