首页 > 其他分享 >搭建小实战和Sequential的使用

搭建小实战和Sequential的使用

时间:2023-08-20 09:11:32浏览次数:37  
标签:实战 nn 32 self torch Sequential 64 搭建

搭建小实战和Sequential的使用

模型搭建

以CIFAR 10 model结构为例搭建网络

CIFAR 10 model结构

torch.nn.Flatten是PyTorch中的一个模块,用于将多维的输入张量转换为一维的输出张量。它可以被用作神经网络模型中的一层,用于将输入张量展平后作为全连接层的输入。比如输入张量的形状是 [10, 3, 32, 32],即批大小为 10,通道数为 3,高度和宽度分别为 32。经过 nn.Flatten 模块处理后,输出张量的形状变为 [10, 3072],即批大小为 10,一维展开后的长度为 3072(3 * 32 * 32)。

卷积层中的stridepadding是由卷积的输入输出计算公式得到(dilation默认为1)

import torch
from torch import nn
from torch.nn import Conv2d, MaxPool2d, Flatten, Linear, Sequential


class Baseseq(nn.Module):
    def __init__(self):
        super(Baseseq, self).__init__()
        # 根据卷积的输入输出公式计算padding和stride
        self.conv1 = Conv2d(in_channels=3, out_channels=32, kernel_size=5, stride=1, padding=2)
        self.maxpool1 = MaxPool2d(kernel_size=2)
        self.conv2 = Conv2d(in_channels=32, out_channels=32, kernel_size=5, stride=1, padding=2)
        self.maxpool2 = MaxPool2d(kernel_size=2)
        self.conv3 = Conv2d(in_channels=32, out_channels=64, kernel_size=5, padding=2)
        self.maxpool3 = MaxPool2d(kernel_size=2)
        # 与torch.flatten的作用相同
        self.flatten = Flatten()
        # 展平后为64*4*4=1024,当不知道时可以先返回flatten之后的结果查看展平大小
        self.linear1 = Linear(1024, 64)
        self.linear2 = Linear(64, 10)

    def forward(self, x):
        x = self.conv1(x)
        x = self.maxpool1(x)
        x = self.conv2(x)
        x = self.maxpool2(x)
        x = self.conv3(x)
        x = self.maxpool3(x)
        x = self.flatten(x)
        x = self.linear1(x)
        x = self.linear2(x)
        return x

baseseq = Baseseq()
print(baseseq)

# 对搭建的网络进行验证
input = torch.ones((64, 3, 32, 32))
output = baseseq(input)
print(output.shape)

Sequential

Sequential是一个时序容器。Modules 会以他们传入的顺序被添加到容器中。包含在PyTorch官网中torch.nn模块中的Containers中,在神经网络搭建的过程中如果使用Sequential,代码更简洁。使用Sequential搭建上述模型,并借助Tensorboard显示计算图的详细信息。

import torch
from torch import nn
from torch.nn import Conv2d, MaxPool2d, Flatten, Linear, Sequential
from torch.utils.tensorboard import SummaryWriter


class Baseseq(nn.Module):
    def __init__(self):
        super(Baseseq, self).__init__()
        self.model1 = Sequential(
            Conv2d(in_channels=3, out_channels=32, kernel_size=5, stride=1, padding=2),
            MaxPool2d(kernel_size=2),
            Conv2d(32, 32, 5, padding=2),
            MaxPool2d(2),
            Conv2d(32, 64, 5, padding=2),
            MaxPool2d(2),
            Flatten(),
            Linear(1024, 64),
            Linear(64, 10)
        )

    def forward(self, x):
        x = self.model1(x)
        return x

baseseq = Baseseq()
print(baseseq)

# 对搭建的网络进行验证
input = torch.ones((64, 3, 32, 32))
output = baseseq(input)
print(output.shape)

writer = SummaryWriter("logs")
writer.add_graph(baseseq, input)
writer.close()

得到的结果和上面的结果相同,同时还为每一步添加了序号

