欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

baselines示例程序train_cartpole.py的ImportError

 更新時(shí)間:2022年05月20日 12:44:42   作者:微丶念(小礦工)  
這篇文章主要為大家介紹了baselines示例程序train_cartpole.py的ImportError引入錯(cuò)誤詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

問(wèn)題導(dǎo)出

為了更方便地實(shí)現(xiàn)自己的一些想法,我最終還是向OpenAI的baselines屈服了,因?yàn)樽约旱囊恍?shí)現(xiàn)總是難與各大論文給出的結(jié)果進(jìn)行對(duì)比。于是我今天安裝了baselines,其中還是有一些坑的,這里主要介紹在安裝完成之后,運(yùn)行示例時(shí)cartpole.py所遇到的坑,它叫做ImportError。

ImportError

我們先cd到文件夾baselines/baselines/deepq/experiments下,然后運(yùn)行下面語(yǔ)句:

$ python3 train_cartpole.py

然后就報(bào)錯(cuò)了……

從圖中我們可以看出,在文件train_cartpole.py中有如下語(yǔ)句:

from baselines import deepq

而在我們導(dǎo)入deepq的時(shí)候,將會(huì)執(zhí)行deepq文件夾下的__init__.py文件,于是我們打開(kāi)這一文件:

from baselines.deepq import models  # noqa
from baselines.deepq.build_graph import build_act, build_train  # noqa
from baselines.deepq.simple import learn, load  # noqa
from baselines.deepq.replay_buffer import ReplayBuffer, PrioritizedReplayBuffer  # noqa
def wrap_atari_dqn(env):
    from baselines.common.atari_wrappers import wrap_deepmind
    return wrap_deepmind(env, fram_stack=True, scale=True)

在報(bào)錯(cuò)中,提到了上面的這一語(yǔ)句:

from baselines.deepq.simple import learn, load  # noqa

同時(shí),報(bào)錯(cuò)中提到,在simple.py中有:

from baselines import deepq

問(wèn)題漸漸明朗了,在我們import deepq的時(shí)候,將要執(zhí)行__init__.py文件,這個(gè)文件將會(huì)從simple.py中把learn和load導(dǎo)入到deepq的命名空間下。而simple.py又想要import deepq,這也就構(gòu)成了所謂的“Looping Import”。那我們應(yīng)該如何解決呢?

我們先將simple.py中的下面這條語(yǔ)句注釋掉:

from baselines import deepq

然后運(yùn)行:

$ python3 train_cartpole.py

發(fā)現(xiàn)又出錯(cuò)了:

不過(guò)這個(gè)錯(cuò)誤是肯定會(huì)出的,我們無(wú)緣無(wú)故注釋掉了人家寫的一個(gè)import語(yǔ)句,能不錯(cuò)嘛。不過(guò)不要慌,我們繼續(xù)分析,為什么這里要import deepq呢?就是為了執(zhí)行下面的語(yǔ)句:

act = deepq.build_act(**act_params)
...
act, train, update_target, debug = deepq.build_train(...)

這里因?yàn)槲覀冊(cè)赺_init__.py中將build_act和build_train方法導(dǎo)入到了deepq的命名空間下,所以這里可以直接在deepq的命名空間中去調(diào)用build_act和build_action。

如果我們要在simple.py文件中使用deepq.build_act的話,那么必然要在simple.py中導(dǎo)入deepq,而且也需要在__init__.py中導(dǎo)入simple,這么一來(lái),就會(huì)出現(xiàn)“Looping Import”問(wèn)題了。

解決方案

所以我們選擇的解決方案是:

a) 將__init__.py中的下列語(yǔ)句注釋掉:

from baselines.deepq.build_graph import build_act, build_train # noqa

b) 將simple.py中的下列語(yǔ)句換掉:

from baselines import deepq

換為:

from baselines.deepq.build_graph import build_act, build_train

c) 修改下列語(yǔ)句:

act = deepq.build_act(**act_params)
...
act, train, update_target, debug = deepq.build_train(...)

改為:

act = build_act(**act_params)
...
act, train, update_target, debug = build_train(...)

d) 運(yùn)行:

$ python3 train_cartpole.py

OK,問(wèn)題解決。

對(duì)了,在OpenAI Baselines里面,有一些代碼用到了Python3.6的特性,比如直接(None, *tuple),這在Python3.4是不允許的,所以建議大家直接安裝conda環(huán)境,并裝好Python3.6。

以上就是baselines示例程序train_cartpole.py的ImportError的詳細(xì)內(nèi)容,更多關(guān)于train_cartpole.py的ImportError的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論