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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

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

利用強(qiáng)化學(xué)習(xí)來探索更優(yōu)排序算法的AI系統(tǒng)

jf_pmFSk4VX ? 來源:GiantPandaCV ? 2023-06-19 10:49 ? 次閱讀

前言

DeepMind 最近在 Nature 發(fā)表了一篇論文 AlphaDev[2, 3],一個(gè)利用強(qiáng)化學(xué)習(xí)來探索更優(yōu)排序算法AI系統(tǒng)。

AlphaDev 系統(tǒng)直接從 CPU 匯編指令的層面入手去探索更優(yōu)的排序算法,因?yàn)橄鄬τ诟呒?jí)編程語言來說,在匯編指令層級(jí)對存儲(chǔ)和寄存器的操作可以更加的靈活,所以能發(fā)現(xiàn)更多潛在的調(diào)優(yōu)策略。

在 AlphaDev 的論文中,只關(guān)注探索短序列排序:

定長序列排序(比如 sort3 算法只能對長度為3的序列進(jìn)行排序)

變長序列排序(比如 variable sort5 算法可以對長度為1~5的變長序列進(jìn)行排序)

而對于長序列的排序,可以被分解為短序列的排序。

DeepMind 通過 AlphaDev 發(fā)現(xiàn)了比目前人工調(diào)優(yōu)算法更優(yōu)的定長短序列排序算法 sort3,sort4 和 sort5 ,并且已經(jīng)將代碼提交到了 LLVM 標(biāo)準(zhǔn) C++ 庫[4] 。

簡單來說,AlphaDev 將探索更高效排序算法的過程,建模為一個(gè)單玩家的匯編游戲(single-player game, AssemblyGame)。

游戲的過程就是玩家從 CPU 匯編指令集合中,選取一系列的指令組合得到一個(gè)新的排序算法。不過這個(gè)過程是非常有挑戰(zhàn)的,玩家需要考慮,匯編指令的組合空間并最終得得到一個(gè)正確和高效的算法。

該游戲主要包括以下難點(diǎn):

匯編游戲的搜索空間和圍棋類似(10^700)

只要有一條指令沒弄對,可能就會(huì)導(dǎo)致整個(gè)算法錯(cuò)誤

AlphaDev 系統(tǒng)詳解

將排序算法表示為 CPU 匯編指令

首先來看一個(gè)簡單的變長(variable sort2)短排序函數(shù)的 C 代碼實(shí)現(xiàn),排序結(jié)果從小到大:

