当前位置: 首页 > news >正文

day 38

Dataset类

定义数据的内容和格式(即“如何获取单个样本”),包括:

  - 数据存储路径/来源(如文件路径、数据库查询)。

  - 原始数据的读取方式(如图像解码为PIL对象、文本读取为字符串)。

  - 样本的预处理逻辑(如裁剪、翻转、归一化等,通常通过`transform`参数实现)。

  - 返回值格式(如`(image_tensor, label)`)。

重点:

PyTorch 要求所有数据集必须实现__getitem__和__len__,这样才能被DataLoader等工具兼容。这是一种接口约定,类似函数参数的规范。这意味着,如果你要创建一个自定义数据集,你需要实现这两个方法,否则PyTorch将无法识别你的数据集。

__getitem__方法

__getitem__方法用于让对象支持索引操作,当使用[]语法访问对象元素时,Python 会自动调用该方法。

# 示例代码
class MyList:def __init__(self):self.data = [10, 20, 30, 40, 50]def __getitem__(self, idx):return self.data[idx]# 创建类的实例
my_list_obj = MyList()
# 此时可以使用索引访问元素,这会自动调用__getitem__方法
print(my_list_obj[2])  # 输出:30

__len__方法

__len__方法用于返回对象中元素的数量,当使用内置函数len()作用于对象时,Python 会自动调用该方法。

class MyList:def __init__(self):self.data = [10, 20, 30, 40, 50]def __len__(self):return len(self.data)# 创建类的实例
my_list_obj = MyList()
# 使用len()函数获取元素数量,这会自动调用__len__方法
print(len(my_list_obj))  # 输出:5

Dataloader类

定义数据的加载方式和批量处理逻辑(即“如何高效批量获取数据”),包括:

  - 批量大小(`batch_size`)。

  - 是否打乱数据顺序(`shuffle`)。

# 3. 创建数据加载器
train_loader = DataLoader(train_dataset,batch_size=64, # 每个批次64张图片,一般是2的幂次方,这与GPU的计算效率有关shuffle=True # 随机打乱数据
)test_loader = DataLoader(test_dataset,batch_size=1000 # 每个批次1000张图片# shuffle=False # 测试时不需要打乱数据
)

作业:

了解下cifar数据集,尝试获取其中一张图片

import torch
import torchvision
import torchvision.transforms as transforms
import matplotlib.pyplot as plt
import numpy as np# 数据预处理
transform = transforms.Compose([transforms.ToTensor(),transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))
])# 加载CIFAR - 10数据集
train_dataset = torchvision.datasets.CIFAR10(root='./data',train=True,download=True,transform=transform
)# 随机选择一张图片
sample_idx = torch.randint(0, len(train_dataset), size=(1,)).item()
image, label = train_dataset[sample_idx]  # 获取图片和标签# 可视化原始图像(需要反归一化)
def imshow(img):img = img * 0.5 + 0.5  # 反标准化,对应CIFAR - 10的标准化参数npimg = img.numpy()npimg = np.transpose(npimg, (1, 2, 0))  # 调整维度顺序,从 (C, H, W) 到 (H, W, C)plt.imshow(npimg)plt.show()imshow(image)

相关文章:

  • python-自定义导包问题ModuleNotFoundError: No module named
  • uni-app 中开发问题汇总
  • 走进黑盒:SQL 是如何在数据库中执行的?
  • 大模型应用:开发移动端页面个人中心页面提示词
  • CVPR2022——立体匹配算法Fast-ACVNet复现
  • 不同数据场景下的聚类算法
  • MybatisPlus - Interceptor(拦截器)的功能点
  • 完全卸载VS Code--Windows版
  • 图文详解 | PhotoScape X Pro 4.2.5 安装步骤与功能初探
  • 003大模型-大模型API调用,function calling的作用以及本地调用
  • 枪弹库专用门
  • Linux挂载新硬盘保姆级教程
  • C++ `typeid` 运算符
  • Python页面纸张大小设置
  • JavaScript的call和apply
  • Qt中的智能指针
  • 【深度学习新浪潮】以图搜地点是如何实现的?(含大模型方案)
  • 哈尔滨云前沿服务器托管,服务器租用
  • 打板策略实战对比,khQuant回测横评第三弹【AI量化第29篇】
  • 题目 3313: 蓝桥杯2025年第十六届省赛真题-电池分组
  • 中国进口贸易网官网/seo网站推广平台
  • 网站首页该怎么做/百度移动端关键词优化
  • 承天示优网站建设项目/搜索引擎外部优化有哪些渠道
  • 如何开网站做代销/世界十大网站排名出炉
  • 自己做网站上传视频/网站如何做seo排名
  • 网站 建设 网站设计公司/西安百度公司