news 2026/2/24 19:06:25

hook来获取模型每层的激活值输出

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
hook来获取模型每层的激活值输出

import sys

import os

from pathlib import Path

# 解决 OpenMP 库冲突问题

os.environ['KMP_DUPLICATE_LIB_OK'] = 'TRUE'

# 添加项目根目录到 Python 路径

project_root = Path(__file__).parent.parent

sys.path.insert(0, str(project_root))

import torch

import torch.nn as nn

import matplotlib.pyplot as plt

import torchvision

from models.UNeXt.UNeXt_Stripe_Conv import UNext_Stripe_Conv

# ========== 1. 准备一个存储激活值的字典 ==========

activations = {}

#x1.detach()的意思是:把张量从计算图中"剪断",不再追踪梯度

def get_activation(name):

"""定义hook函数"""

def hook(model, input, output):

activations[name] = output.detach()

return hook

# ========== 2. 给模型的层注册hook ==========

model = UNext_Stripe_Conv(num_classes=1)

model.eval()

# 给所有卷积层注册hook

for name, layer in model.named_modules():

if isinstance(layer, nn.Conv2d):

layer.register_forward_hook(get_activation(name))

# ========== 3. 前向传播,自动捕获激活值 ==========

input_image = torch.randn(1, 3, 224, 224)

with torch.no_grad():

output = model(input_image)

# ========== 4. 可视化任意层 ==========

def visualize_layer(layer_name, num_channels=16):

"""显示某层的前num_channels个通道"""

act = activations[layer_name][0] # [C, H, W]

fig, axes = plt.subplots(4, 4, figsize=(10, 10))

for i, ax in enumerate(axes.flat):

if i < min(num_channels, act.shape[0]):

ax.imshow(act[i].cpu(), cmap='viridis')

ax.set_title(f'Ch {i}')

ax.axis('off')

plt.suptitle(f'{layer_name}')

plt.show()

# 使用

print(f"捕获了 {len(activations)} 层")

first_conv = list(activations.keys())[0]

visualize_layer(first_conv)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/18 10:36:28

3大痛点解析:Flink监控体系为何总是失效?终极解决方案来了!

你是否经历过Flink作业突然卡死却找不到原因&#xff1f;背压监控数据一片空白&#xff1f;检查点频繁失败却无从下手&#xff1f;这些困扰开发者的监控难题&#xff0c;本文将为你一一解决&#xff01;&#x1f680; 【免费下载链接】flink 项目地址: https://gitcode.com/…

作者头像 李华
网站建设 2026/2/23 11:05:36

Latest:macOS应用更新的终极完整指南

Latest&#xff1a;macOS应用更新的终极完整指南 【免费下载链接】Latest A small utility app for macOS that makes sure you know about all the latest updates to the apps you use. 项目地址: https://gitcode.com/gh_mirrors/la/Latest Latest 是一款专为 macOS …

作者头像 李华
网站建设 2026/2/17 8:00:57

多语言代码质量检测神器:fuck-u-code的国际化实践解析

在全球化协作日益普及的软件开发环境中&#xff0c;代码质量工具的国际化支持已成为提升开发效率的关键要素。GitHub精选项目"fuck-u-code"作为一款基于Go语言构建的代码质量检测器&#xff0c;不仅能够精准评估代码的"屎山等级"&#xff0c;更通过完善的国…

作者头像 李华
网站建设 2026/2/18 14:54:16

终极伺服系统设计指南:5步快速掌握电机控制核心技术

终极伺服系统设计指南&#xff1a;5步快速掌握电机控制核心技术 【免费下载链接】伺服系统设计指导PDF资源说明分享 《伺服系统设计指导》是一本专门针对电机运动控制领域的参考书籍。本书深入浅出地介绍了伺服系统的设计精髓&#xff0c;涵盖了从基础理论到实际应用的广泛知识…

作者头像 李华
网站建设 2026/2/16 23:14:53

5步快速上手GPT-2 XL:从零开始的AI写作实战指南

5步快速上手GPT-2 XL&#xff1a;从零开始的AI写作实战指南 【免费下载链接】gpt2-xl 项目地址: https://ai.gitcode.com/hf_mirrors/ai-gitcode/gpt2-xl 还在为复杂的AI模型部署而头疼吗&#xff1f;&#x1f914; 想要快速掌握强大的文本生成能力却不知从何入手&…

作者头像 李华
网站建设 2026/2/22 10:25:54

windows不会自更新时应怎样处理?

当Windows自动更新功能失效时&#xff0c;这是一个需要认真对待的问题。系统无法获取安全补丁&#xff0c;会带来严重的安全风险。请按照以下从易到难、逐步排查的流程来解决问题。 第一步&#xff1a;基础检查与快速修复检查网络与时间 网络&#xff1a;确保网络连接正常&…

作者头像 李华