重写dataset后dataloader的动态变化

总结:
如果要实现动态变化的dataloader,必须重写dataset的len方法

import torch
from torch.utils.data import DataLoader, TensorDataset

随机生成 100 个样本,每个样本 10 个特征

data = torch.randn(10, 1) # 100个样本,每个样本10个特征

随机生成 100 个标签(二分类标签,0 或 1)

targets = torch.randint(0, 2, (10,)) # 100个标签,取值为0或1

创建 TensorDataset

class MyDataset(TensorDataset):
def init(self, data, targets):
super(MyDataset, self).init(data, targets)
self.data = data
self.targets = targets
def len(self):
return len(self.data)
def getitem(self, index):
# data = super(MyDataset, self).getitem(index)
return self.data[index], self.targets[index]
def aug_data(self,extra_data,extra_targets):
self.data=torch.cat((self.data,extra_data),0)
self.targets=torch.cat((self.targets,extra_tar

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值