TensorBoard得到的计算图:

对于每一个部分双击可以看到详细的信息:

标签:实战,nn,32,self,torch,Sequential,64,搭建
From: https://www.cnblogs.com/yq-ydky/p/17632474.html

相关文章

  • erlang实战手册(1)
    目录变量atom逻辑运算变量变量大写开头,但实际是不能改变,只能赋值一次。X=11.112>Y=X.113>Y.114>Yxxx=Y.115>Yxxx5>.116>Yxxx=44.**exceptionerror:nomatchofrighthandsidevalue44atom原子,可理解为常量。7>A=a1.a18>B=a2.a29>A.a110>......
  • abp-vnext-pro 实战(八,聚合根的写法,客户M:N地址)
    参考数据字典模块的写法///<summary>///地址///</summary>publicclassAddress:FullAuditedAggregateRoot<Guid>,IMultiTenant{publicGuid?TenantId{get;protectedset;}///<summary>///公司名///</summary>p......
  • spark环境搭建
    我们在上一篇文章中搭建了相关的Hadoop,现在我们来搭建spark环境Hadoop搭建[https://www.cnblogs.com/xiaozhounandu/p/14166282.html]前言(注意,spark和Scala环境及配置文件必须每个节点都必须要有!!!)Spark必须在Hadoop集群上,它的数据来源是HDFS,本质上是Yarn上的一个计算框架,像M......
  • Kafka+Fink 实战+工具类
    LogServiceImpl@Service@Slf4jpublicclassLogServiceImplimplementsLogService{privatestaticfinalStringTOPIC_NAME="ods_link_visit_topic";@AutowiredprivateKafkaTemplatekafkaTemplate;/***记录日志**......
  • 一线大厂性能优化实战解析,看到就是赚到
    前言我们平时在使用软件的过程中是不是遇到过这样的情况:"这个app怎么还没下载完!"、太卡了吧!"、"图片怎么还没加载出来!"、"怎么刚进去就卡了!"、"这怎么点了一下就退出了!"等等,这些情况其实包含了我们性能优化的主要内容.,性能的优化是一个老生常谈的点,也是一个比较重要的点.特......
  • 禾匠小程序商城搭建教程
    1、演示环境配置服务器2核2G+centos7.9+php7.2+mysql5.7.40+redis6.2.7+baota8.0.12、创建网站保存好创建的数据库信息3、上传后台上传完毕以后,解压4、配置站点网站目录选择创建好的站点即可,不需要点击到站点目录里面5、配置数据库信息打开config/db.exam......
  • 【web_逆向09】AES加密逆向实战
    目标网站话不多说,直接干:https://www.XXXX.com/rank_m/c7/,可以联系本人微信号:wxid_ps0bm4kbsl0t22寻找加密入口查看接口数据,发现入参、出参都是经过加密的,需要加密、解密查看Initiator中,发现promise。异步通过interceptors搜索,往回找不一定能找到,可以考虑正向搜索注......
  • 利用text-generation-webui快速搭建chatGLM2-6b/LLAMA2-7B-chat大模型运行环境
    text-generation-webui 是一个基于Gradio的LLMWebUI开源项目,可以利用其快速搭建各种文本生成的大模型环境。一、安装text-generation-webui的readme其实已写得相当详细了,这里就不再重复,只说1个可能存在的坑:安装peft安装卡住requirements.txt中有一些依赖项,需要访问gith......
  • 【22.0】课程页面搭建
    【一】原型图【二】前端页面搭建【1】免费课页面<template><divclass="course"><Header></Header><divclass="main"><!--筛选条件--><divclass="condition"><ulclass="c......
  • 【23.0】搜索功能搭建
    【一】搜索功能后端luffyCity\luffyCity\apps\course\views.py#搜索---查询所有+过滤classSearchCourseView(GenericViewSet,ListModelMixin):serializer_class=CourseSerializerqueryset=Course.objects.filter(is_delete=False,is_show=True).order_......