本文整理匯總了Python中torch.utils.data.sampler.RandomSampler方法的典型用法代碼示例。如果您正苦於以下問題:Python sampler.RandomSampler方法的具體用法?Python sampler.RandomSampler怎麽用?Python sampler.RandomSampler使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類torch.utils.data.sampler
的用法示例。
在下文中一共展示了sampler.RandomSampler方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_len
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def test_len(self):
batch_size = 3
drop_uneven = True
dataset = [i for i in range(10)]
group_ids = [random.randint(0, 1) for _ in dataset]
sampler = RandomSampler(dataset)
batch_sampler = GroupedBatchSampler(sampler, group_ids, batch_size, drop_uneven)
result = list(batch_sampler)
self.assertEqual(len(result), len(batch_sampler))
self.assertEqual(len(result), len(batch_sampler))
batch_sampler = GroupedBatchSampler(sampler, group_ids, batch_size, drop_uneven)
batch_sampler_len = len(batch_sampler)
result = list(batch_sampler)
self.assertEqual(len(result), batch_sampler_len)
self.assertEqual(len(result), len(batch_sampler))
示例2: __iter__
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def __iter__(self):
src_list = list()
tgt_list = list()
# sampler is RandomSampler
for i in self.sampler:
self.count += 1
src, tgt = self.sampler.data_source[i]
src_list.append(src)
tgt_list.append(tgt)
if self.count % self.batch_size == 0:
assert len(src_list) == self.batch_size
src = rnn.pad_sequence(src_list, batch_first=True, padding_value=self.pad_id)
tgt = rnn.pad_sequence(tgt_list, batch_first=True, padding_value=self.pad_id)
src_list.clear()
tgt_list.clear()
yield src, tgt
示例3: build_train_sampler
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def build_train_sampler(
data_source, train_sampler, batch_size=32, num_instances=4, **kwargs
):
"""Builds a training sampler.
Args:
data_source (list): contains tuples of (img_path(s), pid, camid).
train_sampler (str): sampler name (default: ``RandomSampler``).
batch_size (int, optional): batch size. Default is 32.
num_instances (int, optional): number of instances per identity in a
batch (when using ``RandomIdentitySampler``). Default is 4.
"""
assert train_sampler in AVAI_SAMPLERS, \
'train_sampler must be one of {}, but got {}'.format(AVAI_SAMPLERS, train_sampler)
if train_sampler == 'RandomIdentitySampler':
sampler = RandomIdentitySampler(data_source, batch_size, num_instances)
elif train_sampler == 'SequentialSampler':
sampler = SequentialSampler(data_source)
elif train_sampler == 'RandomSampler':
sampler = RandomSampler(data_source)
return sampler
示例4: shuffle_dataset
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def shuffle_dataset(loader, cur_epoch):
""""
Shuffles the data.
Args:
loader (loader): data loader to perform shuffle.
cur_epoch (int): number of the current epoch.
"""
sampler = (
loader.batch_sampler.sampler
if isinstance(loader.batch_sampler, ShortCycleBatchSampler)
else loader.sampler
)
assert isinstance(
sampler, (RandomSampler, DistributedSampler)
), "Sampler type '{}' not supported".format(type(sampler))
# RandomSampler handles shuffling automatically
if isinstance(sampler, DistributedSampler):
# DistributedSampler shuffles data based on epoch
sampler.set_epoch(cur_epoch)
示例5: Our_Dataloader
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def Our_Dataloader(dataset,batch_size,shuffle=True,num_workers=2,drop_last=True,max_iteration=100000000):
"""
幾近無限迭代器,迭代次數為1億次,每次迭代輸出一個批次的數據.
:param dataset: 數據集
:param batch_size: 批次數
:param max_iteration: 迭代的總次數,默認1億次,具體迭代次數,在取數據時進行判斷會更為靈活
:param shuffle:
:param num_workers:
:param drop_last:
:return:
"""
if shuffle:
sampler = RandomSampler(dataset) # 隨機采樣器
else:
sampler = SequentialSampler(dataset) # 順序采樣器
batch_sampler = BatchSampler_Our(sampler=sampler,
batch_size=batch_size,
max_iteration=max_iteration,
drop_last=drop_last)
loader = DataLoader(dataset=dataset,batch_sampler=batch_sampler,num_workers=num_workers,collate_fn=BatchCollator(is_train=dataset.is_train))
return loader
示例6: make_data_loader
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def make_data_loader(args, corpus, train_time=False):
dataset = data.MultiCorpusDataset(
args,
corpus,
args.word_dict,
args.feature_dict,
single_answer=False,
para_mode=args.para_mode,
train_time=train_time
)
sampler = SequentialSampler(dataset) if not train_time else RandomSampler(dataset)
loader = torch.utils.data.DataLoader(
dataset,
batch_size=args.batch_size,
sampler=sampler,
num_workers=args.data_workers,
collate_fn=vector.batchify(args, args.para_mode, train_time=train_time),
pin_memory=True
)
return loader
示例7: make_data_loader
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def make_data_loader(args, exs, train_time=False):
dataset = data.ReaderDataset(
args,
exs,
args.word_dict,
args.feature_dict,
single_answer=False,
train_time=train_time
)
sampler = SequentialSampler(dataset) if not train_time else RandomSampler(dataset)
batch_size = args.batch_size if train_time else args.test_batch_size
loader = torch.utils.data.DataLoader(
dataset,
batch_size=batch_size,
sampler=sampler,
num_workers=0,
collate_fn=vector.batchify,
pin_memory=True
)
return loader
示例8: __init__
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def __init__(self, origsilo, trainset, devset, testset):
self.tensor_names = origsilo.tensor_names
self.data = {"train": trainset, "dev": devset, "test": testset}
self.processor = origsilo.processor
self.batch_size = origsilo.batch_size
# should not be necessary, xval makes no sense with huge data
# sampler_train = DistributedSampler(self.data["train"])
sampler_train = RandomSampler(trainset)
self.data_loader_train = NamedDataLoader(
dataset=trainset,
sampler=sampler_train,
batch_size=self.batch_size,
tensor_names=self.tensor_names,
)
self.data_loader_dev = NamedDataLoader(
dataset=devset,
sampler=SequentialSampler(devset),
batch_size=self.batch_size,
tensor_names=self.tensor_names,
)
self.data_loader_test = NamedDataLoader(
dataset=testset,
sampler=SequentialSampler(testset),
batch_size=self.batch_size,
tensor_names=self.tensor_names,
)
self.loaders = {
"train": self.data_loader_train,
"dev": self.data_loader_dev,
"test": self.data_loader_test,
}
示例9: __init__
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def __init__(self, dataset, batch_size=1, shuffle=False, sampler=None, batch_sampler=None,
num_workers=0, collate_fn=default_collate, pin_memory=False, drop_last=False):
self.dataset = dataset
self.batch_size = batch_size
self.num_workers = num_workers
self.collate_fn = collate_fn
self.pin_memory = pin_memory
self.drop_last = drop_last
if batch_sampler is not None:
if batch_size > 1 or shuffle or sampler is not None or drop_last:
raise ValueError('batch_sampler is mutually exclusive with '
'batch_size, shuffle, sampler, and drop_last')
if sampler is not None and shuffle:
raise ValueError('sampler is mutually exclusive with shuffle')
if batch_sampler is None:
if sampler is None:
if shuffle:
sampler = RandomSampler(dataset)
else:
sampler = SequentialSampler(dataset)
batch_sampler = BatchSampler(sampler, batch_size, drop_last)
self.sampler = sampler
self.batch_sampler = batch_sampler
示例10: __init__
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def __init__(self, pairs, shuffle=False, batch_size=1, drop_last=False):
if shuffle:
self.sampler = RandomSampler(pairs)
else:
self.sampler = SequentialSampler(pairs)
self.batch_size = batch_size
self.drop_last = drop_last
示例11: __init__
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def __init__(self, data: Dataset, pad_id: int):
super().__init__(RandomSampler(data), Config.batch_size, True)
self.pad_id = pad_id
self.count = 0
示例12: get_data
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def get_data(split_id, data_dir, img_size, scale_size, batch_size,
workers, train_list, val_list):
root = data_dir
normalizer = T.Normalize(mean=[0.485, 0.456, 0.406],
std=[0.229, 0.224, 0.225]) # RGB imagenet
# with data augmentation
train_transformer = T.Compose([
T.RandomResizedCrop(img_size),
T.RandomHorizontalFlip(),
T.ToTensor(), # [0, 255] to [0.0, 1.0]
normalizer, # normalize each channel of the input
])
test_transformer = T.Compose([
T.Resize(scale_size),
T.CenterCrop(img_size),
T.ToTensor(),
normalizer,
])
train_loader = DataLoader(
Preprocessor(train_list, root=root,
transform=train_transformer),
batch_size=batch_size, num_workers=workers,
sampler=RandomSampler(train_list),
pin_memory=True, drop_last=False)
val_loader = DataLoader(
Preprocessor(val_list, root=root,
transform=test_transformer),
batch_size=batch_size, num_workers=workers,
shuffle=False, pin_memory=True)
return train_loader, val_loader
示例13: get_data
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def get_data(split_id, data_dir, img_size, scale_size, batch_size,
workers, train_list, val_list):
root = data_dir
normalizer = T.Normalize(mean=[0.485, 0.456, 0.406],
std=[0.229, 0.224, 0.225]) # RGB imagenet
# with data augmentation
train_transformer = T.Compose([
T.Resize(scale_size),
T.RandomCrop(img_size),
#T.RandomResizedCrop(img_size),
T.RandomHorizontalFlip(),
T.ToTensor(), # [0, 255] to [0.0, 1.0]
normalizer, # normalize each channel of the input
])
test_transformer = T.Compose([
T.Resize(scale_size),
T.CenterCrop(img_size),
T.ToTensor(),
normalizer,
])
train_loader = DataLoader(
Preprocessor(train_list, root=root,
transform=train_transformer),
batch_size=batch_size, num_workers=workers,
sampler=RandomSampler(train_list),
pin_memory=True, drop_last=False)
val_loader = DataLoader(
Preprocessor(val_list, root=root,
transform=test_transformer),
batch_size=batch_size, num_workers=workers,
shuffle=False, pin_memory=True)
return train_loader, val_loader
示例14: get_data
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def get_data(split_id, data_dir, img_size, scale_size, batch_size,
workers, train_list, val_list):
root = data_dir
normalizer = T.Normalize(mean=[0.485, 0.456, 0.406],
std=[0.229, 0.224, 0.225]) # RGB imagenet
# with data augmentation
train_transformer = T.Compose([
T.Resize(scale_size),
T.RandomCrop(img_size),
T.RandomHorizontalFlip(),
T.ToTensor(), # [0, 255] to [0.0, 1.0]
normalizer, # normalize each channel of the input
])
test_transformer = T.Compose([
T.Resize(scale_size),
T.CenterCrop(img_size),
T.ToTensor(),
normalizer,
])
train_loader = DataLoader(
Preprocessor(train_list, root=root,
transform=train_transformer),
batch_size=batch_size, num_workers=workers,
sampler=RandomSampler(train_list),
pin_memory=True, drop_last=False)
val_loader = DataLoader(
Preprocessor(val_list, root=root,
transform=test_transformer),
batch_size=batch_size, num_workers=workers,
shuffle=False, pin_memory=True)
return train_loader, val_loader
示例15: loader_setup
# 需要導入模塊: from torch.utils.data import sampler [as 別名]
# 或者: from torch.utils.data.sampler import RandomSampler [as 別名]
def loader_setup(self, args):
logging.info("Creating samplers ...")
train_sampler = RandomSampler(self.train_data)
dev_sampler = RandomSampler(self.dev_data)
logging.info("Creating data loaders ...")
self.train_loader = DataLoader(
dataset=self.train_data,
batch_size=args.batch_size,
num_workers=args.workers,
pin_memory=args.pin_memory,
sampler=train_sampler,
)
self.dev_loader = DataLoader(
dataset=self.dev_data,
batch_size=args.batch_size,
num_workers=args.workers,
pin_memory=args.pin_memory,
sampler=dev_sampler,
)
self.display_loader = DataLoader(
dataset=self.display_data,
batch_size=args.batch_size,
num_workers=args.workers,
pin_memory=args.pin_memory,
drop_last=False,
)
logging.debug("Determining batches ...")
self.nbatches = len(self.train_loader)
logging.info("Train Loader created, batches: {}".format(self.nbatches))