婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > pytorch 兩個GPU同時訓練的解決方案

pytorch 兩個GPU同時訓練的解決方案

熱門標簽:市場上的電銷機器人 朝陽手機外呼系統 北京電銷外呼系統加盟 所得系統電梯怎樣主板設置外呼 儋州電話機器人 地圖標注面積 北瀚ai電銷機器人官網手機版 小蘇云呼電話機器人 佛山400電話辦理

使用場景

我有兩個GPU卡。我希望我兩個GPU能并行運行兩個網絡模型。

代碼

錯誤代碼1:

#對于0號GPU
os.environ['CUDA_VISIBLE_DEVICES']='0,1'
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
#對于1號GPU
os.environ['CUDA_VISIBLE_DEVICES']='0,1'
device = torch.device("cuda:1" if torch.cuda.is_available() else "cpu")

0號GPU不報錯,1號GPU報錯。錯誤如下

RuntimeError: Expected tensor for argument #1 ‘input' to have the same device as tensor for argument #2 ‘weight'; but device 0 does not equal 1 (while checking arguments for cudnn_convolution)

錯誤代碼2:

#對于0號GPU
os.environ['CUDA_VISIBLE_DEVICES']='0'
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
#對于1號GPU
os.environ['CUDA_VISIBLE_DEVICES']='1'
device = torch.device("cuda:1" if torch.cuda.is_available() else "cpu")

0號GPU不報錯,1號GPU報錯。錯誤如下

CUDA: invalid device ordinal

正確代碼如下:

#對于0號GPU
os.environ['CUDA_VISIBLE_DEVICES']='0'
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
#對于1號GPU
os.environ['CUDA_VISIBLE_DEVICES']='1'
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")

pytorch 多個gpu遇到的問題

目前所在學校的計算機系自己搭建了個GPU Farm,設備是GTX 1080 Ti的,看起來還算ok,但其實細究起來還挺雞肋的。但是總對于數據量巨大的項目,還是需要跑代碼吧,將就著用了。因為資源有限,分配到超過1個gpu需要排隊,所以從來沒嘗試過使用多個gpu。最近由于數據量變大,也急于取得進展,因此開始嘗試分配多個gpu。使用的過程中出現的問題,在此做個記錄。

首先,因為不同平臺的GPU Farm搭建的規則不一樣,如何分配到多個gpu在此就不做記錄了。不得不說,學校的GPU Farm資源少的可憐,分配到2個gpu常常要排隊半小時。

以下羅列遇到的問題。

torch.nn.DataParallel()

因為對pytorch的理解還不夠深,因此為了提高速度,從官網上注意到DataParallel,據說最簡單的方法是直接用

model = torch.nn.DataParallel(model)
model.cuda()

來實現,但是萬萬沒想到它給我帶來的時間浪費還真不是一星半點。

首先我分配到了2個gpu設備,之后在我的代碼中只添加了如上的命令,而后便收到了如下報錯

ValueError: only one element tensors can be converted to Python scalars

這個報錯直指我的 loss.item(),通過debug我發現它的tensor dimension的確變成了2個elements。在做了更多無效debug和上網查閱之后,我鬼使神差地調整回了1個gpu想看看效果會不會不一樣,然后居然順利運行了。

稍微思考一下,感覺倒是很合理。假設兩個gpu并行同時各自訓練一個batch,那么得到的loss自然應該是2個elements,淺顯地認為將其看做兩個batch訓練的loss結果就可以了。

目前手頭有比較急于出結果的數據集和項目,因此暫時沒有過多的時間去研究具體為什么會有這種情況的出現,不過這也證實了想要合理正確地運用多個gpu同時作業,顯然不是那么簡單地幾行代碼就能解決的。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • pytorch使用horovod多gpu訓練的實現
  • 解決pytorch多GPU訓練保存的模型,在單GPU環境下加載出錯問題
  • pytorch 指定gpu訓練與多gpu并行訓練示例
  • 用Pytorch訓練CNN(數據集MNIST,使用GPU的方法)
  • pytorch 使用單個GPU與多個GPU進行訓練與測試的方法
  • pytorch使用指定GPU訓練的實例
  • 關于pytorch多GPU訓練實例與性能對比分析
  • pytorch 如何在GPU上訓練

標簽:酒泉 云南 江蘇 定西 金融催收 寧夏 龍巖 商丘

巨人網絡通訊聲明:本文標題《pytorch 兩個GPU同時訓練的解決方案》,本文關鍵詞  pytorch,兩個,GPU,同時,訓練,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pytorch 兩個GPU同時訓練的解決方案》相關的同類信息!
  • 本頁收集關于pytorch 兩個GPU同時訓練的解決方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 剑阁县| 沁水县| 黄大仙区| 屏东市| 洪泽县| 镇坪县| 崇信县| 洛川县| 南昌县| 民县| 麻城市| 犍为县| 吉隆县| 临猗县| 红桥区| 呼图壁县| 延安市| 萝北县| 长子县| 新昌县| 鄂伦春自治旗| 讷河市| 桂林市| 西丰县| 富裕县| 吉安市| 治多县| 南宁市| 阿拉善右旗| 丹寨县| 四会市| 皋兰县| 隆子县| 施秉县| 饶阳县| 二手房| 莫力| 如东县| 屏南县| 松阳县| 乳山市|