2013-04-22 75 views
3

我想通过python使用matlab来创建我开发的系统的原型。 mlabwrap是否能够处理多处理?这可能会遇到非常愚蠢的,但我想我可以做到以下几点: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])也会给出相同的错误

注意: 我知道我不应该为我的代码的最终产品做这种事情。我不会在最终版本中这样做,我只想得到一个演示工作。

回答

1

Matlab本身是M代码级别的单线程 - 也就是说,M代码解释器只能处理单个并发的M代码执行 - 所以你将无法在一个单一的内部进行并发处理Matlab程序。

from mlabwrap import mlab 
from mlabwrap import mlab as mlab1 

这只是进口别名都mlabmlab1相同的mlabwrap.mlab变量,它是一个类变量单持有mlabwrap实例,因此他们很可能都在同一mlabwrap对象,因此相同的Matlab的会议指出即使将它们传递给不同的Process对象也是如此。 (如果你用mlab运行一次函数,再用mlab1运行没有Process对象的函数,那么你正在进行阻塞调用并按顺序执行它们,所以在共享的Matlab会话中,一次只运行一段M代码,而不是并发执行。)

为了使这个工作,你需要为每个并行进程启动一个单独的Matlab会话。您可以通过为每个进程创建一个新的mlabwrap对象来实现此目的,而不是仅仅重用mlabMlabwrap在幕后使用Matlab引擎;我不知道它是否支持从单个程序运行多个引擎实例, engOpen documentation没有指定。但是如果是这样,使用多个mlabwrap对象可能会暴露它为您的Python代码,因为mlabwrap.__init__代码尝试在构建时打开一个新的引擎。

+0

我试过了,可能是这种情况,但是我仍然需要mlabwrap不能在一个进程中运行的基础错误(这是上述错误的来源,我得到它,无论是否不是我调用另一个进程,只要我在一个进程中使用mlabwrap,我得到这个错误,并且没有计算运行) – Mark 2013-04-22 18:46:36

+0

你可以通过在工作进程中构建'mlabwrap'对象来取代在主(调用)过程中构造它并将其作为对象传递。那样的话,Matlab Engine库就会被加载并初始化到后面的Matlab调用所发生的相同的过程中。也许你可以启动一个worker的multiprocessing.Pool,每个都加载Matlab引擎,然后将它们发送给Matlab要求。让每个人都运行一个函数来初始化一个mlabwrap,然后读取一个队列或其他函数来应用它。 – 2013-04-22 20:02:39