voidvariable_sort_2(intlength,int*a){
switch(length){
case0:
case1:
return;
case2:
inttmp=a[0];
//a[0]保存兩者之間的最小值
a[0]=(a[1]

通過 gcc 生成對應(yīng)的匯編代碼,我用的 gcc 版本是 11.3.0,命令 gcc -S -O1 -o sort2.s sort2.c

匯編代碼只保留了核心部分,生成的結(jié)果和論文中的示例有些許不同但是原理是一致的:

variable_sort_2:  
.LFB0:
; %edi 寄存器保存參數(shù) length 的值
; cmpl 指令對比 %edi 和 常量 2
cmpl$2, %edi 
; 相等就跳轉(zhuǎn)到 .L3 標(biāo)簽處,
        ; 對應(yīng) C 代碼的 case 2
je.L3
.L1:
; 不等于 2 就直接返回,
        ; 對應(yīng) C 代碼 case 0 和 1
ret 
.L3:
; 將 a[0] 賦值給寄存器 %edx 
movl(%rsi), %edx
; 將 a[1] 賦值給寄存器 %eax 
movl4(%rsi), %eax
; 對比 %edx 和 %eax
cmpl%edx, %eax
; 將 %edx 賦值給 %ecx
movl%edx, %ecx
; cmov 是條件移動(dòng)指令根據(jù) cmpl 
; 指令的結(jié)果判斷是否執(zhí)行
; 如果 %eax <= %edx 
; 則將 %eax 賦值給 %ecx
cmovle%eax, %ecx
; 此時(shí) %ecx 保存了最小值
; 將 %ecx 賦值給 a[0]
movl%ecx, (%rsi)
; 如果 %eax 小于 %edx
; 則將 %edx 賦值給 %eax
cmovl%edx, %eax
; 此時(shí) %eax 保存了最大值
; 將 %eax 賦值給 a[1]
movl%eax, 4(%rsi)
jmp.L1

一般來說匯編程序所做的事情基本都是,將內(nèi)存的值復(fù)制到寄存器,然后對寄存器的值作修改,再將寄存器的值寫回到內(nèi)存中。

而 AlphaDev 系統(tǒng)只關(guān)注 x86 處理器架構(gòu)所支持的匯編指令集合的一個(gè)子集。

每條匯編指令的格式均為:操作碼<操作數(shù)A, 操作數(shù)B> 比如:

mov 移動(dòng)指令,表示將 A 的值賦值給 B

cmp 比較指令,相當(dāng)于 執(zhí)行 A - B 操作,但是不會(huì)對 A 和 B 做修改,而是根據(jù)相減的結(jié)果設(shè)置特殊的 flag 寄存器,更多內(nèi)容可以參考[5]

cmovX 條件移動(dòng)指令,根據(jù) X 和 flag 寄存器的值判斷是否執(zhí)行將 A 賦值給 B 的操作,一般都是出現(xiàn)在 cmp 指令之后。X 可以是 L (是否滿足小于條件), G (是否滿足大于條件),LE (是否滿足小于或等于條件),GE (是否滿足大于等于條件)。

jX 條件跳轉(zhuǎn)指令,根據(jù) X 和 flag 寄存器的值判斷是否執(zhí)行跳轉(zhuǎn)到指定標(biāo)記位置操作,A 可以是匯編程序代碼中的標(biāo)記位置,如上面所示匯編代碼的 .L1 和 .L3。X 可以是 NE (是否不等于),E (是否等于)或者可以填表示無條件跳轉(zhuǎn)。

將探索更優(yōu)排序算法表示為強(qiáng)化學(xué)習(xí)問題

AlphaDev 將 CPU 匯編指令層面的算法優(yōu)化過程轉(zhuǎn)化為一個(gè)單玩家的游戲。

游戲每一步的狀態(tài)定義為 : St = 。

其中, Pt 表示游戲到至今為止所生成的算法,Zt 則表示在給定輸入的前提下執(zhí)行完 Pt 里的指令之后,內(nèi)存和寄存器的狀態(tài)。

406540b6-0df2-11ee-962d-dac502259ad0.png

如上圖所示,在時(shí)間步 t ,AlphaDev 接受到當(dāng)前狀態(tài) St 和 所要執(zhí)行的動(dòng)作 at (比如 mov ),也就是往當(dāng)前生成的算法 Pt 中添加的合法匯編指令。

在添加完指令之后,就是計(jì)算獎(jiǎng)勵(lì)分?jǐn)?shù) rt (包括評估算法的正確性和延遲)。

算法正確性評估

正確性評估就是將 N 組測試序列輸入到算法 Pt 中,得到N 組輸出,和正確的排序結(jié)果最比較來計(jì)算獎(jiǎng)勵(lì)分?jǐn)?shù)。

論文中給出了3種正確性評估函數(shù),首先定義 P 為輸入序列長度, PCt 為在時(shí)間步 t 序列中,位置正確的值的個(gè)數(shù),這里我理解應(yīng)該是和正確的排序結(jié)果逐個(gè)位置對比,統(tǒng)計(jì)相等的個(gè)數(shù)。

三個(gè)函數(shù)分別定義如下:

func1 = (P - PCt) / P

func2 = sqrt(func1)

func3 = sqrt(PCt)

論文中提到采用第三個(gè)函數(shù)效果最好。

