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

主頁(yè) > 知識(shí)庫(kù) > 解決pytorch trainloader遇到的多進(jìn)程問(wèn)題

解決pytorch trainloader遇到的多進(jìn)程問(wèn)題

熱門(mén)標(biāo)簽:天津電話(huà)機(jī)器人公司 開(kāi)封語(yǔ)音外呼系統(tǒng)代理商 應(yīng)電話(huà)機(jī)器人打電話(huà)違法嗎 地圖標(biāo)注線(xiàn)上如何操作 手機(jī)網(wǎng)頁(yè)嵌入地圖標(biāo)注位置 400電話(huà)辦理哪種 河北防封卡電銷(xiāo)卡 開(kāi)封自動(dòng)外呼系統(tǒng)怎么收費(fèi) 電銷(xiāo)機(jī)器人的風(fēng)險(xiǎn)

pytorch中嘗試用多進(jìn)程加載訓(xùn)練數(shù)據(jù)集,源碼如下:

trainloader = torch.utils.data.DataLoader(trainset, batch_size=4, shuffle=True, num_workers=3)

結(jié)果報(bào)錯(cuò):

RuntimeError: 
        An attempt has been made to start a new process before the
        current process has finished its bootstrapping phase.

        This probably means that you are not using fork to start your
        child processes and you have forgotten to use the proper idiom
        in the main module:

            if __name__ == '__main__':
                freeze_support()
                ...

        The "freeze_support()" line can be omitted if the program
        is not going to be frozen to produce an executable.

從報(bào)錯(cuò)信息可以看到,當(dāng)前進(jìn)程在運(yùn)行可執(zhí)行代碼時(shí),產(chǎn)生了一個(gè)新進(jìn)程。這可能意味著您沒(méi)有使用fork來(lái)啟動(dòng)子進(jìn)程或者是未在主模塊中正確使用。

后來(lái)經(jīng)過(guò)查閱發(fā)現(xiàn)了原因,因?yàn)閣indows系統(tǒng)下默認(rèn)用spawn方法部署多線(xiàn)程,如果代碼沒(méi)有受到__main__模塊的保護(hù),新進(jìn)程都認(rèn)為是要再次運(yùn)行的代碼,將嘗試再次執(zhí)行與父進(jìn)程相同的代碼,生成另一個(gè)進(jìn)程,依此類(lèi)推,直到程序崩潰。

解決方法很簡(jiǎn)單

把調(diào)用多進(jìn)程的代碼放到__main__模塊下即可。

if __name__ == '__main__':
    transform = transforms.Compose([transforms.ToTensor(), transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))])
    trainset = torchvision.datasets.CIFAR10(root='./data', train=True, download=True, transform=transform)
    trainloader = torch.utils.data.DataLoader(trainset, batch_size=4, shuffle=True, num_workers=3)

補(bǔ)充:pytorch-Dataloader多進(jìn)程使用出錯(cuò)

使用Dataloader進(jìn)行多進(jìn)程數(shù)據(jù)導(dǎo)入訓(xùn)練時(shí),會(huì)因?yàn)槎噙M(jìn)程的問(wèn)題而出錯(cuò)

dataloader = DataLoader(transformed_dataset, batch_size=4,shuffle=True, num_workers=4)

其中參數(shù)num_works=表示載入數(shù)據(jù)時(shí)使用的進(jìn)程數(shù),此時(shí)如果參數(shù)的值不為0而使用多進(jìn)程時(shí)會(huì)出現(xiàn)報(bào)錯(cuò)

RuntimeError: An attempt has been made to start a new process before the current process has finished its bootstrapping phase. This probably means that you are not using fork to start your child processes and you have forgotten to use the proper idiom in the main module: if __name__ == '__main__': freeze_support() ... The "freeze_support()" line can be omitted if the program is not going to be frozen to produce an executable.

此時(shí)在數(shù)據(jù)的調(diào)用之前加上if __name__ == '__main__':即可解決問(wèn)題

if __name__ == '__main__':#這個(gè)地方可以解決多線(xiàn)程的問(wèn)題

        for i_batch, sample_batched in enumerate(dataloader):

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • pytorch多進(jìn)程加速及代碼優(yōu)化方法
  • PyTorch 解決Dataset和Dataloader遇到的問(wèn)題
  • 解決pytorch DataLoader num_workers出現(xiàn)的問(wèn)題

標(biāo)簽:江蘇 六盤(pán)水 宿遷 駐馬店 成都 常州 山東 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解決pytorch trainloader遇到的多進(jìn)程問(wèn)題》,本文關(guān)鍵詞  解決,pytorch,trainloader,遇到,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解決pytorch trainloader遇到的多進(jìn)程問(wèn)題》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于解決pytorch trainloader遇到的多進(jìn)程問(wèn)題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 江北区| 云南省| 宾阳县| 喀喇沁旗| 罗山县| 贵溪市| 汤原县| 临颍县| 拜泉县| 垦利县| 贺州市| 土默特右旗| 邯郸市| 长沙县| 涿州市| 蒲江县| 通城县| 虞城县| 利津县| 霍州市| 四子王旗| 化隆| 宣威市| 兴仁县| 西华县| 沧州市| 栾川县| 会同县| 尉氏县| 乐业县| 含山县| 东至县| 临沭县| 呈贡县| 安阳市| 涞水县| 鹤庆县| 仪陇县| 博乐市| 上虞市| 枣强县|