我目前正在做一个项目,我需要使用遗留的 Matlab 代码(使用 Matlab 引擎)和 Python(numpy)中的其余部分进行处理。
我注意到将结果从 Matlab 转换matlab.mlarray.double
为 numpynumpy.ndarray
似乎非常缓慢。
下面是一些示例代码,用于创建一个包含来自另一个 ndarray、一个列表和一个 mlarray 的 1000 个元素的 ndarray:
import timeit
setup_range = ("import numpy as np\n"
"x = range(1000)")
setup_arange = ("import numpy as np\n"
"x = np.arange(1000)")
setup_matlab = ("import numpy as np\n"
"import matlab.engine\n"
"eng = matlab.engine.start_matlab()\n"
"x = eng.linspace(0., 1000.-1., 1000.)")
print 'From other array'
print timeit.timeit('np.array(x)', setup=setup_arange, number=1000)
print 'From list'
print timeit.timeit('np.array(x)', setup=setup_range, number=1000)
print 'From matlab'
print timeit.timeit('np.array(x)', setup=setup_matlab, number=1000)
这需要以下时间:
From other array
0.00150722111994
From list
0.0705359556928
From matlab
7.0873282467
转换所需的时间大约是列表转换的 100 倍。
有什么方法可以加快转换速度吗?