<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
為了更方便地實現自己的一些想法,我最終還是向OpenAI的baselines屈服了,因為自己的一些實現總是難與各大論文給出的結果進行對比。於是我今天安裝了baselines,其中還是有一些坑的,這裡主要介紹在安裝完成之後,執行範例時cartpole.py所遇到的坑,它叫做ImportError。
我們先cd到資料夾baselines/baselines/deepq/experiments下,然後執行下面語句:
$ python3 train_cartpole.py
然後就報錯了……
從圖中我們可以看出,在檔案train_cartpole.py中有如下語句:
from baselines import deepq
而在我們匯入deepq的時候,將會執行deepq資料夾下的__init__.py檔案,於是我們開啟這一檔案:
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)
在報錯中,提到了上面的這一語句:
from baselines.deepq.simple import learn, load # noqa
同時,報錯中提到,在simple.py中有:
from baselines import deepq
問題漸漸明朗了,在我們import deepq的時候,將要執行__init__.py檔案,這個檔案將會從simple.py中把learn和load匯入到deepq的名稱空間下。而simple.py又想要import deepq,這也就構成了所謂的“Looping Import”。那我們應該如何解決呢?
我們先將simple.py中的下面這條語句註釋掉:
from baselines import deepq
然後執行:
$ python3 train_cartpole.py
發現又出錯了:
不過這個錯誤是肯定會出的,我們無緣無故註釋掉了人家寫的一個import語句,能不錯嘛。不過不要慌,我們繼續分析,為什麼這裡要import deepq呢?就是為了執行下面的語句:
act = deepq.build_act(**act_params) ... act, train, update_target, debug = deepq.build_train(...)
這裡因為我們在__init__.py中將build_act和build_train方法匯入到了deepq的名稱空間下,所以這裡可以直接在deepq的名稱空間中去呼叫build_act和build_action。
如果我們要在simple.py檔案中使用deepq.build_act的話,那麼必然要在simple.py中匯入deepq,而且也需要在__init__.py中匯入simple,這麼一來,就會出現“Looping Import”問題了。
所以我們選擇的解決方案是:
a) 將__init__.py中的下列語句註釋掉:
from baselines.deepq.build_graph import build_act, build_train # noqa
b) 將simple.py中的下列語句換掉:
from baselines import deepq
換為:
from baselines.deepq.build_graph import build_act, build_train
c) 修改下列語句:
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) 執行:
$ python3 train_cartpole.py
OK,問題解決。
對了,在OpenAI Baselines裡面,有一些程式碼用到了Python3.6的特性,比如直接(None, *tuple),這在Python3.4是不允許的,所以建議大家直接安裝conda環境,並裝好Python3.6。
以上就是baselines範例程式train_cartpole.py的ImportError的詳細內容,更多關於train_cartpole.py的ImportError的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45