延遲評估

延遲分?jǐn)?shù)的計(jì)算可以是:

對系統(tǒng)增加代碼長度計(jì)算懲罰,因?yàn)榇a的長度一般都是和耗時(shí)高度相關(guān)

直接計(jì)算算法的真實(shí)耗時(shí)

整個(gè)強(qiáng)化學(xué)習(xí)的游戲在執(zhí)行有限步驟之后就會(huì)被終止。只有生成正確而又低延遲的匯編代碼才算贏得游戲。而不管是生成了錯(cuò)誤的代碼還是正確但低效的實(shí)現(xiàn)都視為游戲輸了。

AlphaDev 采用的強(qiáng)化學(xué)習(xí)算法是對 AlphqaZero 算法的擴(kuò)展,也是采用深度神經(jīng)網(wǎng)絡(luò)來引導(dǎo)蒙特卡洛樹搜索(MCTS)的規(guī)劃過程。網(wǎng)絡(luò)模型的輸入是 St ,輸出是對動(dòng)作策略和獎(jiǎng)勵(lì)的預(yù)測。

整個(gè)游戲過程簡單來說就是,用一個(gè)固定參數(shù)的網(wǎng)絡(luò)模型,通過給定的當(dāng)前狀態(tài)執(zhí)行一個(gè)蒙特卡洛樹搜索過程,然后采取下一步動(dòng)作。然后可以用生成的游戲過程(包含每一步的狀態(tài)和獎(jiǎng)勵(lì))去訓(xùn)練和更新網(wǎng)絡(luò)的參數(shù)。

網(wǎng)絡(luò)模型結(jié)構(gòu)

模型包含兩部分:

一個(gè) Transformer 編碼器模塊,用于建模算法,輸入是至今為止生成的匯編指令序列

一個(gè) CPU 狀態(tài)編碼器 MLP 模塊,輸入當(dāng)前寄存器和內(nèi)存的狀態(tài)

兩個(gè)網(wǎng)絡(luò)的輸出 embedding 會(huì)合并在一起來表示當(dāng)前的狀態(tài)。

網(wǎng)絡(luò)模型整體的結(jié)構(gòu)如下:40758674-0df2-11ee-962d-dac502259ad0.png

Transformer 編碼器模塊具體圖示

4081092c-0df2-11ee-962d-dac502259ad0.png

如上圖所示,把當(dāng)前生成的匯編代碼序列的每一條指令的操作碼和操作數(shù)都轉(zhuǎn)換為 one-hot 編碼序列,然后輸入到網(wǎng)絡(luò)中。

但是具體的 one-hot 編碼規(guī)則、詞表怎么設(shè)置、還有對于 CPU 狀態(tài)編碼網(wǎng)絡(luò)寄存器和內(nèi)存的狀態(tài)是怎么表示為網(wǎng)絡(luò)的輸入的等等,這些細(xì)節(jié)我在論文里沒找到。

然后兩個(gè)網(wǎng)絡(luò)的輸出 embedding 會(huì)合并到一起接著輸入到幾個(gè)函數(shù)頭里計(jì)算,分別是預(yù)測下一步策略的函數(shù)頭,預(yù)測算法正確性的函數(shù)頭和預(yù)測算法真實(shí)延遲的函數(shù)頭。

網(wǎng)絡(luò)參數(shù)超參設(shè)置

408baee0-0df2-11ee-962d-dac502259ad0.png40913ea0-0df2-11ee-962d-dac502259ad0.png

論文的補(bǔ)充資料中提供了網(wǎng)絡(luò)的參數(shù)和三個(gè)函數(shù)頭的具體配置。

而對于策略的預(yù)測,論文中提到為了簡化問題和提高收斂性,而對動(dòng)作空間做了一些限制,規(guī)則如下:

必須按照升序方式讀取內(nèi)存

寄存器按照升序分配

cmp 和 cmovX 指令的操作數(shù)不能出現(xiàn)內(nèi)存地址

