【pytorch可视化工具】

TensorboardX

在PyTorch中,模型训练的可视化通常通过TensorBoard或Visdom等工具实现。以下是如何使用TensorBoard进行模型训练可视化的步骤:

使用TensorboardX与PyTorch配合

确保已经安装了tensorboardtensorboardX库。

bash 复制代码
pip install tensorboard
pip install tensorboardX

在训练过程中记录损失、准确率等指标:

python 复制代码
from torch.utils.tensorboard import SummaryWriter
import torch.nn as nn

# 假设你已经有了模型、优化器、损失函数以及数据加载器
model = ...  # 你的模型实例
criterion = nn.CrossEntropyLoss()  # 或者其他适合的损失函数
optimizer = torch.optim.Adam(model.parameters())
dataloader = DataLoader(...)  # 你的数据加载器

# 创建一个SummaryWriter对象来写入日志文件
writer = SummaryWriter()

num_epochs = 100
for epoch in range(num_epochs):
    for inputs, targets in dataloader:
        optimizer.zero_grad()
    
        outputs = model(inputs)
        loss = criterion(outputs, targets)

        loss.backward()
        optimizer.step()

        # 记录每批次的损失到TensorBoard
        writer.add_scalar('Training Loss', loss.item(), epoch * len(dataloader) + len(inputs))

    # 在每个epoch结束时记录其他评估指标(例如验证集上的精度)
    with torch.no_grad():
        val_loss = validate_your_model(model, validation_loader)
        writer.add_scalar('Validation Loss', val_loss, epoch)

# 在所有训练完成后关闭writer
writer.close()

# 然后运行tensorboard服务并打开可视化界面
%tensorboard --logdir=runs  # Jupyter notebook内
# 或在终端执行
tensorboard --logdir=runs

计算模型参数量和浮点数:

python 复制代码
def count_parameters(model):
    return sum(p.numel() for p in model.parameters() if p.requires_grad)

total_params = count_parameters(model)
print(f"Total trainable parameters: {total_params}")

评价指标通常根据任务类型有所不同,例如分类任务中的精度、召回率、F1分数等,回归任务中的均方误差(MSE)、平均绝对误差(MAE)等。可以将这些指标也记录到TensorBoard中,就像记录损失那样。

例如,对于分类任务,假设有预测输出和真实标签:

python 复制代码
from sklearn.metrics import accuracy_score

# 验证集上的预测
predictions = torch.argmax(model(val_inputs), dim=1)
true_labels = val_targets

accuracy = accuracy_score(true_labels.cpu().numpy(), predictions.cpu().numpy())
writer.add_scalar('Validation Accuracy', accuracy, epoch

Visdom

这是一个Web-based实时数据可视化工具,可以与PyTorch一起使用来监控训练过程。下面是使用Visdom的基本代码示例:

python 复制代码
import visdom
vis = visdom.Visdom()

# 记录损失值
vis.line(Y=[loss], X=[epoch], win='Loss', update='append')

# 显示图像等其他类型的数据也类似,需要根据Visdom API操作
  1. 对于模型参数量的计算,可以通过torch.nn.Module的子类实例直接统计:
python 复制代码
import torch
from your_model_module import YourModelClass

model = YourModelClass()
total_params = sum(p.numel() for p in model.parameters())
print(f"Total number of parameters: {total_params}")
  1. 浮点数计算通常指的是模型占用的内存大小,可以通过下面的方式来估算(单位为MB):
python 复制代码
param_size = sum(torch.prod(torch.tensor(p.size())) * p.element_size() for p in model.parameters())
print(f"Estimated memory usage: {param_size / (1024 ** 2):.2f} MB")
相关推荐
chatexcel9 分钟前
AI PPT 教程:基于旅游生活场景的提示词设计与生成流程
人工智能·ppt
寻道码路1 小时前
LangChain4j Java AI 应用开发实战(四):提示词工程进阶 - 模板化与结构化 Prompt 设计
java·人工智能·ai·prompt·aigc
Raink老师7 小时前
【AI面试临阵磨枪-70】Agent 系统如何做分布式调度、跨服务协作、故障恢复?
人工智能·面试·职场和发展
lishi_19917 小时前
一键部署MoviePilotV2实现NAS全自动追剧
python·媒体·moviepilot
tedcloud1237 小时前
RTK部署教程:构建稳定的AI Workflow环境
服务器·javascript·人工智能·typescript·ocr
Raink老师7 小时前
【AI面试临阵磨枪-71】如何用 AI 优化推荐系统、内容审核、广告创意、搜索体验?
人工智能·面试·职场和发展
AI医影跨模态组学7 小时前
Biomarker Res(IF=11.5)安徽医科大学第一医院:基于机器学习的放射组学模型:子宫内膜癌患者的预后预测及机制探索
人工智能·深度学习·论文·医学·医学影像·影像组学
ftpeak7 小时前
Mooncake:以 KVCache 为中心的分离式 LLM 服务架构
人工智能·ai·架构·ai编程·ai开发
Terrence Shen7 小时前
Hermes agent的tools是怎么落地应用的系列
人工智能·llm·agent·hermes
Raink老师7 小时前
【AI面试临阵磨枪-72】电商全场景 AI Agent 设计(商品咨询 / 订单 / 物流 / 售后 / 退款)
人工智能·面试·职场和发展