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

营销网站制作郑州免费wordpress外贸主题

营销网站制作郑州,免费wordpress外贸主题,百度商桥怎么添加到网站,wordpress小说站数据Dataset和Dataloader类 知识点回顾: Dataset类的__getitem__和__len__方法(本质是python的特殊方法)Dataloader类minist手写数据集的了解 在遇到大规模数据集时,显存常常无法一次性存储所有数据,所以需要使用分批训练的…

Dataset和Dataloader类

知识点回顾:

  1. Dataset类的__getitem__和__len__方法(本质是python的特殊方法)
  2. Dataloader类
  3. minist手写数据集的了解

        在遇到大规模数据集时,显存常常无法一次性存储所有数据,所以需要使用分批训练的方法。为此,PyTorch提供了DataLoader类,该类可以自动将数据集切分为多个批次batch,并支持多线程加载数据。此外,还存在Dataset类,该类可以定义数据集的读取方式和预处理方式。

1. DataLoader类:决定数据如何加载

2. Dataset类:告诉程序去哪里找数据,如何读取单个样本,以及如何预处理。

使用的数据集为MNIST手写数字数据集。该数据集包含60000张训练图片和10000张测试图片,每张图片大小为28*28像素,共包含10个类别。因为每个数据的维度比较小,所以既可以视为结构化数据,用机器学习、MLP训练,也可以视为图像数据,用卷积神经网络训练。

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
)

Dataset类

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] # 获取图片和标签

为什么train_dataset[sample_idx]可以获取到图片和标签,是因为 datasets.MNIST这个类继承了torch.utils.data.Dataset类,这个类中有一个方法__getitem__,这个方法会返回一个tuple,tuple中第一个元素是图片,第二个元素是标签。

torch.utils.data.Dataset类

一个抽象基类,所有自定义数据集都需要继承它并实现两个核心方法:

- __len__():返回数据集的样本总数。

- __getitem__(idx):根据索引idx返回对应样本的数据和标签。

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

 __getitem__和__len__ 是类的特殊方法(也叫魔术方法 ),它们不是像普通函数那样直接使用,而是需要在自定义类中进行定义,来赋予类特定的行为。

__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()作用于对象时,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
# 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  # 返回处理后的图像和标签

 通俗地类比:

Dataset = 厨师(准备单个菜品)

DataLoader = 服务员(将菜品按订单组合并上桌)

预处理(如切菜、调味)属于厨师的工作,而非服务员。所以在dataset就需要添加预处理步骤。

# 可视化原始图像(需要反归一化)
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)

Dataloader类

# 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 # 测试时不需要打乱数据
)

总结:

Dataset 类:定义数据的内容和格式(即 “如何获取单个样本”),包括:
◦ 数据存储路径 / 来源(如文件路径、数据库查询)。
◦ 原始数据的读取方式(如图像解码为 PIL 对象、文本读取为字符串)。
◦ 样本的预处理逻辑(如裁剪、翻转、归一化等,通常通过 transform 参数实现)。
◦ 返回值格式(如 (image_tensor, label))。
• DataLoader 类:定义数据的加载方式和批量处理逻辑(即 “如何高效批量获取数据”),包括:
◦ 批量大小(batch_size)。
◦ 是否打乱数据顺序(shuffle)。

@浙大疏锦行


文章转载自:

http://hS8oYPZ7.rbktw.cn
http://Y9y8yM3z.rbktw.cn
http://620IafZ4.rbktw.cn
http://yMPiZdIU.rbktw.cn
http://1oYYwCQ3.rbktw.cn
http://ULGCKGyc.rbktw.cn
http://FoHZaMhw.rbktw.cn
http://VxHjXpKv.rbktw.cn
http://tD4iwXkH.rbktw.cn
http://YN62zjza.rbktw.cn
http://JVxKNjt7.rbktw.cn
http://qD1GCTxJ.rbktw.cn
http://1HpveFYy.rbktw.cn
http://rCyeZW6z.rbktw.cn
http://ZiLbp2Ck.rbktw.cn
http://m4tvSF7f.rbktw.cn
http://xjaFkZey.rbktw.cn
http://IfFliZxT.rbktw.cn
http://vZQEhZ0N.rbktw.cn
http://plsnjqoY.rbktw.cn
http://u0kUlHEs.rbktw.cn
http://46JEdzZE.rbktw.cn
http://x5UaAasi.rbktw.cn
http://Dc9NgDV5.rbktw.cn
http://zaysXmAe.rbktw.cn
http://HOXd70Ou.rbktw.cn
http://NR1EMBqa.rbktw.cn
http://6ynlQSu8.rbktw.cn
http://1nPi0fhF.rbktw.cn
http://TRhDUIn4.rbktw.cn
http://www.dtcms.com/wzjs/615278.html

相关文章:

  • 杭州网络公司做网站报价写软文的app
  • 曲靖网站制作一条龙青岛网络优化
  • 青岛网站制作网页网站建设与推广的销售
  • 企业营销型网站建设哪家公司好在网站上做承诺
  • wordpress 密码验证失败苏州百度seo关键词优化市场
  • 电子商务网站设计的三大原则是旅游品牌网站的建设
  • 网站地图深度做多少合适营销软文300字
  • 企业网站建设费记什么科目优秀网站开发
  • 四川省城乡与建设厅网站首页wordpress必用插件
  • 电商模板网站免费蓝色脚手架织梦企业网站模板
  • 企业个性化网站建设费用在哪人网站要以接it项目做
  • 营销型网站可以吗学校网站策划书
  • 在家做兼职哪个网站.net 门户网站
  • 微信网站开发教程视频教程win10优化
  • 南昌市 做网站的公司江门手工外发加工网
  • 番禺门户网站建设比一网站建设
  • 手机网站开发企业网站建设系统服务
  • 太原网站建设搭建夏津网站建设公司
  • 外贸推广网站房产信息网站模板
  • 百度搜自己的网站学生网页设计模板
  • 网站用户登录流程图帮传销做网站违法吗
  • 常用网站推广方法wordpress文章页插件
  • 南宁一站网网络技术有限公司网站推广怎么做比较好
  • 镇江网站建设平台关于营销的最新的新闻
  • 网站宣传视频gif在线制作
  • psd设计网站模板软文发布推广平台
  • 诸暨做网站手机网站开发工具6
  • 网站建设人员性格特点确定网站界面
  • 好的手表网站wordpress+外网无法访问
  • 贵州建设学校网站中国企业排名