求教一个使用 parallel Python 的问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
acone2003
V2EX    Python

求教一个使用 parallel Python 的问题

  •  
  •   acone2003 2018-12-03 09:35:43 +08:00 3159 次点击
    这是一个创建于 2578 天前的主题,其中的信息可能已经有所发展或是发生改变。
    最近在学习使用 parallel python 模块进行分布式机器学习,遇到了一个问题:写了一个创建学习模型的函数,是分发到各计算节点上的,如下面的代码所示。Param 是一个字典,用于传送要构建模型的宏参数,当我不使用它使用默认的参数时,能够正常工作;当把两个#号去掉,使用传过来的参数时,就不能正常工作了。问一下我的代码错在了哪里?

    ModelName = "LGBMRegressor"
    params = { "max_depth": 1, "num_leaves": 4}

    def CreateModel( ModelName, Params ):
    max_depth, num_leaves = 10, 20
    #if "max_depth" in Params: max_depth = Params[ "max_depth" ]
    #if "num_leaves" in Params: num_leaves = Params[ "num_leaves" ]

    Model, IsClassifier = None, True
    ModelName = ModelName.lower()
    if ModelName == "lgbmregressor":
    IsClassifier = False
    Model = lightgbm.LGBMRegressor( max_depth=max_depth, num_leaves=num_leaves )
    return Model, IsClassifier

    另外我若在本地创建好模型,把模型分发给各计算节点,程序就不能正常工作,如果在节点上创建模型,如上所示,就出现了上面的情况,该怎么解决?
    13 条回复    2018-12-03 16:04:37 +08:00
    acone2003
        1
    acone2003  
    OP
       2018-12-03 09:38:00 +08:00
    各位请注意,代码传上去之后没有缩进了,实际上是有的
    imn1
        2
    imn1  
       2018-12-03 09:47:32 +08:00
    大小写
    sanxidiot
        3
    sanxidiot  
       2018-12-03 09:59:26 +08:00 via Android
    希望 v2 能改善一下对代码显示的支持吧,毕竟好歹也是程序员技术社区啊
    GoLand
        4
    GoLand  
       2018-12-03 10:31:40 +08:00
    @sanxidiot 发帖能用 Markdown,评论能用 gist ?还不完善??
    zhangchioulin
        5
    zhangchioulin  
       2018-12-03 10:32:03 +08:00
    @sanxidiot #3 markdown 不行么。。。都说了是‘程序员技术社区’,那么 markdown 应该都会一点吧。。。就算不会也可以编辑器写完复制进来吧
    XIVN1987
        6
    XIVN1987  
       2018-12-03 10:35:50 +08:00
    @GoLand
    @zhangchioulin
    markdown 会用,,gist 第一次听说,,话说不能发帖、评论都用 markdown 吗??
    zhangchioulin
        7
    zhangchioulin  
       2018-12-03 10:39:00 +08:00
    @XIVN1987 #6 评论涉及到代码就‘ gist ’了吧。发帖 markdown 可用可不用,没有人强制要用 md,但是为了看的更清晰最好还是用 md 吧
    sanxidiot
        8
    sanxidiot  
       2018-12-03 10:44:20 +08:00 via Android
    @zhangchioulin @GoLand 是我孤陋寡闻了,主要是看很多帖子都是直接复制代码,使得排版全无,以为没这些东西的...
    ant2017
        9
    ant2017  
       2018-12-03 10:52:39 +08:00
    if 语句格式不是要换行?
    if "max_depth" in Params:
    max_depth = Params[ "max_depth" ]
    wwg1994
        10
    wwg1994  
       2018-12-03 11:02:11 +08:00
    不能正常工作是 python 报错还是结果不符合预期?
    imn1
        11
    imn1  
       2018-12-03 13:46:47 +08:00
    @ant2017
    @wwg1994
    他前面定义的是小写,后面判断用的是大写,是两个变量
    acone2003
        12
    acone2003  
    OP
       2018-12-03 13:51:45 +08:00
    回 ant2017:换行也不行,试了。
    回 wwg1994: 不是 python 报错,是不出结果。并且 CPU 占用率是 0
    acone2003
        13
    acone2003  
    OP
       2018-12-03 16:04:37 +08:00
    各位有点新进展,我把函数添加了一项,然后使用 xgboost 就没有问题。是不是 lightGBM 要依赖一些别的模块? parallel Python 要求把必要的引用显式地写在代码中。添加后的相关代码如下:

    def CreateModel( ModelName, Params ):
    max_depth, num_leaves, min_child_weight = 10, 20, 1
    if "max_depth" in Params: max_depth = Params[ "max_depth" ]
    if "num_leaves" in Params: num_leaves = Params[ "num_leaves" ]
    if "min_child_weight" in Params: min_child_weight = Params[ "min_child_weight" ]

    Model, IsClassifier = None, True
    ModelName = ModelName.lower()
    if ModelName == "lgbmregressor":
    IsClassifier = False
    Model = lightgbm.LGBMRegressor( max_depth=max_depth, num_leaves=num_leaves )
    elif ModelName == "xgbregressor":
    IsClassifier = False;
    Model = xgboost.XGBRegressor( n_jobs=16, max_depth=max_depth, min_child_weight=min_child_weight )
    return Model, IsClassifier
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1144 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 17:49 PVG 01:49 LAX 09:49 JFK 12:49
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86