成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

AI系統首次實現真正自主編程:利用遺傳算法,完爆初級程序員

新聞 人工智能 算法
現在,來自彭博和英特爾實驗室的兩位研究人員,號稱實現了首個能夠自動生成完整軟件程序的AI系統“AI Programmer”,這個“AI程序員”利用遺傳算法和圖靈完備語言,開發的程序理論上能夠完成任何類型的任務。AI自動編程的時代,大幕已開。

編者按:本文由微信公眾號“新智元”(ID:AI_era)編譯,來源:arXiv,編譯:聞菲,常佩琦,36氪經授權發布。

讓AI自動編程是人工智能領域長久以來的夢想之一。現在,來自彭博和英特爾實驗室的兩位研究人員,號稱實現了首個能夠自動生成完整軟件程序的AI系統“AI Programmer”,這個“AI程序員”利用遺傳算法和圖靈完備語言,開發的程序理論上能夠完成任何類型的任務。AI自動編程的時代,大幕已開。

讓AI自動編程一直是計算機科學家的夢想。目前這個方面的成果還非常有限,比如讓AI自動補完編程語言,或者執行簡單的加法程序。今天我們要介紹的這項工作,號稱是第一個能夠全自動生成完整軟件程序的機器學習系統“AI Programmer”。

研究人員表示,他們用這個系統證明了長久以來的假設,那就是功能完備的程序確實能夠被自動生成。具體到這項工作,AI Programmer利用機器學習中的遺傳算法,模擬復雜的指令。雖然現在AI Programmer生成的程序,復雜程度與人類新手程序員編寫的結果相當。但研究人員認為,AI Programmer編寫的程序完全可以超越傳統范疇,不受人類時間和智慧的局限。

AI編寫的程序只是在測試復雜度和計算資源之間找得到最適合的點。換句話說,可能性無限。

研究人員還表示,我們需要重新思考,設計新的、面向機器的編程語言,因為當前的編程語言是面向人類的,不適用于基于ML的編程。“在考慮ML驅動程序生成的未來時,我們需要放棄和重新考慮典型程序語言創建的方法。”

研究人員寫道,只有這樣做,我們才能開始設想一個由AI系統驅動,以人類創造力和設計為指導的計算機軟件開發的新未來。

AI Programmer的軟件架構。從圖中可見,由人類驅動的部分非常少,只需要在開始輸入指令,最后接收適用于某項任務的函數即可,剩下部分全部由機器完成。

AI Programmer:利用遺傳算法自動生成程序,理論上能夠完成所有類型的任務

根據論文,研究人員選擇了無類型編程語言,只包括了8種指令來驅動AI Programmer生成軟件。

AI Programmer使用的編程語言是圖靈完備的,如表1所示。理論上,在時間和內存不限的情況下,圖靈完備編程語言能夠處理任何編程任務。本質上,任何一種具有這種特質的編程語言都能夠解決海量編程問題。同樣,AI Programmer生成的軟件能夠完成所有任務。

有了這個保障,再來看AI Programmer的核心——遺傳算法。

要使用遺傳算法生成軟件程序,必須首先創建一個基因組(genome)。基因組是一組被組合在一起作為單個單元的基因。AI Programmer的基因組編碼為浮點數組,每個唯一指令的固定值范圍在0和1之間,如上面表1的基因范圍列所示。

創建好基因組后,AI Programmer就將其轉換為相應的程序,執行,并根據程序的輸出為結果程序分配適合度。生成的程序越靠近解決提供的任務,適應度就越高,越有可能繼續進行下一代的進化。在每一代,AI Programmer利用隨機選擇以及交叉和變異來創建子程序,其中包含輕微的隨機擾動,并且可能比其父母更好的基因組來解決目標任務。

圖3展示了從浮點數組中構建基因組的實例。每個值范圍映射到編程語言中的特定指令。最初,這些值是隨機的,導致生成的程序無法正常運行。但是,其中必將有一兩個能夠運行并執行一些有效的指令。一個程序執行得越成功,就越有可能繼續使用代碼,實現更成功的后代。

為了創建后代,父母將其基因的一部分交給孩子,這個過程如圖4所示。除了繼承父母的編程指令外,每個孩子也可能會遇到突變,也就是對特定基因增加受控但隨機的擾動。這導致特定基因的值發生修改,使所得到的編程指令發生變化,進而改變整個程序。

可執行程序根據其執行情況進行排名,如圖5所示。其中,特定程序會被立即從基因組池中刪除,成功的方案則被推進以產生新的后代。

AI Programmer使用結果:輸出“Hello World”,反轉字符串,加減乘,輸出斐波那契數列……