對每個(gè)內(nèi)存位置,只能讀取和寫入一次

每個(gè)寄存器在使用之前,必須初始化

不能連續(xù)調(diào)用 cmp 指令

訓(xùn)練細(xì)節(jié)

AlphaDev 的訓(xùn)練采用了 TPU v3,每個(gè) TPU 核的 batch size 是 1024 ,總共用了 16 個(gè) TPU 核,總共訓(xùn)練了 100 萬次迭代。而在對于玩游戲積累訓(xùn)練數(shù)據(jù)來說,則是在 TPU v4 上進(jìn)行,總共用了 512 個(gè) TPU 核。

實(shí)驗(yàn)結(jié)果表明,最多只需2天模型就能訓(xùn)收斂。

實(shí)驗(yàn)結(jié)果

生成的算法和人工調(diào)優(yōu)對比

409ba660-0df2-11ee-962d-dac502259ad0.png

從實(shí)驗(yàn)結(jié)果表格可以看到,對于短序列排序算法 AlphaDev 生成的代碼長度更短,而且平均耗時(shí)也更低。

對生成算法延遲的評估方式,比如對于 sort3 則是在 100 臺(tái)機(jī)器上做評估,每臺(tái)機(jī)器隨機(jī)生成 1000 條 3個(gè)數(shù)的序列,然后每條序列輸入到算法中,對這 1000 次評估取第5百分位數(shù)作為最終的評估結(jié)果(排除 cache miss 和 任務(wù)搶占 等因素)。

耗時(shí)采用的是 CPU_CLK_UNHALTED.CORE 這個(gè)計(jì)數(shù)器結(jié)果, 其計(jì)數(shù)值表示在一個(gè)特定時(shí)間段內(nèi),處理器內(nèi)核的時(shí)鐘周期數(shù)。這個(gè)值越高,意味著處理器內(nèi)核在該時(shí)間段內(nèi)執(zhí)行了更多的指令。

AlphaDev 發(fā)現(xiàn)新的算法

對于定長序列排序,當(dāng)應(yīng)用到排序網(wǎng)絡(luò)算法[6](sorting network algorithm)的時(shí)候 AlphaDev 生成的代碼中包含了一些有趣指令序列,相對于原始指令序列可以減少一條匯編指令,論文中稱之為:

AlphaDev swap move

AlphaDev copy move

啥是排序網(wǎng)絡(luò)算法?

排序網(wǎng)絡(luò)算法(Sorting Network Algorithm)是一種能夠?qū)σ唤M輸入數(shù)據(jù)進(jìn)行排序的并行算法,其具有較好的并行性能適用于多處理器或多核心系統(tǒng)。

該算法的特點(diǎn)是,它將所有的比較和交換操作預(yù)先規(guī)劃好形成一個(gè)固定的結(jié)構(gòu),然后將輸入數(shù)據(jù)按照這個(gè)結(jié)構(gòu)進(jìn)行排序。

排序網(wǎng)絡(luò)由比較器(comparator)和線(wire)組成,如下圖所示:40b34e0a-0df2-11ee-962d-dac502259ad0.png

水平線表示 wire,每條水平線持有一個(gè)待排序的值。兩條 wire 之間的垂直線段就表示一個(gè)比較器,比較器對比兩條水平線的值,如果比較器下方的值小于上方的值則交換兩條橫線的值,否則則不交換。

一個(gè)優(yōu)化過的排序網(wǎng)絡(luò)可以以最少的比較器,并將這些比較器放置在特定位置上,來實(shí)現(xiàn)對任意序列進(jìn)行排序。

下圖是對一個(gè)構(gòu)造好的排序網(wǎng)絡(luò),輸入真實(shí)待排序序列的例子:40bc85d8-0df2-11ee-962d-dac502259ad0.png

