0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

Dota2敗給OpenAI-Five究竟是為什么?

mK5P_AItists ? 來源:電子發(fā)燒友網(wǎng) ? 作者:工程師譚軍 ? 2018-07-05 16:17 ? 次閱讀

OpenAI昨日發(fā)布研究成果,宣布Dota2 5v5在限定條件下(英雄陣容固定,部分道具和功能禁用)戰(zhàn)勝人類半職業(yè)選手。本文主要對其模型技術架構做一些分析總結。

一、 模型輸入與輸出

模型的輸入是使用RAM(內(nèi)存信息),如位置坐標,技能血量數(shù)值狀態(tài)等,而不是圖像像素信息。

模型輸入主要分為兩個部分:

直接觀測的信息:場面其他英雄的絕對位置,相對距離,相對角度,血量,狀態(tài)等。

人工定義抽象的信息:是否被攻擊以及正在被誰攻擊,炮彈距離命中的時間,朝向的cos與sin,最近12幀內(nèi)的英雄的血量變化等。

模型的輸出即是指AI所選擇的動作,包括移動,攻擊釋放技能等。OpenAI將連續(xù)的動作,離散化對應到網(wǎng)格,并對各種技能定制化釋放動作,以減少動作空間的大小。以下圖為例,AI要釋放一個攻擊技能,需要選取這個技能,并選擇一個目標單位周圍網(wǎng)格內(nèi)的一個位置:

值得注意的是,在Dota2游戲內(nèi)還有其他動作,例如操控信使,購買裝備,技能升級與天賦等,這些都是人工定義好,而不需AI決策的。而操控幻象分身,召喚物等涉及更復雜的多單位操作,則未在OpenAI當前版本的考慮范圍內(nèi)。

二、 網(wǎng)絡架構與訓練方式

網(wǎng)絡架構架構局部如下圖:

Dota2敗給OpenAI-Five究竟是為什么?

模型大圖下載鏈接:https://d4mucfpksywv.cloudfront.net/research-covers/openai-five/network-architecture.pdf

總的來看,大量信息通過連接(concatenate)與全連接層(dense)層進行綜合,作為1024維的LSTM的輸入。LSTM綜合時序信息,并輸出決策向量,再用決策向量解構出詳細動作。

訓練方式:

純自我對弈訓練。

隨機化訓練:隨機初始狀態(tài)(血量速度移動等)的訓練,以增強泛化能力。

使用很高的γ=0.9997。γ為獎勵衰減值,一般在其他環(huán)境中設置為0.98,0.998。

大量計算:128,000CPU+256GPU,能做到每天模擬玩180年的游戲。

獎勵(reward)設計:

總體獎勵:當前局面評估(塔的情況等),KDA(個人戰(zhàn)績),補兵表現(xiàn)等。

合作獎勵:全隊的表現(xiàn)作為自己獎勵的一部分。

分路對線的獎勵與懲罰:最開始分配一條路,前期發(fā)育時如果偏離就會懲罰。

三、 總結

用強化學習玩Dota2需要面對4個挑戰(zhàn):狀態(tài)空間大,局面不完全可見(有視野限制),動作空間大,時間尺度大。

近期論文中提出的解決方案,大致有以下幾個方向:

狀態(tài)空間大:解決方法如先用World Models抽象,再進行決策。

局面不完全可見:一般認為需要進行一定的搜索,如AlphaGo的MCTS(蒙特卡洛樹搜索)。

動作空間大:可以使用模仿學習(Imitation Learning),或者與層次強化學習結合的方法。

時間尺度大:一般認為需要時間維度上的層次強化學習(Hierarchical Reinforcement Leanring)來解決這個問題。

而神奇的是,OpenAI沒有使用上述任一方法,而僅僅使用高γ值的PPO基礎算法,就解決了這些問題。這說明憑借非常大量的計算,強化學習的基礎算法也能突破這些挑戰(zhàn)。

OpenAI沒有使用的WorldModels,MCTS,IL,HRL等方法,既是學術界研究的重點方向,也是OpenAI-Five潛在的提升空間。這些更高效的方法若被合理應用,可以加快模型的學習速度,增強模型的遷移能力,并幫助模型突破當前的限制。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • AI
    AI
    +關注

    關注

    87

    文章

    30947

    瀏覽量

    269213
  • 模型
    +關注

    關注

    1

    文章

    3248

    瀏覽量

    48864

