首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mlabwrap多处理

Mlabwrap多处理
EN

Stack Overflow用户
提问于 2013-04-22 08:14:11
回答 1查看 830关注 0票数 3

我正在尝试通过python与matlab合作,以创建我开发的系统的原型。mlabwrap能够处理多进程吗?这可能看起来非常愚蠢,但我认为我可以这样做:

代码语言:javascript
复制
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()

但是我一直收到这个错误:

代码语言:javascript
复制
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)也会产生相同的错误

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

EN

回答 1

Stack Overflow用户

发布于 2013-04-22 09:30:47

Matlab本身在M代码级别是单线程的-即M代码解释器只能处理单个并发M代码执行-因此您不能在单个Matlab进程中进行并发处理。

代码语言:javascript
复制
from mlabwrap import mlab
from mlabwrap import mlab as mlab1

此导入只是将mlabmlab1别名为同一个mlabwrap.mlab变量,该变量是一个保存单个mlabwrap实例的类变量,因此即使您将它们传递给不同的进程对象,它们也可能都指向相同的mlabwrap对象,从而指向相同的Matlab会话。(如果使用mlab运行函数一次,使用不带进程对象的mlab1运行一次,那么您就是在进行阻塞调用并按顺序执行它们,因此在共享的Matlab会话中,一次只运行一段M代码,而不是并发执行。)

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16137619

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档