GAN版马里奥创作家来了:一个样本即可训练,生成关卡要素丰富
魚羊發(fā)自凹非寺
量子位報道公眾號 QbitAI
對超級馬里奧的關卡太熟悉,想玩點刺激的?
現(xiàn)在,漢諾威大學的研究人員推出了一個新的 GAN,能夠生成船新、可玩的超級馬里奧關卡。
畫風完美統(tǒng)一,難點出其不意:
并且,僅需要一個示例,就可以進行訓練。
比起我這樣的馬里奧亂造家,看上去有邏輯多了。
并且,他們已經把代碼開源啦。
GAN 版馬里奧創(chuàng)作家
在《超級馬里奧制造2》這款游戲里,玩家可以組合不同的關卡零件,憑借自己的靈感創(chuàng)作超級馬里奧關卡。
事實上,這只名為TOAD-GAN的 AI 生成關卡的邏輯也與之類似。
TOAD-GAN 是基于 SinGAN 架構的擴展,能夠生成基于 token 的超級馬里奧關卡。
所謂 token 長這樣:
通過使用級聯(lián)的生成器和判別器,SinGAN 可以僅憑單一圖像,訓練生成模型。
基于這個架構,在訓練中,一個關卡被采樣為N個不同的尺寸。
N 的選擇標準,是生成器和判別器中卷積濾波器的感受野能夠覆蓋最小尺寸下關卡高度的至少一半。
這樣一來,既可以確保關卡中較大的結構被正確建模,也能保障其全局位置的變化。
在空間下采樣的過程中,一些小但重要的結構可能會丟失。為此,研究人員提出了一種保留重要 token 的下采樣方法。
具體步驟如下:
首先,在單樣本編碼的訓練關卡上,使用雙線性下采樣來創(chuàng)建所選尺寸的基礎關卡。
針對每個尺寸中的每個像素,選擇值大于 0 的 token。并從該列表中,保留層次結構中等級最高的 token,將其余 token 設置為0。
然后,在每個像素的所有通道上應用 Softmax。
接著,還需要對較小尺寸的輸出進行雙線性上采樣。
這樣,TOAD-GAN 就可以通過將預定義輸入注入到生成器級聯(lián)中,來執(zhí)行關卡編寫。
研究人員表示,這種應用對于程序內容生成而言十分有趣,因為給定 token,設計者只需指定參考關卡或布局,生成器就會自動創(chuàng)建其變體,對數(shù)據(jù)量的要求并不高。
實驗結果
研究人員對 TOAD-GAN 生成的結果進行了定性對比。
可以看出,與超級馬里奧的原生關卡相比,TOAD-GAN 生成的關卡在保留了風格的基礎上,產生了不同的元素組合方式。
與此前的其他方法不同的是,TOAD-GAN 是一個生成器對應一個關卡。這也就避免了不同類型的關卡風格被混合到一起,造成混亂。
并且,也不會因為依賴于小樣本的問題,而導致(p)中出現(xiàn)的重復情況。
所以,TOAD-GAN 生產成本的游戲關卡在視覺效果上,更加令人信服。
研究人員還用 Baumgarten 等人提出的馬里奧通關 AI,驗證了生成關卡的有效性。通關 AI 能在 65% 的隨機生成關卡中取勝。在原生關卡中,其勝率是 52%。
不只是超級馬里奧
其實,不只是超級馬里奧,研究人員也通過實驗證明,TOAD-GAN 可以生成任何基于 token 的游戲的關卡,比如超級馬里奧賽車。
TOAD-GAN 只用原生賽道樣本進行訓練。
對布局進行種子化處理,就可以保證賽車軌道的連接性和可玩性,還能讓軌道結構與原始樣本產生明顯的不同。
研究人員還表示,下一步他們還會將游戲機制揉進生成過程中,并將 TOAD-GAN 應用于 Minecraft 這樣的像素游戲,或具有非線性關卡結構的迷宮游戲。
傳送門
論文地址:
https://arxiv.org/abs/2008.01531
GitHub 項目地址:
https://github.com/Mawiszus/TOAD-GAN
—完—
總結
以上是生活随笔為你收集整理的GAN版马里奥创作家来了:一个样本即可训练,生成关卡要素丰富的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LoL德玛出装顺序怎样才好,
- 下一篇: 耳朵豆角怎么做好吃呢?