【D2L学习笔记】人造数据 Synthetic Regression Data 3.3

本文探讨了在D2L中使用DataModule进行面向对象设计,涉及数据生成、模型评估及高效数据加载方法,以PyTorch为核心工具。
摘要由CSDN通过智能技术生成

人造数据

主要内容: 介绍了如何在面向对象的设计下,实现 d2l 框架中的 DataModule 的方法

人造数据的意义: 用于评估模型的能力

如何生成数据集?

自定义一个类,并继承自 DataModule,在 init 中完成数据的生成

例子:

class SyntheticRegressionData(d2l.DataModule):  #@save
    """Synthetic data for linear regression."""
    def __init__(self, w, b, noise=0.01, num_train=1000, num_val=1000,
                 batch_size=32):
        super().__init__()
        self.save_hyperparameters()
        n = num_train + num_val
        self.X = torch.randn(n, len(w))
        noise = torch.randn(n, 1) * noise
        self.y = torch.matmul(self.X, w.reshape((-1, 1))) + b + noise

调用 init 和 save_hyperparameters 将参数变为类的属性

如何加载数据集?

使用 add_to_class 修饰器重载 get_dataloader 方法

例子:

@d2l.add_to_class(SyntheticRegressionData)
def get_dataloader(self, train):
    if train:
        indices = list(range(0, self.num_train))
        # The examples are read in random order
        random.shuffle(indices)
    else:
        indices = list(range(self.num_train, self.num_train+self.num_val))
    for i in range(0, len(indices), self.batch_size):
        batch_indices = torch.tensor(indices[i: i+self.batch_size])
        yield self.X[batch_indices], self.y[batch_indices]

train 用来判断数据是训练集(随机)还是验证集(按顺序)

更加简洁且高效的实现

使用 Pytorch 等框架中内置的 API 加载数据

更高效,功能更多

实现:

@d2l.add_to_class(d2l.DataModule)  #@save
def get_tensorloader(self, tensors, train, indices=slice(0, None)):
    tensors = tuple(a[indices] for a in tensors)
    dataset = torch.utils.data.TensorDataset(*tensors)
    return torch.utils.data.DataLoader(dataset, self.batch_size,
                                       shuffle=train)

tensors 是含有若干张量的元组,将 tensors 中每一个张量进行切片,再整合为新的 tensors

dataset 以新的 tensors 作为数据

最终返回一个内置的 DataLoader

重载 get_dataloader:

@d2l.add_to_class(SyntheticRegressionData)  #@save
def get_dataloader(self, train):
    i = slice(0, self.num_train) if train else slice(self.num_train, None)
    return self.get_tensorloader((self.X, self.y), train, i)

[end]

mofianger

2024/2/1

代码引自 en.d2l.ai

参考:3.3. Synthetic Regression Data — Dive into Deep Learning 1.0.3 documentation (d2l.ai)

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值