Theano error when fitting a PyMC3 model in parallel No module named'tmpttugnbtl'并行拟合PyMC3模型时无错误

2024-04-20 12:14:44 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在使用joblibmultiprocessing模块将相同的PyMC3模型并行地适配到不同的数据集,我遇到了一个奇怪的错误。你知道吗

尽管该模型适用于绝大多数数据集,但对于随机子集,它失败了,下面是错误消息:

Traceback (most recent call last):
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/externals/loky/process_executor.py", line 418, in _process_worker
    r = call_item()
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/externals/loky/process_executor.py", line 272, in __call__
    return self.fn(*self.args, **self.kwargs)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/_parallel_backends.py", line 567, in __call__
    return self.func(*args, **kwargs)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/parallel.py", line 225, in __call__
    for func, args, kwargs in self.items]
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/parallel.py", line 225, in <listcomp>
    for func, args, kwargs in self.items]
  File "fit_ogle3_2002.py", line 80, in fit_event
    pspl_model, alert_time  = initialize_model(event)
  File "/gpfs1/home/fb90/hierarchical/fit_albrow/model.py", line 88, in initialize_model
    mean = f*F_base*mag + (1 - f)*F_base
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/tensor/var.py", line 155, in __mul__
    return theano.tensor.mul(self, other)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/op.py", line 670, in __call__
    no_recycling=[])
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/op.py", line 955, in make_thunk
    no_recycling)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/op.py", line 858, in make_c_thunk
    output_storage=node_output_storage)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cc.py", line 1217, in make_thunk
    keep_lock=keep_lock)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cc.py", line 1157, in __compile__
    keep_lock=keep_lock)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cc.py", line 1624, in cthunk_factory
    key=key, lnk=self, keep_lock=keep_lock)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cmodule.py", line 1148, in module_from_key
    module = self._get_from_key(key)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cmodule.py", line 1047, in _get_from_key
    return self._get_module(name)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cmodule.py", line 720, in _get_module
    self.module_from_name[name] = dlimport(name)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/theano/gof/cmodule.py", line 317, in dlimport
    rval = __import__(module_name, {}, {}, [module_name])
ModuleNotFoundError: No module named 'tmpttugnbtl'
"""

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "fit_ogle3_2002.py", line 153, in <module>
    result = Parallel(n_jobs)(delayed(fit_event)(directory) for directory in dirs)
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/parallel.py", line 934, in __call__
    self.retrieve()
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/parallel.py", line 833, in retrieve
    self._output.extend(job.get(timeout=self.timeout))
  File "/home/fb90/anaconda3/lib/python3.7/site-packages/joblib/_parallel_backends.py", line 521, in wrap_future_result
    return future.result(timeout=timeout)
  File "/home/fb90/anaconda3/lib/python3.7/concurrent/futures/_base.py", line 425, in result
    return self.__get_result()
  File "/home/fb90/anaconda3/lib/python3.7/concurrent/futures/_base.py", line 384, in __get_result
    raise self._exception
ModuleNotFoundError: No module named 'tmpttugnbtl'

No module named 'tmpttugnbtl'到底是什么意思:S?你知道吗

我使用的是PyMC3的版本3.7和Theano的版本1.0.4。代码使用以下行并行化

from joblib import Parallel, delayed
import multiprocessing

n_jobs = 32
result = Parallel(n_jobs)(delayed(fit_event)(directory) for directory in dirs)

Tags: inpyselfhomelibpackageslinesite