MLPerf是一套衡量機(jī)器學(xué)習(xí)系統(tǒng)性能的權(quán)威標(biāo)準(zhǔn),于2018年由谷歌、哈佛、斯坦福、百度等機(jī)構(gòu)聯(lián)合發(fā)起成立,每年定期公布榜單成績(jī),它將在標(biāo)準(zhǔn)目標(biāo)下訓(xùn)練或推理機(jī)器學(xué)習(xí)模型的時(shí)間,作為一套系統(tǒng)性能的測(cè)量標(biāo)準(zhǔn)。MLPerf訓(xùn)練任務(wù)包括圖像分類(ResNet50)、目標(biāo)物體檢測(cè)(SSD)、目標(biāo)物體檢測(cè)(Mask R-CNN)、智能推薦(DLRM)、自然語言處理(BERT)以及強(qiáng)化機(jī)器學(xué)習(xí)(Minigo)等。最新的1.0版本增加了兩項(xiàng)新的測(cè)試項(xiàng)目:語音識(shí)別(RNN-T)和醫(yī)學(xué)影像分割(U-Net3D)。
本文將著重討論其中的圖像分類模型Resnet50。
ResNet是殘差網(wǎng)絡(luò),該系列網(wǎng)絡(luò)被廣泛用于目標(biāo)分類等領(lǐng)域,并作為計(jì)算機(jī)視覺任務(wù)主干經(jīng)典神經(jīng)網(wǎng)絡(luò)的一部分,是一個(gè)典型的卷積網(wǎng)絡(luò)。ResNet50網(wǎng)絡(luò)結(jié)構(gòu)如下圖,首先對(duì)輸入做卷積操作,之后經(jīng)過4個(gè)殘差模塊,最后進(jìn)行一個(gè)全連接操作用于分類任務(wù),ResNet50包含50個(gè)卷積操作。
圖1 ResNet網(wǎng)絡(luò)結(jié)構(gòu)▲
圖2 ResNet34網(wǎng)絡(luò)結(jié)構(gòu)▲
來源:Deep Residual Learning for Image Recognition
作者:何愷明等
在MLPerf最早版本V0.5中,就包含Resnet50訓(xùn)練任務(wù)。下圖是歷次MLPerf 訓(xùn)練競(jìng)賽Resnet50的單機(jī)最優(yōu)性能。在MLPerf V0.7訓(xùn)練基準(zhǔn)測(cè)試中,浪潮AI服務(wù)器NF5488A5在33.37分鐘內(nèi)完成ResNet50訓(xùn)練,在所有提交的單服務(wù)器性能成績(jī)中名列榜首,比同類配置服務(wù)器快16.1%。而在最新的MLPerf 訓(xùn)練V1.0榜單中,浪潮AI服務(wù)器NF5688M6進(jìn)一步將Resnet50單機(jī)訓(xùn)練提速到27.38分鐘,耗時(shí)較V0.7縮短了17.95%。
圖3 歷次MLPerf訓(xùn)練測(cè)試Resnet50單機(jī)最優(yōu)性能▲
性能的一次次突破,得益于硬件的發(fā)展和軟件的更新及優(yōu)化。本文將深度解析取得這一成績(jī)背后的原因,談?wù)凴esnet50對(duì)計(jì)算平臺(tái)的需求以及如何提升訓(xùn)練速度。
ResNet50訓(xùn)練流程簡(jiǎn)介
在MLPerf訓(xùn)練V1.0測(cè)試中,Resnet50使用的數(shù)據(jù)集是包含128萬圖片的ImageNet2012(注:數(shù)據(jù)下載需要注冊(cè)),訓(xùn)練的目標(biāo)精度是75.9%,共需運(yùn)行5次。廠商提交的成績(jī)是訓(xùn)練模型達(dá)到目標(biāo)精度所花費(fèi)的時(shí)間(以分鐘為單位),值越小則表示性能越好。去掉一個(gè)最差性能和一個(gè)最優(yōu)性能,其余3次的平均值為最終成績(jī)。
我們來看看Resnet50模型訓(xùn)練的流程。首先,需要從硬盤上讀取訓(xùn)練集,進(jìn)行解碼,然后對(duì)圖像進(jìn)行預(yù)處理,處理后的數(shù)據(jù)送入訓(xùn)練框架進(jìn)行訓(xùn)練,經(jīng)過若干個(gè)epoch后得到滿足精度要求的模型。
圖4 Resnet50模型訓(xùn)練流程▲
硬件平臺(tái)選取
在Resnet50訓(xùn)練中,硬件及設(shè)備平臺(tái)的選取至關(guān)重要。其中磁盤讀取性能、CPU運(yùn)算性能、內(nèi)存到顯存的傳輸性能以及GPU運(yùn)算性能對(duì)訓(xùn)練速度的影響都比較大:磁盤讀取性能直接決定訓(xùn)練數(shù)據(jù)供給的速度;在引入DALI后,CPU的性能、CPU到GPU的傳輸帶寬以及GPU的性能共同決定了數(shù)據(jù)前處理的速度;而訓(xùn)練中的前向推理和反向傳播由GPU的性能及GPU之間的數(shù)據(jù)傳輸帶寬決定。上述幾個(gè)硬件就如同工廠流水線上的幾名工人,任何一名工人的處理速度跟不上就會(huì)導(dǎo)致堆積,成為性能瓶頸,影響最終結(jié)果。因此這幾個(gè)重要部分不能有明顯的短板。
此次MLPerf評(píng)測(cè)浪潮選取了NF5688M6和NF5488A5服務(wù)器作為Resnet50的訓(xùn)練平臺(tái),不僅保證上述關(guān)鍵部件性能十分強(qiáng)勁,而且把它們很好地整合在一起,能更好地發(fā)揮它們的性能,滿足了模型訓(xùn)練對(duì)硬件的性能要求,從而能快速地完成訓(xùn)練任務(wù)。
NF5688M6在6U空間內(nèi)支持2顆Intel最新的Ice Lake CPU和8顆NVIDIA最新的NVSwitch全互聯(lián)GPU。支持PCIe Gen4.0高速互聯(lián),實(shí)現(xiàn)CPU和GPU之間數(shù)據(jù)高速傳輸。同時(shí)采用完全風(fēng)道獨(dú)立,有效避免回流產(chǎn)生,實(shí)現(xiàn)風(fēng)冷支持8顆 GPU高環(huán)溫下穩(wěn)定工作。在本次MLPerf V1.0訓(xùn)練測(cè)試中,NF5688M6獲得了ResNet50、DLRM和SSD三項(xiàng)任務(wù)的單機(jī)訓(xùn)練性能第一。
NF5488A5在4U空間內(nèi)實(shí)現(xiàn)8顆高性能NVIDIA GPU液冷散熱,搭載2顆支持PCIe4.0的AMD EPYC 7742 處理器,能夠?yàn)锳I 用戶提供超強(qiáng)單機(jī)訓(xùn)練性能和超高數(shù)據(jù)吞吐。NF5488A5在MLPerf V0.7基準(zhǔn)測(cè)試中創(chuàng)下Resnet50訓(xùn)練任務(wù)最佳單服務(wù)器性能成績(jī),在MLPerf V1.0榜單中獲得了BERT任務(wù)的單機(jī)訓(xùn)練性能第一。
訓(xùn)練調(diào)優(yōu)方法
Resnet50模型的訓(xùn)練時(shí)長(zhǎng)主要受兩大因素的影響:一是訓(xùn)練模型到目標(biāo)精度的步數(shù),也就是需要多少輪可以達(dá)到目標(biāo)精度,在其它性能相同的情況下步數(shù)越短則訓(xùn)練時(shí)間越短,這部分需要找出一組超參數(shù)讓步數(shù)足夠少;二是圖4所示的數(shù)據(jù)讀取、數(shù)據(jù)預(yù)處理、訓(xùn)練等各個(gè)步驟的處理速度。Resnet50的訓(xùn)練數(shù)據(jù)為128萬張ImageNet2012圖片數(shù)據(jù)集,訓(xùn)練過程對(duì)傳輸帶寬和計(jì)算能力的要求都很高。正如木桶理論所說,模型訓(xùn)練速度是由流水線上最慢的部分決定,因此需要對(duì)流水線上的每一個(gè)步驟做分析,特別是著重分析整個(gè)流水線上的瓶頸,有針對(duì)性地去做優(yōu)化。
從這兩大因素入手,浪潮主要采用了以下調(diào)優(yōu)方法:
對(duì)學(xué)習(xí)率、batch size、優(yōu)化器等超參數(shù)進(jìn)行調(diào)試,將ResNet50模型收斂的步數(shù)從41降為35,帶來了15%左右的性能提升;
通過優(yōu)化DALI,使用GPU資源加速解碼和數(shù)據(jù)處理環(huán)節(jié),實(shí)現(xiàn)了1%左右的性能提升;
使用NCCL提升多GPU卡之間通信效率,加速訓(xùn)練環(huán)節(jié),性能提升0.1%左右。
下面分別按照訓(xùn)練流程進(jìn)行詳述。
| 訓(xùn)練集讀取
訓(xùn)練集是官方指定的。需要注意是讀取圖像帶來的開銷,如前所述,這個(gè)取決于磁盤讀取的速度和傳輸帶寬。好的磁盤自然能帶來更快的速度,另外通過組Raid 0 磁盤陣列也能帶來讀取速度的提升。我們?cè)趦煞N不同的磁盤上使用同樣的Raid 0磁盤陣列,測(cè)試結(jié)果的訓(xùn)練時(shí)長(zhǎng)差異達(dá)到5‰左右,所以磁盤的選擇是很重要的。
| 解碼和數(shù)據(jù)處理
讀取數(shù)據(jù)后便是解碼和數(shù)據(jù)處理,通常它們是一起進(jìn)行的。圖像解碼會(huì)比較耗時(shí),常常會(huì)成為性能瓶頸,一般的處理方式只能利用CPU資源來進(jìn)行圖像解碼,性能會(huì)受到極大的制約,我們選擇的是DALI(NVIDIA Data Loading Library)框架,這是一款高度優(yōu)化用來加速計(jì)算機(jī)視覺深度學(xué)習(xí)應(yīng)用的執(zhí)行引擎,可以利用GPU的資源來做圖像解碼和預(yù)處理,號(hào)稱可以比原框架帶來4倍的性能提升。使用DALI來做預(yù)處理處理是個(gè)不錯(cuò)的選擇,大家可以試試。
選定預(yù)處理的方法后,需要對(duì)其做優(yōu)化,充分利用它的優(yōu)勢(shì),使之適用于我們的系統(tǒng)和數(shù)據(jù)。首先,我們先找出預(yù)處理數(shù)據(jù)的極限,通過設(shè)置訓(xùn)練數(shù)據(jù)為模擬的擬合數(shù)據(jù),這樣可以拋開數(shù)據(jù)讀取以及預(yù)處理的開銷,評(píng)測(cè)只有訓(xùn)練開銷時(shí)的吞吐率,后面要做的就是調(diào)整DALI參數(shù),讓真實(shí)數(shù)據(jù)的吞吐率接近擬合數(shù)據(jù)的吞吐率。
我們可以從以下幾個(gè)方面入手:
1. DALI的計(jì)算分配:DALI可以把預(yù)處理的計(jì)算按指定的比例分配到CPU和GPU上,如果分配給GPU的比例小了則不能充分利用GPU的性能,如果大了則會(huì)擠占后面的訓(xùn)練資源;
2. DALI的處理線程:這個(gè)值大了,會(huì)占用資源,并讓一些線程處于等待狀態(tài),這個(gè)值小了,不能充分利用資源;
3. ALI的數(shù)據(jù)預(yù)取量:值過小會(huì)讓后面的處理等待,值過大會(huì)占用過多顯存存儲(chǔ)和計(jì)算資源,甚至?xí)谋M顯存;
4. 使用融合函數(shù):采用ImageDecoderRandomCrop函數(shù),把解碼和隨機(jī)裁剪放在一起做,通常會(huì)比分開做性能提升不少。
前3個(gè)參數(shù)值的選取需要針對(duì)不同硬件設(shè)備和模型進(jìn)行測(cè)試,找出一個(gè)最優(yōu)組合,通過這個(gè)部分的優(yōu)化,可以帶來大概7‰左右的性能提升。而采用融合函數(shù)通常能帶來1%左右的性能提升。
上述DALI代碼關(guān)鍵就是實(shí)現(xiàn)一個(gè)自己的Pipeline類,ResNet50的數(shù)據(jù)前處理關(guān)鍵代碼參考如下:
圖6 ResNet50數(shù)據(jù)前處理關(guān)鍵代碼▲
| 訓(xùn)練框架選取
目前訓(xùn)練框架有很多,如tensorflow、pytorch、mxnet等。不同的模型在不同的框架下有不一樣的性能表現(xiàn),通過比較,我們發(fā)現(xiàn)mxnet框架在處理resnet50模型的訓(xùn)練上有較大的優(yōu)勢(shì)。
另外,使用多塊GPU進(jìn)行訓(xùn)練時(shí),各卡之間有大量的數(shù)據(jù)傳輸,各個(gè)框架會(huì)采用horovod或者直接采用NCCL來進(jìn)行分布式的訓(xùn)練,而horovod本質(zhì)上也是調(diào)用NCCL進(jìn)行的數(shù)據(jù)傳輸。在MLPerf的示例代碼中有的框架會(huì)提供默認(rèn)的NCCL參數(shù)選擇,這在不同的硬件設(shè)備中可能會(huì)有所不同,例如在最新的NVSWITCH架構(gòu)中MAXCHANNEL數(shù)為32,而在之前的NVLINK架構(gòu)中默認(rèn)值為16最佳。在大部分的情況下,NCCL內(nèi)部的默認(rèn)值即可滿足其要求, 但仍要注意其傳入?yún)?shù)對(duì)傳輸速度的影響。另外經(jīng)測(cè)試最新的NCCL版本,對(duì)于不同的硬件設(shè)備可能不是速度最快的版本,可通過NCCL_TEST進(jìn)行測(cè)試選擇,這里不再展開說明。
| 超參數(shù)調(diào)優(yōu)
訓(xùn)練中的一個(gè)關(guān)鍵因素就是超參數(shù)的調(diào)試,一組好的超參數(shù)能讓模型經(jīng)過更少的epoch就收斂,自然會(huì)讓性能提升。試想一下如果兩個(gè)廠商的訓(xùn)練吞吐率一樣,但其中一家的模型要10個(gè)epoch才能收斂到目標(biāo)精度,而另一家的模型可以8個(gè)epoch就收斂,相當(dāng)于2位選手以同樣的速度下山,其中一位選手找到的路需要走10公里,另一位找到的路只需要走8公里,那毫無疑問走8公里路的占有明顯優(yōu)勢(shì),能更快到達(dá)終點(diǎn)。所以挑選一組合適的超參數(shù)能事半功倍。實(shí)際上,MLPerf Training為了避免走“錯(cuò)路”帶來的不公平,特意制定了超參數(shù)借用規(guī)則,讓大家借一條“路”再跑一次,在同一個(gè)賽道下的結(jié)果才公平。
當(dāng)然,要找這樣一條“路”是不容易的,下面給出一些超參數(shù)調(diào)試的小技巧:
學(xué)習(xí)率(learning rate):學(xué)習(xí)率對(duì)收斂速度和精度都有影響。而調(diào)整學(xué)習(xí)率也是讓人抓狂的事情,經(jīng)常出現(xiàn)梯度不收斂。一般對(duì)于學(xué)習(xí)率等超參數(shù)采用先粗調(diào)、再微調(diào)的策略。其中在粗調(diào)過程中學(xué)習(xí)率先以10的倍數(shù)進(jìn)行調(diào)整,如選取0.01、0.1、1等值進(jìn)行嘗試,等學(xué)習(xí)率基本固定后,再進(jìn)行精調(diào),可以在基準(zhǔn)值上每次以10%的變化量進(jìn)行調(diào)整。
batch size:一般來講增大batch size可以提高訓(xùn)練速度,同時(shí)也可以提高AI加速器的利用率,但稍有不慎來個(gè)out of memory就可以終止你增大該值的念想,另外過大的batch size也會(huì)帶來精度的下降。那么選一個(gè)小batch size是否就可以了呢?經(jīng)實(shí)驗(yàn)驗(yàn)證,過小的batch size也會(huì)導(dǎo)致精度下降,所以該值的選取,也需要調(diào)試。此外,batch size和learning rate也會(huì)相互影響,一般操作是,在增大batch size的同時(shí),也應(yīng)對(duì)應(yīng)的增大learning rate。
優(yōu)化器:一般在分類模型中,最常用的優(yōu)化器為隨機(jī)梯度下降SGD。雖然adam等優(yōu)化器可以獲取到更快的速度,但是經(jīng)常會(huì)出現(xiàn)精度下降的問題。除此之外還有LARS(Layer-wise Adaptive Rate Scaling:https://arxiv.org/abs/1708.03888)優(yōu)化器,這是MLPerf中各個(gè)參賽廠家普遍使用的優(yōu)化器。LARS的優(yōu)化器的公式如下:
LARS是SGD 的有動(dòng)量擴(kuò)展,可以適應(yīng)每層的學(xué)習(xí)率,核心是讓網(wǎng)絡(luò)的每個(gè)層根據(jù)自己的情況動(dòng)態(tài)的調(diào)整學(xué)習(xí)率,作用是可以有效緩解在較大batch size訓(xùn)練的前期由于學(xué)習(xí)率太大導(dǎo)致的不穩(wěn)定問題。
按照上述的方法調(diào)試超參數(shù),最終我們將ResNet50模型收斂的epoch次數(shù)從41降為35,帶來了15%左右的性能提升,看來正確的“路”效果很明顯,超參數(shù)帶來的性能提升不容小覷。
總之,影響訓(xùn)練性能的因素有很多。本文主要從硬件平臺(tái)和軟件優(yōu)化的角度,以MLPerf訓(xùn)練V1.0榜單中的ResNet50模型為例,從數(shù)據(jù)處理、訓(xùn)練框架、超參數(shù)等方面來提升訓(xùn)練速度,取得了不錯(cuò)的效果。浪潮優(yōu)化代碼已共享至Github(附1)。如果各位有興趣可以試一試,希望能幫助你提升模型訓(xùn)練速度。
展望
MLPerf競(jìng)賽經(jīng)過3年多時(shí)間的發(fā)展,已經(jīng)逐漸進(jìn)入成熟期,其模型的選取也緊跟時(shí)代潮流,為評(píng)估各類AI計(jì)算平臺(tái)在實(shí)際應(yīng)用場(chǎng)景中的性能提供了權(quán)威有效的基準(zhǔn)。MLPerf是一個(gè)開放社區(qū),很多廠商將優(yōu)化方法回饋至社區(qū),推動(dòng)AI技術(shù)的共同進(jìn)步。如浪潮已將在MLPerf V0.7中用到的ResNet收斂性優(yōu)化方案共享給社區(qū)成員,得到廣泛采納并應(yīng)用到本次V1.0測(cè)試中??梢灶A(yù)見,隨著谷歌、英偉達(dá)、英特爾、浪潮、戴爾等眾多主流芯片及系統(tǒng)廠商持續(xù)參與MLPerf,并貢獻(xiàn)軟硬件系統(tǒng)優(yōu)化方法,未來AI計(jì)算平臺(tái)的性能將會(huì)得到進(jìn)一步提升,為AI技術(shù)在更多應(yīng)用場(chǎng)景的落地打下堅(jiān)實(shí)的基礎(chǔ)。
* 附:
1.浪潮代碼:
https://github.com/mlcommons/training_results_v1.0/tree/master/Inspur/benchmarks/resnet/implementations/mxnet
按照下面的步驟來搭建環(huán)境:
a. 下載以上代碼
b. 按照代碼中README.MD中的描述下載所需數(shù)據(jù),并參考附2里的方法對(duì)數(shù)據(jù)進(jìn)行預(yù)處理,生成Mxnet格式的數(shù)據(jù)集
c. 進(jìn)入mxnet目錄,通過docker構(gòu)建所需的image,可參考以下代碼:
cd ./benchmarks/resnet/implementations/mxnet/docker build --pull -t image_name:image_version .
d. Image構(gòu)建完成后,修改設(shè)置參數(shù)的配置文件config_NF5688M6.sh,修改參數(shù)為適合你的系統(tǒng)的值(填入按照后面的調(diào)優(yōu)方法去找出優(yōu)化后的值)
e. 至此軟件環(huán)境構(gòu)建完成,可以開始執(zhí)行訓(xùn)練, 比如我們使用的系統(tǒng)是“NF5688M6”:
source config_5688M6.sh
DGXSYSTEM="NF5688M6"
CONT=image_name:image_version
DATADIR=/path/to/preprocessed/data
LOGDIR=/path/to/logfile ./run_with_docker.sh
接下來等著訓(xùn)練結(jié)束,通過查找日志里的“run_stop”和“run_start”記錄的時(shí)間點(diǎn)就可以計(jì)算出整個(gè)訓(xùn)練時(shí)間(單位是秒)。
2.數(shù)據(jù)預(yù)處理:
https://github.com/NVIDIA/DeepLearningExamples/blob/master/MxNet/Classification/RN50v1.5/README.md#prepare-dataset
審核編輯:湯梓紅
-
服務(wù)器
+關(guān)注
關(guān)注
12文章
9242瀏覽量
85709 -
浪潮
+關(guān)注
關(guān)注
1文章
465瀏覽量
23902 -
機(jī)器學(xué)習(xí)
+關(guān)注
關(guān)注
66文章
8428瀏覽量
132823 -
MLPerf
+關(guān)注
關(guān)注
0文章
35瀏覽量
647
原文標(biāo)題:深度解析MLPerf競(jìng)賽Resnet50訓(xùn)練單機(jī)最佳性能
文章出處:【微信號(hào):浪潮AIHPC,微信公眾號(hào):浪潮AIHPC】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論