【導(dǎo)讀】這是一篇關(guān)于GAN的零基礎(chǔ)入門(mén)介紹。作者用“制假販子”和“偵探”的比方講起,形象介紹了關(guān)于GAN的概念、組成和運(yùn)作機(jī)制,以及基于GAN常見(jiàn)熱門(mén)應(yīng)用方向等入門(mén)概念性知識(shí)。
目前,人工智能(AI)領(lǐng)域正在快速發(fā)展,每隔一段時(shí)間就取得新的突破。最近突出的一個(gè)詞是Generative Adversarial Network(GAN) - 但這是什么意思?
名詞解釋?zhuān)壕烤故裁词巧蓪?duì)抗網(wǎng)絡(luò)(GAN)?
GAN背后的理念最初是在2014年提出的,在最基本的層面上將,它描述了一個(gè)系統(tǒng),這個(gè)系統(tǒng)中將兩個(gè)AI系統(tǒng)(神經(jīng)網(wǎng)絡(luò))相互對(duì)立,以提高模型輸出結(jié)果的質(zhì)量。
為了理解GAN是如何工作的,可以想象一個(gè)盲人偽造者試圖仿造一幅大師的畫(huà)作。首先,他并不知道這幅畫(huà)應(yīng)該是什么樣子的,但他碰巧有一位朋友對(duì)所有大師的杰作都有照片般的記憶。
這位朋友相當(dāng)于一名偵探,必須確定他的朋友所展示的畫(huà)作是與真正偉大大師創(chuàng)作的畫(huà)作一致,還是明顯的贗品。
這是GAN運(yùn)行的基本機(jī)制--只不過(guò)這位偽造者他的朋友都是AI,行事速度超快,每秒可以制造和檢測(cè)數(shù)千件贗品。然后兩人都從結(jié)果中進(jìn)行“學(xué)習(xí)”,以改善在未來(lái)的表現(xiàn)。偵探在檢測(cè)贗品方面的能力越來(lái)越強(qiáng),要求偽造者必須要把贗品做的更逼真才行。
近年來(lái),由于GAN能夠基于現(xiàn)有的真實(shí)信息建立的規(guī)則制造出“新”信息,因此在人工智能開(kāi)發(fā)領(lǐng)域引起了廣泛關(guān)注。編寫(xiě)說(shuō)明書(shū)可能是一個(gè)典型的例子。開(kāi)發(fā)人員在成千上萬(wàn)的指導(dǎo)手冊(cè)的內(nèi)容作為訓(xùn)練數(shù)據(jù)對(duì)GAN進(jìn)行訓(xùn)練,有朝一日可以創(chuàng)建一個(gè)可以查看任何工具,設(shè)備或軟件的系統(tǒng),再為這個(gè)系統(tǒng)生成一份使用說(shuō)明書(shū)。
如何設(shè)計(jì)了解你感覺(jué)的AI
接下來(lái),讓我們更深入地研究一下GAN的工作機(jī)制。負(fù)責(zé)創(chuàng)建虛假數(shù)據(jù)的“偽造”網(wǎng)絡(luò)被稱為生成網(wǎng)絡(luò),它的工作是閱讀并理解訓(xùn)練數(shù)據(jù)的特征屬性。然后嘗試通過(guò)生成遵循相同規(guī)則的“候選”數(shù)據(jù)集來(lái)復(fù)制這些訓(xùn)練數(shù)據(jù)。
“偵探”網(wǎng)絡(luò)的作用是識(shí)別生成網(wǎng)絡(luò)的輸出數(shù)據(jù)是(人工生成的)假數(shù)據(jù),還是真實(shí)的(訓(xùn)練)數(shù)據(jù),這個(gè)“偵探”稱為判別網(wǎng)絡(luò)。因?yàn)榕袆e網(wǎng)絡(luò)與生成網(wǎng)絡(luò)進(jìn)行對(duì)抗性競(jìng)爭(zhēng),所以整個(gè)系統(tǒng)被描述為“對(duì)抗性網(wǎng)絡(luò)”。
對(duì)于GAN的應(yīng)用實(shí)例,最典型的就是“假臉生成工具”。為網(wǎng)站提供動(dòng)力的網(wǎng)絡(luò)已經(jīng)學(xué)會(huì)了制作人臉的超逼真圖像,雖然這些人臉圖像幾乎完美再現(xiàn)了真實(shí)人臉圖像的一切細(xì)節(jié)特征和規(guī)則,但無(wú)一例外都是計(jì)算機(jī)程序生成的,現(xiàn)實(shí)世界中并不存在。
人們可能存在這樣的固有印象,即計(jì)算機(jī)是將人們的眼睛、耳朵、嘴巴和頭發(fā)的數(shù)據(jù)庫(kù)中的碎片數(shù)據(jù)組合在一起,來(lái)構(gòu)建面部圖像的,但事實(shí)并非如此。生成網(wǎng)絡(luò)的“輸入”數(shù)據(jù)只是一串?dāng)?shù)字,只有判別網(wǎng)絡(luò)才能看到訓(xùn)練數(shù)據(jù)。生成網(wǎng)絡(luò)需要完全基于判別網(wǎng)絡(luò)的輸出來(lái)改善自己的輸出。
作為判別網(wǎng)絡(luò)給出的唯一反饋,是對(duì)生成網(wǎng)絡(luò)輸出是否與訓(xùn)練數(shù)據(jù)匹配的“是或否”的判斷,這個(gè)生成-判斷-再生成的過(guò)程要循環(huán)多次,生成網(wǎng)絡(luò)和判別網(wǎng)絡(luò)的性能不斷提升后,才可能產(chǎn)生與訓(xùn)練輸入足夠相似的人臉圖像輸出。
?。ㄟ@個(gè)例子實(shí)際上借用了去年由Nvidia開(kāi)發(fā)的proGAN模型,該模型在與運(yùn)行過(guò)程中會(huì)逐漸增加生成網(wǎng)絡(luò)輸出的圖像分辨率,從4*4超低分辨率開(kāi)始,最終生成逼真的人臉。)
用于訓(xùn)練對(duì)抗性網(wǎng)絡(luò)的數(shù)據(jù)不必為標(biāo)記數(shù)據(jù),因?yàn)榕袆e網(wǎng)絡(luò)可以完全基于訓(xùn)練數(shù)據(jù)本身的特征來(lái)對(duì)生成網(wǎng)絡(luò)的輸出做出判斷。所以,GAN既可以用于監(jiān)督學(xué)習(xí),也可以用于無(wú)監(jiān)督學(xué)習(xí)和強(qiáng)化學(xué)習(xí)。
GAN的另一個(gè)用處是為其他AI應(yīng)用程序高效地創(chuàng)建訓(xùn)練數(shù)據(jù)集。大多數(shù)當(dāng)前的AI技術(shù),特別是深度學(xué)習(xí)技術(shù),都依賴于海量的訓(xùn)練數(shù)據(jù)。
GAN可以生成遵循“自然”數(shù)據(jù)集的所有規(guī)則的數(shù)據(jù)集,因此理論上可以用于深度學(xué)習(xí)模型的訓(xùn)練。這一點(diǎn)對(duì)于醫(yī)學(xué)成像領(lǐng)域非常有用,收集真實(shí)數(shù)據(jù)成本高、耗時(shí)久,而且需要患者同意,以及大量的醫(yī)學(xué)專(zhuān)業(yè)知識(shí)才能對(duì)其進(jìn)行數(shù)據(jù)標(biāo)記。利用GAN可以有效克服這些障礙。
GAN可用于創(chuàng)建虛構(gòu)的圖像,移動(dòng)視頻,文本甚至是音樂(lè)。雖然近期對(duì)GAN存在著大量炒作,但它顯然是近年來(lái)從AI領(lǐng)域出現(xiàn)的最有趣的新概念之一,我們可以期待在不久的將來(lái)看到更多基于GAN的令人興奮的新應(yīng)用。