AI Programmer由C#.NET設計的模塊化框架組成。包括運行遺傳算法的引擎,基因組編碼器和解碼器,用于執行模擬程序的沙箱解讀器,以及將代碼轉換為二進制可執行文件的編譯程序。雖然最初設計AI Programmer的時候使用C#,但需要注意的是,設計原則并不限于使用C#。

研究人員指出,AI Programmer的適應性測試軟件框架具有延展性,并已被開發。用戶可以自己設計無數的定制化軟件,最終指導系統的遺傳算法(GA)生成和軟件程序演變。

如果目標程序旨在生成一個字符串,如”Hello World”(見上圖),測試分數可能是字符串中的數字。但由于AI Programmer是在字節級生成代碼,測試分數應將輸出字符的增量差考慮在內。

研究人員表示i,他們能用AI Programmer生成很多軟件程序。表2是所生成程序的名單。

一開始,研究人員讓AI Programmer生成了一個非常簡單的程序來輸出“hi”。經過5700代后,測試成功。生成代碼如圖9所示。

經過580,900代后,生成了“hello world”,如圖10所示。

經過6,057,200代后,AI Programmer成功生成了”I love all humans”,如圖11所示。

AI Programmer生成反轉字符串的程序。生成代碼如圖13所示。

AI Programmer能在92,400代之后生成加法程序;在177,900代之后生成減法程序,如圖15所示。

圖16所示的生成程序可以從兩個初始輸入值來輸出斐波納契序列。

論文:AI Programmer,使用遺傳算法自動創建軟件程序

摘要

在本文中,我們介紹了首個能夠自動生成完整軟件程序的機器學習(ML)系統,全程只需最低限度的人類參與。這個系統名叫“AI Programmer”,以遺傳算法(GA)為核心,加上緊密約束的編程語言,將其ML搜索空間的開銷降到最低。AI Programmer的新穎部分源于(i)獨特的系統設計,包括用于效率和安全性的嵌入式手工解釋器(hand-crafted interpreter),以及(ii)對遺傳算法的增強,納入了指令基因(instruction-gene)隨機化綁定,以及編程語言特定的基因組構建及消除技術。我們詳細介紹了AI Programmer的系統設計,詳細介紹了系統的工作原理,以及使用主流CPU來演示其軟件生成功能和性能的實驗數據。

責任編輯:張燕妮 來源: 36Kr
相關推薦

2017-10-18 12:53:21

AI自主編程遺傳算法

2017-10-27 18:20:59

程序員

2011-01-19 11:14:45

程序員

2017-11-16 15:25:54

Go語言算法代碼

2025-01-16 07:10:00

2018-02-02 16:41:01

程序員編程Web

2025-01-13 09:30:00

2024-07-03 08:00:00

2015-11-03 11:01:26

編程Anders微軟

2017-10-26 09:34:23

谷歌AI機器學習

2021-03-16 11:30:33

2020-06-11 08:32:50

Python遺傳算法代碼

2009-06-02 13:43:04

程序員定義職場

2021-03-10 15:49:20

人工智能遺傳算法

2020-04-04 20:59:28

程序員技術開發

2017-09-22 15:03:08

Python遺傳算法GAFT框架

2019-04-26 13:26:00

預測股票深度學習股票

2009-08-14 09:41:03

C#遺傳算法

2012-08-30 10:05:40

編程編程語言程序員

2017-07-12 14:23:25

遺傳算法java自然選擇
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 二区久久 | 狠狠操网站 | 精品乱码一区二区三四区视频 | 色综合久 | 亚洲视频中文字幕 | 国产成人精品网站 | 黄色网址免费在线观看 | 日韩欧美国产精品 | 99精品国自产在线 | 欧美一区二区 | 国产精品视频在线观看 | 亚洲一区二区视频 | 激情福利视频 | 久久国产成人精品国产成人亚洲 | 国产va| 成人自拍视频 | 久久久久国产一区二区三区四区 | 69性欧美高清影院 | av黄色在线 | 国产精品观看 | 欧美小视频在线观看 | 1000部精品久久久久久久久 | 羞羞网站在线观看 | a级在线 | 伊人久麻豆社区 | 日韩不卡一区二区 | 天堂久 | 国产精品色婷婷久久58 | 国产第一页在线播放 | 91影院在线观看 | 欧美福利| 亚洲天堂精品一区 | 国精产品一区一区三区免费完 | 国产一级在线 | 久久免费精品视频 | 精品久久久久久久久久久久 | 亚洲a一区| 亚洲一区二区三区视频在线 | 久久久性 | 精品国产18久久久久久二百 | 91视频精选 |