pytorch 之 nn 库与调试

系列文章目录


文章目录

  • 系列文章目录
  • [一、torch.nn 库](#一、torch.nn 库)
    • [1. nn.Parameter](#1. nn.Parameter)
    • [2. 基于nn.Moduel 的接口](#2. 基于nn.Moduel 的接口)
    • [3. nn.functional](#3. nn.functional)
    • 4.nn.Sequential
  • 二、调式visdom
    • [1. vidom 功能简介](#1. vidom 功能简介)
    • [2. visdom 安装](#2. visdom 安装)
    • [visdom 简单编程](#visdom 简单编程)
    • [三、tensorboardX 数据可视化工具](#三、tensorboardX 数据可视化工具)


一、torch.nn 库

  • torch.nn 是专门为神经网络设计的接口
  • torch.nn 构建于 autograd 之上,可以用来定义和构建神经网络。
    五个常用的函数:
    nn.Patameter
    nn.Linear & nn.cov2d
    nn.functional
    nn.Model
    nn.Sequential

1. nn.Parameter

该接口来定义可训练参数:

  • self.my_param = nn.Parameter(torch.randn(1)) 定义和初始化参数
  • self.register_parameter 注册可训练参数,效果一致
  • nn.ParameterList & nn.ParameterDict 使用列表或者字典来定义多个可训练的参数。
python 复制代码
import torch
from torch import nn

self.paramas = nn.ParameterList([nn.Parameter(torch.randn(10,10)) for i in range(10)])

self.grads = nn.ParameterDisct({
    'left': nn.Parameter(torch.randn(5,10)),
    'right': nn.Parameter(torch.randn(5.10))
})

列表和字典与我们Python定义的数据结构是一样的。

2. 基于nn.Moduel 的接口

nn.Linear & nn.conv2d & nn.ReLU & nn.MaxPool2d() & nn.MESLoos这些函数都基于 nn.Module,实现了前向传播和后向传播,我们直接调用就行,非常省事

  • 各种神经网络层的定义,基于 nn.Module 的子类
    • self.conv1 = nn.Conv2d(1,6,(5,5)) 定义一个卷积类,初始化卷积的具体参数。
    • 调用时 self.conv1(x) 调用这个卷积类,进行一次卷积操作,前向运算。
  • 定义网络层,参数为Parameter 类型,也叫可训练类型的参数:
    • lay = nn.Linear(1,1)
    • lay.weight = nn.Parameter(torch.FloatTensor([[0]]))
    • lay.bias = nn.Parameter(torch.FloatTensor([0]))

3. nn.functional

包含 torch.nn 库中所有的函数,包含大量的 Loss 和 activation function:

  • nn.functional.conv2d(input,weight,bias = None,Stride = 1,padding = 0,dialtion = 1,groups = 1) 这个是函数,不是类,与上面有本质的区别
  • nn.functional.xx 本质上就是一个函数接口,无法和 nn.Sequential 结合使用。没有学习参数使用 nn.xx 和 nn.functional.xx 都可以,有学习参数就建议使用 nn.xx.
  • 特别注意 DropOut 层。

4.nn.Sequential

作用就是把层次给串联起来,形成一个模型

python 复制代码
# Example of use Sequential
model = nn.Sequential(
    nn.Conv2d(1, 5, 10),
    nn.ReLU(),
    nn.Conv2d(1, 5, 10),
    nn.ReLU(),
)

# Example of using Sequential with OrderedDict
model1 = nn.Sequential(OrderedDict([
    ('conv1', nn.Conv2d(1, 5, 10)),
    ('relu1':nn.ReLu()),
    ('conv2', nn.Conv2d(20, 64, 5)),
    ('relu2':nn.ReLu())
]))

二、调式visdom

1. vidom 功能简介

visdom 主要应用于我们展示神经网络运行的中间过程,一些中间结果,检测结果的变化过程可视化等等。我们可以将 visdom 理解成一个库:

  • 支持数值、文本、视频等可视化。
  • 支持 pyotorch、torch、numpy

图1 例举了数据可视化的一些图表,通过这些可视化的图表,我们可以更加直观的看出数据的变化规律,看起来就很专业。
图 1 数据可视化

2. visdom 安装

安装:

pip install visdom

启动服务:

python -m visdom.server

visdom 简单编程

python 复制代码
import visdom
import numpy as np
vis = visdom.Visdom()
vis.text("hello,四川兔兔")
vis.image(np.ones((3,10,10)))

具体的实例展示,在搭建神经网络章节,后面会完善这篇文章。

三、tensorboardX 数据可视化工具

这个工具是基于tensorboard,专门用于pytorch的数据可视化:

1.支持 scalar, image, figure, histogram, audio, text, graph等等不同的可视化展示方式

  1. 安装:pip install tensorboardX

最后如果本文有帮助,帮我点击小店吧,浏览下就行,谢谢朋友们。

相关推荐
老纪的技术唠嗑局2 分钟前
AI 时代的数据库进化论 —— 从向量到混合检索
人工智能
Better Bench7 分钟前
【大模型RAG安全基准】安装和使用SafaRAG框架
网络·人工智能·安全·大模型·组件·rag
大千AI助手8 分钟前
差分隐私:机器学习和数据发布中的隐私守护神
人工智能·神经网络·机器学习·dp·隐私保护·差分隐私·大千ai助手
R-G-B10 分钟前
【P27 回归算法及应用实践】有监督的机器学习、分类与回归、一元线性回归、最小二乘法、多元回归与梯度下降、学习率
人工智能·回归·最小二乘法·梯度下降·一元线性回归·有监督的机器学习·分类与回归
程序员小赵同学10 分钟前
Spring AI Alibaba语音合成实战:从零开始实现文本转语音功能
人工智能·spring·语音识别
Dev7z20 分钟前
结合HOG特征与支持向量机(SVM)的车牌字符识别系统
人工智能·分类·数据挖掘
咋吃都不胖lyh26 分钟前
比较两个excel文件的指定列是否一致
爬虫·python·pandas
MaybeAI35 分钟前
Skill 与 Workflow:让自动化更“聪明”的系统架构
人工智能·ai·自动化·workflow·工作流
唯道行40 分钟前
计算机图形学·9 几何学
人工智能·线性代数·计算机视觉·矩阵·几何学·计算机图形学
Antonio91543 分钟前
【图像处理】tiff格式介绍
图像处理·人工智能