91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Pytorch如何加速Dataloader提升數據讀取速度

發布時間:2021-05-28 11:46:45 來源:億速云 閱讀:996 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關Pytorch如何加速Dataloader提升數據讀取速度,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

在利用DL解決圖像問題時,影響訓練效率最大的有時候是GPU,有時候也可能是CPU和你的磁盤。

很多設計不當的任務,在訓練神經網絡的時候,大部分時間都是在從磁盤中讀取數據,而不是做 Backpropagation 。

這種癥狀的體現是使用 Nividia-smi 查看 GPU 使用率時,Memory-Usage 占用率很高,但是 GPU-Util 時常為 0% ,如下圖所示:

Pytorch如何加速Dataloader提升數據讀取速度

如何解決這種問題呢?

在 Nvidia 提出的分布式框架 Apex 里面,我們在源碼里面找到了一個簡單的解決方案:

https://github.com/NVIDIA/apex/blob/f5cd5ae937f168c763985f627bbf850648ea5f3f/examples/imagenet/main_amp.py#L256

class data_prefetcher():
    def __init__(self, loader):
        self.loader = iter(loader)
        self.stream = torch.cuda.Stream()
        self.mean = torch.tensor([0.485 * 255, 0.456 * 255, 0.406 * 255]).cuda().view(1,3,1,1)
        self.std = torch.tensor([0.229 * 255, 0.224 * 255, 0.225 * 255]).cuda().view(1,3,1,1)
        # With Amp, it isn't necessary to manually convert data to half.
        # if args.fp16:
        #     self.mean = self.mean.half()
        #     self.std = self.std.half()
        self.preload()

    def preload(self):
        try:
            self.next_input, self.next_target = next(self.loader)
        except StopIteration:
            self.next_input = None
            self.next_target = None
            return
        with torch.cuda.stream(self.stream):
            self.next_input = self.next_input.cuda(non_blocking=True)
            self.next_target = self.next_target.cuda(non_blocking=True)
            # With Amp, it isn't necessary to manually convert data to half.
            # if args.fp16:
            #     self.next_input = self.next_input.half()
            # else:
            self.next_input = self.next_input.float()
            self.next_input = self.next_input.sub_(self.mean).div_(self.std)

我們能看到 Nvidia 是在讀取每次數據返回給網絡的時候,預讀取下一次迭代需要的數據,

那么對我們自己的訓練代碼只需要做下面的改造:

training_data_loader = DataLoader(
    dataset=train_dataset,
    num_workers=opts.threads,
    batch_size=opts.batchSize,
    pin_memory=True,
    shuffle=True,
)
for iteration, batch in enumerate(training_data_loader, 1):
    # 訓練代碼

#-------------升級后---------

data, label = prefetcher.next()
iteration = 0
while data is not None:
    iteration += 1
    # 訓練代碼
    data, label = prefetcher.next()

這樣子我們的 Dataloader 就像打了雞血一樣提高了效率很多,如下圖:

Pytorch如何加速Dataloader提升數據讀取速度

當然,最好的解決方案還是從硬件上,把讀取速度慢的機械硬盤換成 NVME 固態吧~

補充:Pytorch設置多線程進行dataloader時影響GPU運行

使用PyTorch設置多線程(threads)進行數據讀取時,其實是假的多線程,他是開了N個子進程(PID是連續的)進行模擬多線程工作。

以載入cocodataset為例

DataLoader

dataloader = torch.utils.data.DataLoader(COCODataset(config["train_path"],
                                                     (config["img_w"], config["img_h"]),
                                                     is_training=True),
                                         batch_size=config["batch_size"],
                                         shuffle=True, num_workers=32, pin_memory=True)

numworkers就是指定多少線程的參數,原為32。

檢查GPU是否運行該程序

查看運行在gpu上的所有程序:

fuser -v /dev/nvidia*

如果沒有返回,則該程序并沒有在GPU上運行

指定GPU運行

將num_workers改成0即可

關于“Pytorch如何加速Dataloader提升數據讀取速度”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

波密县| 家居| 神木县| 洪雅县| 米泉市| 大新县| 阿城市| 南靖县| 怀来县| 南京市| 乐昌市| 长岛县| 台中市| 章丘市| 台山市| 弥勒县| 浑源县| 滁州市| 周至县| 砀山县| 荥阳市| 慈利县| 汉寿县| 竹溪县| 湘潭县| 珠海市| 灵璧县| 南宫市| 城步| 洛隆县| 晴隆县| 衡阳市| 湘乡市| 将乐县| 南木林县| 美姑县| 都昌县| 南涧| 安仁县| 西乌珠穆沁旗| 长丰县|