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

相关推荐
阿瑞IT3 分钟前
AI Agent 从 Demo 到生产:被低估的四个工程问题
人工智能
小锋java12343 分钟前
【技术专题】LangChain4j 开发Java Agent智能体 - 整合SpringBoot4
java·人工智能
MemOS3 分钟前
产品更新 |MemOS CLI 上线:让能跑命令行的 Agent 更轻量接入长期记忆
人工智能
独秀不如众秀4 分钟前
AI Coding 的最大问题不是写错代码,而是反复犯同一个错
人工智能
CV实验室6 分钟前
Remote Sensing 29个SITS基准数据集综述:多模态遥感分类的新起点
人工智能·深度学习·计算机视觉·音视频
m0_4665252912 分钟前
锚定场景深耕数据 东软探索城市全域数字化新路径
大数据·人工智能
Data-Miner14 分钟前
智慧城市数据中台建设方案深度解析PPT解读
人工智能·智慧城市
喵了几个咪21 分钟前
AI重构软件开发范式:框架与脚手架为何仍是生产级开发的刚需?
vue.js·人工智能·react.js·重构·golang·ai编程
星辰AI25 分钟前
告别翻译腔:用 AI Agent 自动化构建开源项目的多语言技术文档
人工智能·ai·语言模型
KJ_BioMed28 分钟前
突破“不可成药”靶点:科晶生物AI互作蛋白与纳米抗体设计技术解析
人工智能·抗体药物·多肽药物·多肽设计·抗体设计