当前位置:   article > 正文

pytorch中使用numpy生成随机数每个epoch都一样_pytorch 每个epoch加载数据相同

pytorch 每个epoch加载数据相同

pytorch中使用numpy生成随机数每个epoch都一样

问题

最近在使用pytorch做实验的过程中发现,在dataset里面使用numpy生成随机数,每个epoch生成的随机数是一样的。
代码

import numpy as np
import torch
from torch.utils.data import Dataset
from torch.utils.data import DataLoader


class RandomDataset(Dataset):

    def __init__(self):
        pass

    def __getitem__(self, ind):
        return np.random.randint(100)

    def __len__(self):
        return 10


ds = RandomDataset()
ds = DataLoader(ds, 10, shuffle=False, num_workers=1)

total_epoch = 5
for epoch in range(total_epoch):
    for batch in ds:
        print(batch)

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

输出如下:

tensor([62, 66, 47, 55, 11, 90, 66, 64, 79, 62])
tensor([62, 66, 47, 55, 11, 90, 66, 64, 79, 62])
tensor([62, 66, 47, 55, 11, 90, 66, 64, 79, 62])
tensor([62, 66, 47, 55, 11, 90, 66, 64, 79, 62])
tensor([62, 66, 47, 55, 11, 90, 66, 64, 79, 62])

原因

通过google搜索发现github上有人提过这个问题 https://github.com/pytorch/pytorch/issues/5059

简单来说就是numpy的随机数生成在多进程的情况下存在问题。因为在DataLoader中设置了num_workers参数后,DataLoader内部会启动多进程来读数据。

解决途径

上面的连接给出了解决方法。
我采用的方法是不使用numpy生成随机数,而是使用pytorch的库生成随机数。

import numpy as np
import torch
from torch.utils.data import Dataset
from torch.utils.data import DataLoader


class RandomDataset(Dataset):

    def __init__(self):
        pass

    def __getitem__(self, ind):
        # return np.random.randint(100)
        return torch.randint(0, 100, (1,)).item()

    def __len__(self):
        return 10


ds = RandomDataset()
ds = DataLoader(ds, 10, shuffle=False, num_workers=1)

total_epoch = 5
for epoch in range(total_epoch):
    for batch in ds:
        print(batch)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

输出结果

tensor([93, 87, 57, 2, 10, 1, 6, 8, 71, 8])
tensor([76, 57, 73, 97, 85, 20, 1, 11, 25, 27])
tensor([72, 69, 37, 26, 99, 71, 38, 79, 6, 96])
tensor([90, 6, 38, 27, 14, 36, 66, 54, 32, 39])
tensor([72, 18, 7, 36, 45, 8, 74, 33, 17, 15])

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号