原文標題:技術架構分析:攻克Dota2的OpenAI-Five

文章出處:【微信號:AItists,微信公眾號:人工智能學家】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    DotA2》同時在線人數(shù)首次突破100萬,全民打年獸?

    早在2015年22日,Steam同時在線人數(shù)最高曾超過840萬名PC玩家。當時根據(jù)Steam統(tǒng)計,當時《DotA2》是玩的人最多的游戲,其次是《CS:GO》,《軍團要塞2》,《足球經(jīng)
    發(fā)表于 02-26 15:06

    圖解:IGBT究竟是什么?

    圖解:IGBT究竟是什么? IGBT究竟是什么?
    發(fā)表于 08-10 08:01

    S參數(shù)究竟是什么?

    S參數(shù)究竟是什么?起決定性作用的S參數(shù)將S參數(shù)擴展到多端口器件和差分器件
    發(fā)表于 03-01 11:46

    我們仿真DDR究竟是仿真什么

    我們仿真DDR究竟是仿真什么?
    發(fā)表于 03-04 07:32

    電感飽和究竟是什么

    電感飽和究竟是什么
    發(fā)表于 03-11 08:13

    真正軟件定義無線電究竟是怎樣的?

    真正軟件定義無線電究竟是怎樣的?
    發(fā)表于 05-14 06:47

    分貝究竟是什么?如何去理解它?

    分貝究竟是什么?如何去理解它?
    發(fā)表于 05-31 07:05

    一文讀懂eMMC究竟是啥?

    eMMC究竟是啥?eMMC長什么樣?eMMC用在哪?主要是干嘛用的?eMMC究竟是如何工作的呢?
    發(fā)表于 06-18 06:04

    spec究竟是什么?有誰可以分享一下嗎

    spec究竟是什么?哪位同行可以幫忙分享下DFI 5.0的spec?
    發(fā)表于 06-21 07:16

    AI在簡化了的DOTA2擊敗前1%玩家,學習能力很出色

    ”、沒有隱身裝備、沒有召喚單位和幻象、以及少了一些裝備等。這也使整個比賽簡化了不少,從另一個角度看AI仍然沒能力完全加入人類版的DOTA2游戲中。
    發(fā)表于 06-29 19:39 ?606次閱讀

    AI也能相互協(xié)作的玩游戲,玩Dota2戰(zhàn)勝了人類玩家

    據(jù)悉,OpenAI開發(fā)了出了一套名為“OpenAI Five”的算法,雖然單獨來看這種算法并沒有什么突破,只是針對玩Dota2的一種神經(jīng)網(wǎng)絡,并且此前也曾有AI算法在1對1的
    發(fā)表于 06-27 05:29 ?625次閱讀

    AI之間能團隊合作嗎?AI團隊挑戰(zhàn)Dota2職業(yè)選手團隊

    近日,馬斯克和Sam Altman所創(chuàng)立的人工智能非營利組織OpenAI宣布:其開發(fā)的AI能夠組隊在5V5對戰(zhàn)中戰(zhàn)勝Dota2頂尖業(yè)余玩家,這些人類玩家的平均天梯分數(shù)超過4200分。這也是繼阿爾法狗
    的頭像 發(fā)表于 07-17 11:51 ?3505次閱讀

    OpenAI FiveDota2國際競賽TI8中進行首次對戰(zhàn)以失敗告終

    OpenAI Five是一個由5個人工神經(jīng)網(wǎng)絡組成的隊伍,可以把它想象成一個模擬的“大腦”,是專門為學習Dota而設計的。OpenAI Five
    的頭像 發(fā)表于 08-24 08:53 ?5189次閱讀

    人工智能戰(zhàn)隊OpenAI將戰(zhàn)Dota2人類最強戰(zhàn)隊的最終決戰(zhàn)

    人工智能戰(zhàn)隊OpenAI將戰(zhàn)Dota2人類最強戰(zhàn)隊,人工智能在圍棋上擊敗人類之后,很多技術人員就開始展望 AI 在視頻游戲中的表現(xiàn)了。2017 年的 Dota2 國際邀請賽 TI7 上,Ope
    發(fā)表于 07-04 11:09 ?1398次閱讀

    S參數(shù)究竟是什么?

    S參數(shù)究竟是什么?
    發(fā)表于 11-01 08:24 ?2次下載
    S參數(shù)<b class='flag-5'>究竟是</b>什么?