news 2026/4/18 10:01:48

Day41 Dataset和Dataloader

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Day41 Dataset和Dataloader
import torch import torch.nn as nn import torch.optim as optim from torch.utils.data import DataLoader , Dataset # DataLoader 是 PyTorch 中用于加载数据的工具 from torchvision import datasets, transforms # torchvision 是一个用于计算机视觉的库,datasets 和 transforms 是其中的模块 import matplotlib.pyplot as plt # 设置随机种子,确保结果可复现 torch.manual_seed(42) # 1. 数据预处理,该写法非常类似于管道pipeline # transforms 模块提供了一系列常用的图像预处理操作 # 先归一化,再标准化 transform = transforms.Compose([ transforms.ToTensor(), # 转换为张量并归一化到[0,1] transforms.Normalize((0.1307,), (0.3081,)) # MNIST数据集的均值和标准差,这个值很出名,所以直接使用 ]) # 2. 加载MNIST数据集,如果没有会自动下载 train_dataset = datasets.MNIST( root='./data', train=True, download=True, transform=transform ) test_dataset = datasets.MNIST( root='./data', train=False, transform=transform ) import matplotlib.pyplot as plt # 随机选择一张图片,可以重复运行,每次都会随机选择 sample_idx = torch.randint(0, len(train_dataset), size=(1,)).item() # 随机选择一张图片的索引 # len(train_dataset) 表示训练集的图片数量;size=(1,)表示返回一个索引;torch.randint() 函数用于生成一个指定范围内的随机数,item() 方法将张量转换为 Python 数字 image, label = train_dataset[sample_idx] # 获取图片和标签 # 示例代码 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 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 # minist数据集的简化版本 class MNIST(Dataset): def __init__(self, root, train=True, transform=None): # 初始化:加载图片路径和标签 self.data, self.targets = fetch_mnist_data(root, train) # 这里假设 fetch_mnist_data 是一个函数,用于加载 MNIST 数据集的图片路径和标签 self.transform = transform # 预处理操作 def __len__(self): return len(self.data) # 返回样本总数 def __getitem__(self, idx): # 获取指定索引的样本 # 获取指定索引的图像和标签 img, target = self.data[idx], self.targets[idx] # 应用图像预处理(如ToTensor、Normalize) if self.transform is not None: # 如果有预处理操作 img = self.transform(img) # 转换图像格式 # 这里假设 img 是一个 PIL 图像对象,transform 会将其转换为张量并进行归一化 return img, target # 返回处理后的图像和标签 # 可视化原始图像(需要反归一化) def imshow(img): img = img * 0.3081 + 0.1307 # 反标准化 npimg = img.numpy() plt.imshow(npimg[0], cmap='gray') # 显示灰度图像 plt.show() print(f"Label: {label}") imshow(image) # 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 # 测试时不需要打乱数据 )

@浙大疏锦行

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 21:38:56

Web端调用TensorRT?通过WASM实现的可能性探讨

Web端调用TensorRT?通过WASM实现的可能性探讨 在浏览器里跑深度学习模型,听起来像天方夜谭吗?十年前或许是。但今天,随着WebAssembly(WASM)的成熟和AI推理框架的轻量化演进,我们正站在一个技术拐…

作者头像 李华
网站建设 2026/4/17 23:06:14

【课程设计/毕业设计】基于springboot的校园二手交易平台物品管理-求购物品 ◦ 学生管理【附源码、数据库、万字文档】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/4/17 14:29:22

开源大模型+TensorRT镜像超强推理组合?真相来了

开源大模型TensorRT镜像超强推理组合?真相来了 在生成式AI浪潮席卷各行各业的今天,越来越多企业试图将LLaMA、Falcon、ChatGLM等开源大模型部署到生产环境。然而,现实往往令人沮丧:一个7B参数的模型,在PyTorch下逐toke…

作者头像 李华
网站建设 2026/4/16 12:00:58

django基于Python豆瓣电影数据可视化分析设计与实现

背景分析随着互联网和数字化娱乐的快速发展,电影产业数据呈现爆炸式增长。豆瓣作为国内权威的电影评分平台,积累了海量用户评分、评论和电影元数据。这些数据蕴含用户偏好、市场趋势及文化现象,但原始数据难以直接洞察规律。通过数据可视化技…

作者头像 李华
网站建设 2026/4/16 12:01:01

大模型服务成本太高?用TensorRT降低90%推理开销

用TensorRT降低90%推理开销:大模型落地的性价比革命 在AI服务从实验室走向生产环境的过程中,一个现实问题正变得越来越尖锐:为什么训练好的大模型一上线,成本就高得让人喘不过气? 你可能经历过这样的场景——一个微调后…

作者头像 李华
网站建设 2026/4/17 12:53:22

django基于Spark的南昌房价数据分析系统的设计与实现

背景分析房地产行业作为国民经济支柱产业之一,房价波动直接影响民生与经济稳定。南昌作为江西省会城市,近年来城市化进程加速,房价呈现复杂变化趋势。传统数据分析方法受限于处理能力和实时性,难以应对海量房产数据(如…

作者头像 李华