我正在尝试使用matlab通过python来构建我开发的系统。 mlabwrap是否能够处理多处理?这可能会非常愚蠢,但我认为我可以做到以下几点:
from multiprocessing import Process,Lock
from mlabwrap import mlab
from mlabwrap import mlab as mlab1
def some_Function(mlab,Astring)
#do some stuff....
p1=Process(target=some_Function,args=(mlab,"Example string 1"))
p2=Process(target=some_Function,args=(mlab1,"Example string 2"))
p1.start()
p2.start()
但我一直收到这个错误:
Traceback (most recent call last):
File "/usr/lib64/python2.6/multiprocessing/process.py", line 232, in _bootstrap
self.run()
File "/usr/lib64/python2.6/multiprocessing/process.py", line 88, in run
self._target(*self._args, **self._kwargs)
File "test.py", line 15, in process_Camera
res=mlab.RetrieveAndProcess(cameraDirectory)
File "/home/mar608/data/cameraSystem/mlabwrap-1.1/build/lib.linux-x86_64-2.6/mlabwrap.py", line 607, in mlab_command
return self._do(name, *args, **update({'nout':nout}, kwargs))
File "/home/mar608/data/cameraSystem/mlabwrap-1.1/build/lib.linux-x86_64-2.6/mlabwrap.py", line 515, in _do
mlabraw.eval(self._session, "cd('%s');" % os.getcwd().replace("'", "''"))
error: Unable to evaluate string in MATLAB(TM) workspace
注意,当我经常运行该函数时,即使我使用mlab和mlab1再次运行该函数,也不会出现此错误。它只发生在我作为一个进程运行它时,无论我是否用它运行另一个进程,它都会发生。
任何提示都将不胜感激!
请注意,所有matlab函数都会发生这种情况。例如,调用mlab.sum([2,3])也会产生相同的错误
注意: 我知道我不应该为我的代码的最终产品做这种事情。我不会在最终版本中这样做,我只是想让一个演示工作。
答案 0 :(得分:1)
Matlab本身在M代码级别是单线程的 - 也就是说,M代码解释器只能处理单个并发M代码执行 - 因此您将无法在单个Matlab内部进行并发处理过程
from mlabwrap import mlab
from mlabwrap import mlab as mlab1
此导入只将mlab
和mlab1
同名为同一个mlabwrap.mlab
变量,该变量是一个包含单个mlabwrap
实例的类变量,所以它们可能都是指向相同的mlabwrap对象,因此即使将它们传递给不同的Process对象,也会指向相同的Matlab会话。 (如果你使用mlab运行一次函数,再使用没有Process对象的mlab1运行,你就会进行阻塞调用并按顺序执行它们,所以在共享的Matlab会话中,一次只运行一段M代码,而不是并发执行。)
要使其工作,您需要为每个并行进程启动单独的Matlab会话。您可以通过为每个流程创建新的mlabwrap
对象来实现此目的,而不是仅仅重用mlab
。 Mlabwrap
在幕后使用Matlab引擎;我不知道它是否支持从单个程序运行多个引擎实例; engOpen
documentation未指定。但如果确实如此,使用多个mlabwrap
对象可能会为您的Python代码公开它,因为mlabwrap.__init__
代码在构造时会尝试打开新引擎。