build_loader.py 1.12 KB
Newer Older
Kai Chen's avatar
Kai Chen committed
1
2
from functools import partial

3
from mmcv.torchpack import get_dist_info
Kai Chen's avatar
Kai Chen committed
4
5
6
7
8
9
10
11
12
13
14
15
16
from torch.utils.data import DataLoader

from .collate import collate
from .sampler import GroupSampler, DistributedGroupSampler


def build_dataloader(dataset,
                     imgs_per_gpu,
                     workers_per_gpu,
                     num_gpus,
                     dist=True,
                     **kwargs):
    if dist:
17
        rank, world_size = get_dist_info()
Kai Chen's avatar
Kai Chen committed
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
        sampler = DistributedGroupSampler(dataset, imgs_per_gpu, world_size,
                                          rank)
        batch_size = imgs_per_gpu
        num_workers = workers_per_gpu
    else:
        sampler = GroupSampler(dataset, imgs_per_gpu)
        batch_size = num_gpus * imgs_per_gpu
        num_workers = num_gpus * workers_per_gpu

    if not kwargs.get('shuffle', True):
        sampler = None

    data_loader = DataLoader(
        dataset,
        batch_size=batch_size,
        sampler=sampler,
        num_workers=num_workers,
        collate_fn=partial(collate, samples_per_gpu=imgs_per_gpu),
        pin_memory=False,
        **kwargs)

    return data_loader