首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用joblib共享变量

如何使用joblib共享变量
EN

Stack Overflow用户
提问于 2016-12-09 22:37:42
回答 1查看 457关注 0票数 1

类似于这个问题How to share a variable in 'joblib' Python library

我想在joblib中共享一个变量。然而,我的问题完全不同,我有一个巨大的变量(2-3 3Gb的RAM),我希望我的所有线程都从它读取。他们永远不会写,比如:

代码语言:javascript
复制
def func(varThatChange, varToRead):
    # Do something over varToRead depending on varThatChange
    return results

def main():
    results = Parallel(n_jobs=100)(delayed(func)(varThatChange, varToRead) for varThatChange in listVars) 

我不能正常地分享它,因为它需要大量的时间来复制变量,而且,我耗尽了内存。

我怎么分享它呢?

EN

回答 1

Stack Overflow用户

发布于 2019-12-21 18:23:34

您可以尝试使用multiprocessing.Manager,例如:

代码语言:javascript
复制
import pandas as pd
import numpy as np
from joblib import Parallel, delayed
from multiprocessing import Manager

manager = Manager()
q = manager.Namespace()
q.arr = np.array([1,2,3,4])

def test(i, q):
    return q.arr[i]

out = Parallel(n_jobs=4)(delayed(test)(i, q) for i in range(4))

输出:

代码语言:javascript
复制
[1, 2, 3, 4]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41062790

复制
相关文章

相似问题

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