如何实现CNN特征层可视化?终于懂了....

本文介绍了如何可视化卷积神经网络(CNN)的特征层,通过建立网络模型、获取中间层输出并构建可视化模型,详细展示了从获取特征图到标准化显示的全过程。
摘要由CSDN通过智能技术生成

程序员宝藏库:https://github.com/Jackpopc/CS-Books-Store

现如今,谈起人工智能,对于大多数人来说已经不再陌生。

而作为其中比较热门的计算机视觉,更是吸引了一大批从业者。

但是,其中绝大多部分都“不知所以然”。搭建起开发环境,照搬一段代码,就认为大功告成,但是,到底数据进入网络中发生了什么?特征是什么样的,很多人都回答不上来。

本文,就来教大家如何如何可视化CNN网络层的特征图。

教程

废话不多说,我们先来建立一个网络模型:

model = tf.keras.models.Sequential([
    
    tf.keras.layers.Conv2D(8,(3,3),激活='relu',input_shape =150,150,3)),
    tf.keras.layers.MaxPooling2D(2,2),
    
    tf.keras.layers.Conv2D(16,(3,3),激活='relu'),
    tf.keras.layers.MaxPooling2D(2,2),
    
    tf.keras.layers.Conv2D(32,(3,3),激活='relu'),
    tf.keras.layers.MaxPooling2D(2,2),
    
    tf.keras.layers.Flatten(),
    
    tf.keras.layers.Dense(1024,activation ='relu'),
    tf.keras.layers.Dense(512,activation ='relu'),
    
    tf.keras.layers.Dense(3,activation ='softmax']

该模型的概括如下:

model.summary()

img

如上所示,我们具有三个卷积层,其后是MaxPooling层,两个全连接层和一个最终输出全连接层。

我们需要训练和拟合模型。因此,首先运行模型,然后才能得到特征图。只不过,在这里不演示这部分过程。

要生成特征图,需要用到model.layersAPI,接下来了解如何访问CNN中间层。

获取CNN网络层的名称

layer_names 
  • 1
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
可以使用PyTorch提供的可视化工具来查看CNN的每一特征。以下是一些实现方法: 1. 使用torchsummary库来可视化模型的结构和参数。 ```python from torchsummary import summary import torch.nn as nn # 定义一个CNN模型 class Net(nn.Module): def __init__(self): super(Net, self).__init__() self.conv1 = nn.Conv2d(in_channels=3, out_channels=64, kernel_size=3, stride=1, padding=1) self.conv2 = nn.Conv2d(in_channels=64, out_channels=128, kernel_size=3, stride=1, padding=1) self.conv3 = nn.Conv2d(in_channels=128, out_channels=256, kernel_size=3, stride=1, padding=1) self.pool = nn.MaxPool2d(kernel_size=2, stride=2) self.fc1 = nn.Linear(256 * 4 * 4, 1024) self.fc2 = nn.Linear(1024, 10) def forward(self, x): x = self.pool(F.relu(self.conv1(x))) x = self.pool(F.relu(self.conv2(x))) x = self.pool(F.relu(self.conv3(x))) x = x.view(-1, 256 * 4 * 4) x = F.relu(self.fc1(x)) x = self.fc2(x) return x # 输出模型的结构和参数 model = Net() print(summary(model, (3, 32, 32))) ``` 2. 使用hook函数来获取每一特征,并将其可视化。 ```python import matplotlib.pyplot as plt import numpy as np # 定义hook函数 def get_activation(name): def hook(model, input, output): activation[name] = output.detach() return hook # 注册hook函数 model.conv1.register_forward_hook(get_activation('conv1')) model.conv2.register_forward_hook(get_activation('conv2')) model.conv3.register_forward_hook(get_activation('conv3')) # 加载一张图片 image = np.array(Image.open('image.jpg').resize((32, 32))) # 转换图片维度 image_tensor = torch.from_numpy(image).permute(2, 0, 1).unsqueeze(0).float() # 对图片进行预测 model.eval() with torch.no_grad(): output = model(image_tensor) # 可视化每一特征 for i in range(3): plt.figure() plt.imshow(activation['conv{}'.format(i+1)][0][0].cpu(), cmap='gray') plt.axis('off') ``` 以上两种方法都可以帮助我们可视化CNN的每一特征,方便我们观察模型的学习情况。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值