可見初始輸入是 [2, 3, 1, 4],這些隨機(jī)數(shù)從左到右按順序經(jīng)過這些比較器之后,就得到了排序好的序列 [1, 2, 3, 4]。

AlphaDev swap move

40d3fd58-0df2-11ee-962d-dac502259ad0.png先來看這個(gè)排序網(wǎng)絡(luò),只看紅圈部分的功能就是對給定的輸入 [A, B, C] 將其轉(zhuǎn)換為 [min(A,B,C), max(min(A,C),B), max(A,C)]。

然后經(jīng)過 AlphaDev 優(yōu)化之后,可以將第一個(gè)輸出的 min(A,B,C) 改為只計(jì)算 min(A,B),原因是因?yàn)榍懊娴?B 和 C橫線之間經(jīng)過比較器之后已經(jīng)有了前置條件 B <= C。

而通過這個(gè)優(yōu)化就能省去一條匯編指令,下圖是紅圈部分的偽代碼實(shí)現(xiàn):

40e0a102-0df2-11ee-962d-dac502259ad0.png

左邊是原始偽代碼實(shí)現(xiàn),右邊是經(jīng)過 AlphaDev 優(yōu)化之后的實(shí)現(xiàn),可以看到少了一條匯編指令 mov S P。

AlphaDev copy move

411110da-0df2-11ee-962d-dac502259ad0.png

