下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
第Tensorflow中使用cpu和gpu有什么區(qū)別目錄使用cpu和gpu的區(qū)別一些術(shù)語的比較(tensorflow和pytorch/cpu和gpu/)tensorflow和pytorchcpu和gpucuda
使用cpu和gpu的區(qū)別
在Tensorflow中使用gpu和cpu是有很大的差別的。在小數(shù)據(jù)集的情況下,cpu和gpu的性能差別不大。
不過在大數(shù)據(jù)集的情況下,cpu的時間顯著增加,而gpu變化并不明顯。
不過,我的筆記本電腦的風扇終于全功率運行了。
importtensorflowastf
importtimeit
importnumpyasnp
importmatplotlib.pyplotasplt
defcpu_run(num):
withtf.device('/cpu:0'):
cpu_a=tf.random.normal([1,num])
cpu_b=tf.random.normal([num,1])
c=tf.matmul(cpu_a,cpu_b)
returnc
defgpu_run(num):
withtf.device('/gpu:0'):
gpu_a=tf.random.normal([1,num])
gpu_b=tf.random.normal([num,1])
c=tf.matmul(gpu_a,gpu_b)
returnc
cpu_result=np.arange(m,dtype=np.float32)
gpu_result=np.arange(m,dtype=np.float32)
x_time=np.arange(m)
foriinrange(m):
k=k*10
x_time[i]=k
cpu_str='cpu_run('+str(k)+')'
gpu_str='gpu_run('+str(k)+')'
#print(cpu_str)
cpu_time=timeit.timeit(cpu_str,'from__main__importcpu_run',number=10)
gpu_time=timeit.timeit(gpu_str,'from__main__importgpu_run',number=10)
#正式計算10次,取平均時間
cpu_time=timeit.timeit(cpu_str,'from__main__importcpu_run',number=10)
gpu_time=timeit.timeit(gpu_str,'from__main__importgpu_run',number=10)
cpu_result[i]=cpu_time
gpu_result[i]=gpu_time
print(cpu_result)
print(gpu_result)
fig,ax=plt.subplots()
ax.set_xscale("log")
ax.set_adjustable("datalim")
ax.plot(x_time,cpu_result)
ax.plot(x_time,gpu_result)
ax.grid()
plt.draw()
plt.show()
藍線是cpu的耗時,而紅線是gpu的耗時。
一些術(shù)語的比較(tensorflow和pytorch/cpu和gpu/)
tensorflow和pytorch
pytorch是一個動態(tài)框架,tensorflow是一個靜態(tài)框架。tensorflow是一個靜態(tài)框架體現(xiàn)在:需要先構(gòu)建一個tensorflow的計算圖,構(gòu)建好之后這樣的一個計算圖是不能變的,然后再傳入不同的數(shù)據(jù)進去進行計算。這種靜態(tài)框架帶來的問題是:固定了計算的流程,勢必帶來不靈活性,如果要改變計算的邏輯或者是隨著時間變化的計算邏輯,這樣的動態(tài)計算tensorflow是是無法實現(xiàn)的。pytorch是一個動態(tài)框架,和python的邏輯一樣,對變量做任何操作都是靈活的。一個好的框架需要具備三點:(1)對大的計算圖能方便的實現(xiàn)(2)能自動求變量的導數(shù)(3)能簡單的運行在GPU上。這三點pytorch都可以達到tensorflow在gpu上的分布式計算更為出色,在數(shù)據(jù)量巨大的時候效率比pytorch要高。企業(yè)很多都是用的tensorflow,pytorch在學術(shù)科研上使用多些。pytorch包括三個層次:tensor/variable/module。tensor即張量的意思,由于是矩陣的運算,所以適合在矩陣上跑。variable就是tensor的封裝,封裝的目的就是為了能夠保存住該variable在整個計算圖中的位置,能夠知道計算圖中各個變量之間的相互依賴關(guān)系,這樣就能夠反向求梯度。module是一個更高的層次,是一個神經(jīng)網(wǎng)絡的層次,可以直接調(diào)用全連接層、卷積層等神經(jīng)網(wǎng)絡。
cpu和gpu
cpu更少的核,但是單個核的計算能力很強gpu:更多的核,每個核的計算能力不如cpu,所以更適合做并行計算,如矩陣計算,深度學習就是很多
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 職業(yè)健康促進服務供給側(cè)改革與可持續(xù)發(fā)展
- 職業(yè)健康中的人機環(huán)境評估
- 黔西南2025年貴州黔西南高新區(qū)實驗中學臨聘教師招聘12人筆試歷年參考題庫附帶答案詳解
- 西雙版納2025年云南西雙版納勐??h黨政儲備人才專項招引18人筆試歷年參考題庫附帶答案詳解
- 肇慶2025年廣東肇慶市高要區(qū)教育局招聘中小學教師59人筆試歷年參考題庫附帶答案詳解
- 河池2025年廣西河池市南丹縣參加2025屆河池學院畢業(yè)生雙選會招聘22人筆試歷年參考題庫附帶答案詳解
- 榆林2025年陜西榆林市榆陽區(qū)招聘編外學科教師和教輔人員389人筆試歷年參考題庫附帶答案詳解
- 張家界2025年湖南張家界市桑植縣職業(yè)中等專業(yè)學校選調(diào)筆試歷年參考題庫附帶答案詳解
- 山西2025年山西農(nóng)業(yè)大學軟件學院招聘人事代理人員10人筆試歷年參考題庫附帶答案詳解
- 寧波浙江寧波一院龍山醫(yī)院醫(yī)療健康集團(慈溪市龍山醫(yī)院)招聘4人筆試歷年參考題庫附帶答案詳解
- 2025年醫(yī)療器械收貨與驗收管理制度培訓試題(附答案)
- 2025年急診科面試常見問題及答案
- 北師大版初中九年級下冊數(shù)學3.2圓的對稱性課件
- 建筑起重司索信號工安全操作規(guī)程
- 青光眼病人的健康宣教
- 2024-2025學年天津市河西區(qū)七年級下英語期中考試題(含答案和音頻)
- 商業(yè)地產(chǎn)運營管理手冊
- 哈鐵面試試題及答案
- 質(zhì)量小品完整版本
- 《家禽的主要傳染病》課件
- 試用期員工轉(zhuǎn)正申請書(匯編15篇)
評論
0/150
提交評論