PyTorch深度学习入门笔记(七)Pooling layers可视化层 非线性激活 线性层

Pooling layers可视化层

相当于1080P—>720P
在这里插入图片描述
在这里插入图片描述

Dilation空洞卷积
在这里插入图片描述
ceil_mode默认是false

在这里插入图片描述
此时池化核(3 * 3)步长为3

测试代码

# Kyrie Irving
# !/9462...
import torch
import torchvision
from torch import nn
from torch.nn import MaxPool2d
from torch.utils.data import DataLoader
from torch.utils.tensorboard import SummaryWriter

from src.nn_conv2d import net

dataset = torchvision.datasets.CIFAR10("../dataset", train=False, transform=torchvision.transforms.ToTensor(), download=True)

dataLoader = DataLoader(dataset, batch_size=64)

input = torch.tensor([
    [1, 2, 0, 3, 1],
    [0, 1, 2, 3, 1],
    [1, 2, 1, 0, 0],
    [5, 2, 3, 1, 1],
    [2, 1, 0, 1, 1]
], dtype=torch.float32)
# -1自己torch计算该值 1个通道 5 * 5
input = torch.reshape(input, (-1, 1, 5, 5))
print(input.shape) # torch.Size([1, 1, 5, 5])

class Tudui(nn.Module):
    def __init__(self):
        super().__init__()
        self.maxPool1 = MaxPool2d(kernel_size=3, ceil_mode=True) # Cell

    def forward(self, input):
        output = self.maxPool1(input)
        return output

tudui = Tudui()
output = tudui(input)
print(output) # tensor([[[[2., 3.], [5., 1.]]]])

输出

Files already downloaded and verified
Net(
  (conv1): Conv2d(3, 6, kernel_size=(3, 3), stride=(1, 1))
)
Files already downloaded and verified
torch.Size([1, 1, 5, 5])
tensor([[[[2., 3.],
          [5., 1.]]]])

写入图片测试

# Kyrie Irving
# !/9462...
import torch
import torchvision
from torch import nn
from torch.nn import MaxPool2d
from torch.utils.data import DataLoader
from torch.utils.tensorboard import SummaryWriter

dataset = torchvision.datasets.CIFAR10("../dataset", train=False, transform=torchvision.transforms.ToTensor(), download=True)

dataLoader = DataLoader(dataset, batch_size=64)

# input = torch.tensor([
#     [1, 2, 0, 3, 1],
#     [0, 1, 2, 3, 1],
#     [1, 2, 1, 0, 0],
#     [5, 2, 3, 1, 1],
#     [2, 1, 0, 1, 1]
# ], dtype=torch.float32)
# # -1自己torch计算该值 1个通道 5 * 5
# input = torch.reshape(input, (-1, 1, 5, 5))
# print(input.shape) # torch.Size([1, 1, 5, 5])

class Tudui(nn.Module):
    def __init__(self):
        super().__init__()
        self.maxPool1 = MaxPool2d(kernel_size=3, ceil_mode=True) # Cell

    def forward(self, input):
        output = self.maxPool1(input)
        return output

tudui = Tudui()
# output = tudui(input)
# print(output) # tensor([[[[2., 3.], [5., 1.]]]])

writer = SummaryWriter("../logs")
step = 0
for data in dataLoader:
    imgs, targets = data
    writer.add_images("input", imgs, step)
    # (-1, 3, 30, 30) batch-size不知道多少时候弄成-1 会根据后边的值进行计算 通道改为3 不然会报错
    output = tudui(imgs)
    writer.add_images("output", output, step)
    step = step + 1

writer.close()

(pytorch) E:\CodeCodeCodeCode\AI\Pytorch-study>tensorboard --logdir="logs/"
TensorFlow installation not found - running with reduced feature set.
Serving TensorBoard on localhost; to expose to the network, use a proxy or pass --bind_all
TensorBoard 2.7.0 at http://localhost:6006/ (Press CTRL+C to quit)

输出

在这里插入图片描述

在这里插入图片描述

非线性激活

inplace是否在原位进行操作
在这里插入图片描述

# Kyrie Irving
# !/9462...
import torch
import torchvision
from torch import nn
from torch.nn import ReLU, Sigmoid
from torch.utils.data import DataLoader
from torch.utils.tensorboard import SummaryWriter