接下來看對4個(gè)元素進(jìn)行排序的排序網(wǎng)絡(luò),是在對 sort8 這個(gè)算法優(yōu)化過程中發(fā)現(xiàn)的。該排序網(wǎng)絡(luò)對于輸入序列 [A, B, C, D] 轉(zhuǎn)換為 [min(A, B, C, D), max(B, min(A, C, D), max(C, min(A, D)), max(A, D) ]。

該排序網(wǎng)絡(luò)是 sort8 的一個(gè)子排序網(wǎng)絡(luò),而根據(jù)比較器的放置位置來看,A 和 D 比較之后后續(xù)就不再和其他元素比較了,所以D出來的結(jié)果就是四個(gè)元素中最大的,所以隱含了一個(gè)條件就是 D >= min(A, C)。

因此對第二個(gè)輸出元素的計(jì)算可以從 max(B, min(A, C, D)) 改為 max(B, min(A, C)),就可以節(jié)省一條匯編指令。

偽代碼如下:

411d2870-0df2-11ee-962d-dac502259ad0.png

左邊是原始偽代碼實(shí)現(xiàn),右邊是經(jīng)過 AlphaDev 優(yōu)化之后的實(shí)現(xiàn),可以看到少了一條匯編指令 mov P T。

總結(jié)

這篇文章只是對 AlphaDev 論文中的主要內(nèi)容作解讀,對于更多的內(nèi)容和細(xì)節(jié)感興趣的讀者可以查閱原論文和論文的補(bǔ)充資料 [2,3],DeepMind 也也開源了一份偽代碼實(shí)現(xiàn) [7]。
責(zé)任編輯:彭菁

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

    關(guān)注

    1

    文章

    312

    瀏覽量

    60802
  • AI
    AI
    +關(guān)注

    關(guān)注

    87

    文章

    31294

    瀏覽量

    269655
  • 排序算法
    +關(guān)注

    關(guān)注

    0

    文章

    53

    瀏覽量

    10086
收藏 人收藏

    評論

    相關(guān)推薦

    使用Isaac Gym 強(qiáng)化學(xué)習(xí)mycobot 抓取任務(wù)

    使用Isaac Gym強(qiáng)化學(xué)習(xí)mycobot抓取任務(wù)
    的頭像 發(fā)表于 04-11 14:57 ?7310次閱讀
    使用Isaac Gym <b class='flag-5'>來</b><b class='flag-5'>強(qiáng)化學(xué)習(xí)</b>mycobot 抓取任務(wù)

    什么是深度強(qiáng)化學(xué)習(xí)?深度強(qiáng)化學(xué)習(xí)算法應(yīng)用分析

    什么是深度強(qiáng)化學(xué)習(xí)? 眾所周知,人類擅長解決各種挑戰(zhàn)性的問題,從低級(jí)的運(yùn)動(dòng)控制(如:步行、跑步、打網(wǎng)球)到高級(jí)的認(rèn)知任務(wù)。
    發(fā)表于 07-01 10:29 ?1500次閱讀
    什么是深度<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b>?深度<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b><b class='flag-5'>算法</b>應(yīng)用分析

    反向強(qiáng)化學(xué)習(xí)的思路

    強(qiáng)化學(xué)習(xí)的另一種策略(二)
    發(fā)表于 04-03 12:10

    深度強(qiáng)化學(xué)習(xí)實(shí)戰(zhàn)

    內(nèi)容2:課程一: TensoRFlow入門到熟練:課程二:圖像分類:課程三:物體檢測:課程四:人臉識(shí)別:課程五:算法實(shí)現(xiàn):1、卷積神經(jīng)網(wǎng)絡(luò)CNN2、循環(huán)神經(jīng)網(wǎng)絡(luò)RNN3、強(qiáng)化學(xué)習(xí)DRL4、對抗性生成
    發(fā)表于 01-10 13:42

    利用強(qiáng)化學(xué)習(xí)探索多巴胺對學(xué)習(xí)的作用

    當(dāng)我們使用虛擬的計(jì)算機(jī)屏幕和隨機(jī)選擇的圖像模擬一個(gè)非常相似的測試時(shí),我們發(fā)現(xiàn),我們的“元強(qiáng)化學(xué)習(xí)智能體”(meta-RL agent)似乎是以類似于Harlow實(shí)驗(yàn)中的動(dòng)物的方式在學(xué)習(xí),甚至在被顯示以前從未見過的全新圖像時(shí)也是
    的頭像 發(fā)表于 05-16 09:03 ?4750次閱讀
    <b class='flag-5'>利用</b><b class='flag-5'>強(qiáng)化學(xué)習(xí)</b><b class='flag-5'>探索</b>多巴胺對<b class='flag-5'>學(xué)習(xí)</b>的作用

    什么是強(qiáng)化學(xué)習(xí)?純強(qiáng)化學(xué)習(xí)有意義嗎?強(qiáng)化學(xué)習(xí)有什么的致命缺陷?

    強(qiáng)化學(xué)習(xí)是人工智能基本的子領(lǐng)域之一,在強(qiáng)化學(xué)習(xí)的框架中,智能體通過與環(huán)境互動(dòng),學(xué)習(xí)采取何種動(dòng)作能使其在給定環(huán)境中的長期獎(jiǎng)勵(lì)最大化,就像在上述的棋盤游戲寓言中,你通過與棋盤的互動(dòng)
    的頭像 發(fā)表于 07-15 10:56 ?1.8w次閱讀
    什么是<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b>?純<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b>有意義嗎?<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b>有什么的致命缺陷?

    基于強(qiáng)化學(xué)習(xí)的MADDPG算法原理及實(shí)現(xiàn)

    之前接觸的強(qiáng)化學(xué)習(xí)算法都是單個(gè)智能體的強(qiáng)化學(xué)習(xí)算法,但是也有很多重要的應(yīng)用場景牽涉到多個(gè)智能體之間的交互。
    的頭像 發(fā)表于 11-02 16:18 ?2.2w次閱讀

    如何構(gòu)建強(qiáng)化學(xué)習(xí)模型訓(xùn)練無人車算法

    本文作者通過簡單的方式構(gòu)建了強(qiáng)化學(xué)習(xí)模型訓(xùn)練無人車算法,可以為初學(xué)者提供快速入門的經(jīng)驗(yàn)。
    的頭像 發(fā)表于 11-12 14:47 ?4909次閱讀

    對NAS任務(wù)中強(qiáng)化學(xué)習(xí)的效率進(jìn)行深入思考

    在一些情況下,我們會(huì)用策略函數(shù)(policy, 總得分,也就是搭建的網(wǎng)絡(luò)在測試集上的精度(accuracy),通過強(qiáng)化學(xué)習(xí)(Reinforcement Learning)這種通用黑盒算法優(yōu)化。然而,因?yàn)?/div>
    的頭像 發(fā)表于 01-28 09:54 ?5083次閱讀

    基于PPO強(qiáng)化學(xué)習(xí)算法AI應(yīng)用案例

    Viet Nguyen就是其中一個(gè)。這位來自德國的程序員表示自己只玩到了第9個(gè)關(guān)卡。因此,他決定利用強(qiáng)化學(xué)習(xí)AI算法幫他完成未通關(guān)的遺憾。
    發(fā)表于 07-29 09:30 ?2829次閱讀

    機(jī)器學(xué)習(xí)中的無模型強(qiáng)化學(xué)習(xí)算法及研究綜述

    強(qiáng)化學(xué)習(xí)( Reinforcement learning,RL)作為機(jī)器學(xué)習(xí)領(lǐng)域中與監(jiān)督學(xué)習(xí)、無監(jiān)督學(xué)習(xí)并列的第三種學(xué)習(xí)范式,通過與環(huán)境進(jìn)行
    發(fā)表于 04-08 11:41 ?11次下載
    機(jī)器<b class='flag-5'>學(xué)習(xí)</b>中的無模型<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b><b class='flag-5'>算法</b>及研究綜述

    徹底改變算法交易:強(qiáng)化學(xué)習(xí)的力量

    強(qiáng)化學(xué)習(xí)(RL)是人工智能的一個(gè)子領(lǐng)域,專注于決策過程。與其他形式的機(jī)器學(xué)習(xí)相比,強(qiáng)化學(xué)習(xí)模型通過與環(huán)境交互并以獎(jiǎng)勵(lì)或懲罰的形式接收反饋學(xué)習(xí)
    發(fā)表于 06-09 09:23 ?544次閱讀

    DeepMind新作AlphaDev----強(qiáng)化學(xué)習(xí)探索更優(yōu)排序算法

    AlphaDev 系統(tǒng)直接從 CPU 匯編指令的層面入手去探索更優(yōu)排序算法,因?yàn)橄鄬τ诟呒?jí)編程語言來說,在匯編指令層級(jí)對存儲(chǔ)和寄存器的操作
    的頭像 發(fā)表于 06-19 10:49 ?559次閱讀
    DeepMind新作AlphaDev----<b class='flag-5'>強(qiáng)化學(xué)習(xí)</b><b class='flag-5'>探索</b><b class='flag-5'>更優(yōu)</b><b class='flag-5'>排序</b><b class='flag-5'>算法</b>

    基于強(qiáng)化學(xué)習(xí)的目標(biāo)檢測算法案例

    摘要:基于強(qiáng)化學(xué)習(xí)的目標(biāo)檢測算法在檢測過程中通常采用預(yù)定義搜索行為,其產(chǎn)生的候選區(qū)域形狀和尺寸變化單一,導(dǎo)致目標(biāo)檢測精確度較低。為此,在基于深度強(qiáng)化學(xué)習(xí)的視覺目標(biāo)檢測算法基礎(chǔ)上,提出聯(lián)
    發(fā)表于 07-19 14:35 ?0次下載

    如何使用 PyTorch 進(jìn)行強(qiáng)化學(xué)習(xí)

    強(qiáng)化學(xué)習(xí)(Reinforcement Learning, RL)是一種機(jī)器學(xué)習(xí)方法,它通過與環(huán)境的交互學(xué)習(xí)如何做出決策,以最大化累積獎(jiǎng)勵(lì)。PyTorch 是一個(gè)流行的開源機(jī)器
    的頭像 發(fā)表于 11-05 17:34 ?344次閱讀