PyTorch自学&遇到的一些错误

为什么是false?

①检查GPU是否支持CUDA?

支持

理解Package结构及法宝函数的作用

pytorch就像一个工具箱

dir():打开操作,能看到里面有什么东西---->dir(torch)

help():说明书---->help(torch.cuda.is_available)

From torch.utils.data import Dataset

pytorch如何读取数据?

①Dataset

提供一种方式去获取数据及其label

如何获取每一个数据及其label

告诉我们总共有多少的数据

②Dataloader

为网络提供不同的数据形式

Tensorboard的使用

Global_step:x轴

Scalar_value:y轴

如何读取logs里面的文件

PS F:\HDU\PyTorchStudy> tensorboard --logdir=logs

指定端口:tensorboard --logdir=logs --port=6007

结果:有图像展示

图像变换,transform的使用

利用numpy.array(),对PIL图片进行转换

torchvision中的transforms:对图像进行一个变换

Transforms.py 工具箱

Totensor/resize/。。。

图片--->工具 --->结果

结果:

tensor(\[\[0.3137, 0.3137, 0.3137, ..., 0.3176, 0.3098, 0.2980,
0.3176, 0.3176, 0.3176, ..., 0.3176, 0.3098, 0.2980,
0.3216, 0.3216, 0.3216, ..., 0.3137, 0.3098, 0.3020,
...,
0.3412, 0.3412, 0.3373, ..., 0.1725, 0.3725, 0.3529,
0.3412, 0.3412, 0.3373, ..., 0.3294, 0.3529, 0.3294,
0.3412, 0.3412, 0.3373, ..., 0.3098, 0.3059, 0.3294],

\[0.5922, 0.5922, 0.5922, ..., 0.5961, 0.5882, 0.5765,
0.5961, 0.5961, 0.5961, ..., 0.5961, 0.5882, 0.5765,
0.6000, 0.6000, 0.6000, ..., 0.5922, 0.5882, 0.5804,
...,
0.6275, 0.6275, 0.6235, ..., 0.3608, 0.6196, 0.6157,
0.6275, 0.6275, 0.6235, ..., 0.5765, 0.6275, 0.5961,
0.6275, 0.6275, 0.6235, ..., 0.6275, 0.6235, 0.6314],

\[0.9137, 0.9137, 0.9137, ..., 0.9176, 0.9098, 0.8980,
0.9176, 0.9176, 0.9176, ..., 0.9176, 0.9098, 0.8980,
0.9216, 0.9216, 0.9216, ..., 0.9137, 0.9098, 0.9020,
...,
0.9294, 0.9294, 0.9255, ..., 0.5529, 0.9216, 0.8941,
0.9294, 0.9294, 0.9255, ..., 0.8863, 1.0000, 0.9137,
0.9294, 0.9294, 0.9255, ..., 0.9490, 0.9804, 0.9137]])

常见的Transforms

|----|---------|--------------|
| 输入 | PIL | Image.open() |
| 输出 | tensor | ToTensor() |
| 作用 | narrays | Cv.imread() |

call的使用

__call__Hello zhangsan
Hellolisi

归一化:Normalize

outputchannel = (inputchannel - meanchannel) / stdchannel

<PIL.JpegImagePlugin.JpegImageFile image mode=RGB size=500x333 at 0x232A68BC488>
tensor(0.8863)
tensor(0.7725)

Resize()的使用

(500, 333)
tensor(\[\[0.8863, 0.8824, 0.8745, ..., 0.8392, 0.8392, 0.8392,
0.8824, 0.8784, 0.8706, ..., 0.8392, 0.8392, 0.8392,
0.8784, 0.8745, 0.8667, ..., 0.8353, 0.8353, 0.8353,
...,
1.0000, 1.0000, 1.0000, ..., 0.8314, 0.8314, 0.8314,
1.0000, 1.0000, 1.0000, ..., 0.8314, 0.8314, 0.8314,
1.0000, 1.0000, 1.0000, ..., 0.8314, 0.8314, 0.8314],

\[0.1451, 0.1412, 0.1333, ..., 0.8471, 0.8471, 0.8471,
0.1451, 0.1412, 0.1333, ..., 0.8471, 0.8471, 0.8471,
0.1490, 0.1451, 0.1373, ..., 0.8431, 0.8431, 0.8431,
...,
0.8275, 0.8275, 0.8275, ..., 0.8549, 0.8549, 0.8549,
0.8275, 0.8275, 0.8275, ..., 0.8549, 0.8549, 0.8549,
0.8275, 0.8275, 0.8275, ..., 0.8549, 0.8549, 0.8549],

\[0.1686, 0.1647, 0.1569, ..., 0.4275, 0.4275, 0.4275,
0.1686, 0.1647, 0.1569, ..., 0.4275, 0.4275, 0.4275,
0.1686, 0.1647, 0.1569, ..., 0.4235, 0.4235, 0.4235,
...,
0.0078, 0.0078, 0.0078, ..., 0.4235, 0.4235, 0.4235,
0.0078, 0.0078, 0.0078, ..., 0.4235, 0.4235, 0.4235,
0.0078, 0.0078, 0.0078, ..., 0.4235, 0.4235, 0.4235]])

Compose()用法

数据需要时transforms类型,所以得到Compose(transforms参数1,transforms参数2,...)

RandomCrop

关注输入和输出类型

多看官方文档

关注方法需要什么参数

不知道返回值的时候

*print

*print(type())

*debug

DataLoader的使用

例:

Dataloader(batch_size=4)

Img0,target0 = dataset0

Img1,target1 = dataset1

Img2,target2 = dataset2

Img3,target3 = dataset3

Getitem():

Return img,target

神经网络的搭建nn.Module

相关推荐
大模型真好玩1 小时前
什么是Loop Engineering?最通俗易懂的Loop Engineering核心概念
人工智能·agent·deepseek
叁两1 小时前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js
顾林海1 小时前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程
LaiYoung_1 小时前
🎁 送你一套超好用超实用的 FE AI-Coding Skills
前端·人工智能·开源
ZzT4 小时前
怎么做才不会被 AI 替代?
人工智能·程序员
道友可好4 小时前
从今天开始:你的第一个 Harness Engineering 实践
前端·人工智能·后端
呱呱复呱呱4 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的
python·django
小姜前线技术5 小时前
AI回答代码块高亮加一键复制
人工智能
洛阳泰山5 小时前
从 0 到 1.6K Star:一个 Java 开源项目的增长复盘
人工智能·后端·开源
米小虾6 小时前
Agent Skill 设计模式完全指南
人工智能·agent