from src.nn_conv2d import dataLoader

input = torch.tensor([
    [1, -0.5],
    [-1, 3]
])
input = torch.reshape(input, (-1, 1, 2, 2))
print(input.shape) # torch.Size([1, 1, 2, 2])

class Tudui(nn.Module):
    def __init__(self):
        super().__init__()
        self.relu1 = ReLU() # 大于0使用input, 小于0用0
        self.sigmoid1 = Sigmoid()

    def forward(self, input):
        output = self.relu1(input)
        return output
tudui = Tudui()
output = tudui(input)
print(output) # tensor([[[[1., 0.], [0., 3.]]]])

dataset = torchvision.datasets.CIFAR10("../dataset", train=False, transform=torchvision.transforms.ToTensor(), download=True)

dataLoader = DataLoader(dataset, batch_size=64)

writer = SummaryWriter("../logs")
step = 0
for data in dataLoader:
    imgs, targets = data
    writer.add_images("input", imgs, global_step=step)
    output = tudui(imgs)
    writer.add_images("output", output, step)
    step += 1

writer.close()

输出

Files already downloaded and verified
Net(
  (conv1): Conv2d(3, 6, kernel_size=(3, 3), stride=(1, 1))
)
torch.Size([1, 1, 2, 2])
tensor([[[[1., 0.],
          [0., 3.]]]])
Files already downloaded and verified

在这里插入图片描述

线性模型

主要改变是在搭建神经网络里边
在这里插入图片描述

全部代码

# Kyrie Irving
# !/9462...
import torch
import torchvision
from torch import nn
from torch.nn import ReLU, Sigmoid, Linear
from torch.utils.data import DataLoader
from torch.utils.tensorboard import SummaryWriter

# 每张图片都转为ToTensor类型
dataset_transform = torchvision.transforms.Compose([
    torchvision.transforms.ToTensor()
])
test_set = torchvision.datasets.CIFAR10(root="../dataset", train=False, transform=dataset_transform, download=True)
test_loader = DataLoader(dataset=test_set, batch_size=64)


class Tudui(nn.Module):
    def __init__(self):
        super().__init__()
        self.linear1 = Linear(196608, 10)

    def forward(self, input):
        output = self.linear1(input)
        return output
tudui = Tudui()


for data in test_loader:
    imgs, targets = data
    # output = torch.reshape(imgs, (1, 1, 1, -1))
    output = torch.flatten(imgs)
    print(output.shape)
    output = tudui(output)
    print(output.shape)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
深度学习是一种机器学习方法,通过构建包含多个中间的神经网络来进行模型训练和预测。深度学习模型的每一都负责从输入数据中提取不同级别的特征表示,这些特征表示也被称为中间。 孪生网络是一种特殊的深度学习模型,它包含两个相同结构的子网络,每个子网络分别处理一对输入数据。通过比较两个子网络的输出,可以进行任务,例如人脸识别中的同一性验证。 在深度学习中,理解中间的表示对于模型的性能和可解释性都非常重要。一种常用的方法是可视化中间的输出,以了解数据在不同次上的表示。这可以通过PyTorch深度学习框架来实现。 使用PyTorch进行深度学习模型的训练时,可以通过在适当的位置插入代码,将中间的输出提取出来并可视化。一种常见的做法是使用PyTorch的钩子(hook)函数来截取中间的输出。钩子函数会在网络前向传播过程中被调用,并将中间的输出保存下来。 通过提取并可视化中间的输出,我们可以观察到数据在不同次上的特征表示。例如,在图像分类任务中,我们可以观察到第一中间可能提取简单的边缘特征,而越靠近输出的中间则可能提取更高级别的语义特征。 可视化中间有助于我们理解网络的工作原理,并可以帮助我们进行模型调优和故障排查。通过观察中间的输出,我们可以发现模型中存在的潜在问题,并根据需要进行调整和改进。 总而言之,深度学习中的中间表示对于模型的性能和解释性至关重要。通过使用PyTorch深度学习框架,我们可以提取并可视化中间的输出,以增进对模型的理解,并改进和优化模型设计。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值