網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
PyTorch之TensorDataset
TensorDataset 可以用來對(duì)?tensor?進(jìn)行打包,就好像 python 中的 zip 功能。
該類通過每一個(gè) tensor 的第一個(gè)維度進(jìn)行索引。
因此,該類中的 tensor 第一維度必須相等。
from torch.utils.data import TensorDataset
import torch
from torch.utils.data import DataLoader
a = torch.tensor([[1, 2, 3], [4, 5, 6], [7, 8, 9], [1, 2, 3], [4, 5, 6], [7, 8, 9], [1, 2, 3], [4, 5, 6], [7, 8, 9], [1, 2, 3], [4, 5, 6], [7, 8, 9]])
b = torch.tensor([44, 55, 66, 44, 55, 66, 44, 55, 66, 44, 55, 66])
train_ids = TensorDataset(a, b)
# 切片輸出
print(train_ids[0:2])
print('=' * 80)
# 循環(huán)取數(shù)據(jù)
for x_train, y_label in train_ids:
print(x_train, y_label)
# DataLoader進(jìn)行數(shù)據(jù)封裝
print('=' * 80)
train_loader = DataLoader(dataset=train_ids, batch_size=4, shuffle=True)
for i, data in enumerate(train_loader, 1): # 注意enumerate返回值有兩個(gè),一個(gè)是序號(hào),一個(gè)是數(shù)據(jù)(包含訓(xùn)練數(shù)據(jù)和標(biāo)簽)
x_data, label = data
print(' batch:{0} x_data:{1} label: {2}'.format(i, x_data, label))
運(yùn)行結(jié)果:
(tensor([[1, 2, 3],
? ? ? ? [4, 5, 6]]), tensor([44, 55]))
================================================================================
tensor([1, 2, 3]) tensor(44)
tensor([4, 5, 6]) tensor(55)
tensor([7, 8, 9]) tensor(66)
tensor([1, 2, 3]) tensor(44)
tensor([4, 5, 6]) tensor(55)
tensor([7, 8, 9]) tensor(66)
tensor([1, 2, 3]) tensor(44)
tensor([4, 5, 6]) tensor(55)
tensor([7, 8, 9]) tensor(66)
tensor([1, 2, 3]) tensor(44)
tensor([4, 5, 6]) tensor(55)
tensor([7, 8, 9]) tensor(66)
================================================================================
?batch:1 x_data:tensor([[1, 2, 3],
? ? ? ? [1, 2, 3],
? ? ? ? [4, 5, 6],
? ? ? ? [4, 5, 6]]) ?label: tensor([44, 44, 55, 55])
?batch:2 x_data:tensor([[4, 5, 6],
? ? ? ? [7, 8, 9],
? ? ? ? [7, 8, 9],
? ? ? ? [7, 8, 9]]) ?label: tensor([55, 66, 66, 66])
?batch:3 x_data:tensor([[1, 2, 3],
? ? ? ? [1, 2, 3],
? ? ? ? [7, 8, 9],
? ? ? ? [4, 5, 6]]) ?label: tensor([44, 44, 66, 55])
注意:TensorDataset 中的參數(shù)必須是 tensor
Pytorch中TensorDataset的快速使用
Pytorch中,TensorDataset()可以快速構(gòu)建訓(xùn)練所用的數(shù)據(jù),不用使用自建的Mydataset(),如果沒有熟悉適用的dataset可以使用TensorDataset()作為暫時(shí)替代。
只需要把data和label作為參數(shù)輸入,就可以快速構(gòu)建,之后便可以用Dataloader處理。
import numpy as np
from torch.utils.data import DataLoader, TensorDataset
data = np.loadtxt('x.txt')
label = np.loadtxt('y.txt')
data = torch.tensor(data)
label = torch.tensor(label)
train_data = TensorDataset(data, label)
train_loader = DataLoader(dataset=train_data, batch_size=BATCH_SIZE, shuffle=True)?
總結(jié)
原文鏈接:https://blog.csdn.net/qq_40211493/article/details/107529148
- 上一篇:沒有了
- 下一篇:沒有了
相關(guān)推薦
- 2024-02-25 關(guān)于數(shù)據(jù)庫(kù)時(shí)間為datetime,前臺(tái)數(shù)據(jù)不正常級(jí)時(shí)區(qū)+8問題
- 2022-08-11 C#使用DoddleReport快速生成報(bào)表_C#教程
- 2022-07-07 Android?配合Mat工具監(jiān)聽查找內(nèi)存泄漏的操作方法_Android
- 2022-04-22 git報(bào)錯(cuò)Please make sure you have the correct access
- 2023-02-03 VB十七種可用一行代碼完成判斷的技巧代碼_vb
- 2022-12-29 R語(yǔ)言中dnorm,pnorm,qnorm和rnorm的區(qū)別淺析_R語(yǔ)言
- 2022-07-13 @postconstruct注解 和 InitializingBean 在bean實(shí)例化后執(zhí)行某些初
- 2022-04-12 git 提交到遠(yuǎn)程倉(cāng)庫(kù) 報(bào)錯(cuò) error: failed to push some refs to
- 欄目分類
-
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支