Pytorch:torch.utils.tensorboard.SummaryWriter

SummaryWriter 通常是指在TensorBoard日志记录库中的一个类,这是TensorFlow的一个组件,可以用于记录和展示神经网络训练过程中的各种参数。PyTorch也提供了与TensorBoard兼容的工具torch.utils.tensorboard.SummaryWriter

SummaryWriter 主要用于在训练神经网络时捕获和存储指标,比如损失、精度、模型内部的权重和梯度等。随后,这些数据可以被TensorBoard读取并显示为图形,帮助开发者可视化训练过程,从而更好地理解模型的训练和性能。

以下是一个使用PyTorch中SummaryWriter的基本示例:

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

# 实例化SummaryWriter
writer = SummaryWriter('runs/experiment_1')

for epoch in range(num_epochs):
    # ...
    # 在这里实现模型的训练逻辑
    # ...

    # 记录损失
    writer.add_scalar('Loss/train', loss_value, epoch)

    # 记录模型权重直方图
    for tag, value in model.named_parameters():
        tag = tag.replace('.', '/')
        writer.add_histogram(tag, value.data.cpu().numpy(), epoch)

    # 记录图像
    if epoch % 10 == 0:
        # 假设images是一个批次的图像张量
        writer.add_images('Train/images', images, epoch)

# 训练结束后关闭SummaryWriter
writer.close()

使用这样的代码,你可以在TensorBoard中查看损失和权重直方图的变化,以及每十个epoch保存的图像。

以下是它常用的几个功能:

标量记录(Scalars):

python 复制代码
   # 记录损失
   for epoch in range(num_epochs):
       writer.add_scalar('training_loss', loss_value, epoch)

直方图记录(Histograms):

python 复制代码
# 记录权重分布
   for name, param in model.named_parameters():
       writer.add_histogram(name, param.clone().cpu().data.numpy(), epoch)

图结构(Graphs):

python 复制代码
# 记录模型结构
   inputs = torch.rand(1, 3, 224, 224)  # 随机生成输入张量
   writer.add_graph(model, inputs)

图像记录(Images):

python 复制代码
   # 记录一批图像
   images, labels = next(iter(dataloader))
   writer.add_images('four_fashion_mnist_images', images, epoch)

音频记录(Audio):

python 复制代码
 # 记录一段音频
   audio = torch.randn(1, 44100)  # 随机生成音频数据
   writer.add_audio('my_audio', audio, epoch, sample_rate=44100)

文本记录(Text):

python 复制代码
  # 记录文本信息
   writer.add_text('my_text', 'This is an example of adding text to TensorBoard', epoch)

嵌入记录(Embeddings):

python 复制代码
   # 记录嵌入
   features = torch.randn(100, 256)  # 假设有100个256维的特征向量
   writer.add_embedding(features, metadata=None, label_img=None, global_step=epoch)

超参数调优(HParams):

python 复制代码
# 记录超参数与指标
   hparams = {'lr': 0.1, 'bsize': 1}
   metrics = {'hparam/accuracy': 0.99}

   writer.add_hparams(hparam_dict=hparams, metric_dict=metrics)

PR曲线(Precision-Recall Curves):

python 复制代码
   # 记录PR曲线
   from sklearn.metrics import precision_recall_curve
   y_true = np.array([0, 1, 1, 0, 1])  # 实际标签
   y_scores = np.array([0.1, 0.4, 0.35, 0.8, 0.7])  # 预测得分
   precision, recall, _ = precision_recall_curve(y_true, y_scores)
   writer.add_pr_curve('pr_curve', y_true, y_scores, epoch)

使用上述代码的方式,利用SummaryWriter 的各种方法,可以帮助你记录和可视化模型训练时产生的各种数据。这些数据记录之后可以通过TensorBoard进行查看。

记得在代码中导入必要的模块,并适当调整参数和数据要与你的实际模型训练情况相符。

相关推荐
千匠网络1 小时前
破局出海壁垒,千匠网络新能源汽车跨境出海解决方案
人工智能
方安乐2 小时前
python之向量、向量和、向量点积
开发语言·python·numpy
zh1570233 小时前
JavaScript中WorkerThreads解决服务端计算瓶颈
jvm·数据库·python
马丁聊GEO3 小时前
解码AI用户心智,筑牢可信GEO根基——悠易科技深度参与《中国AI用户态度与行为研究报告(2026)》发布会
人工智能·科技
nap-joker3 小时前
Fusion - Mamba用于跨模态目标检测
人工智能·目标检测·计算机视觉·fusion-mamba·可见光-红外成像融合·远距离/伪目标问题
一只幸运猫.3 小时前
2026Java 后端面试完整版|八股简答 + AI 大模型集成技术(最新趋势)
人工智能·面试·职场和发展
Promise微笑3 小时前
2026年国产替代油介损测试仪:油介损全场景解决方案与技术演进
大数据·网络·人工智能
深海鱼在掘金4 小时前
深入浅出 LangChain —— 第三章:模型抽象层
人工智能·langchain·agent
生信碱移4 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
workflower4 小时前
具身智能行业应用-生活服务业
大数据·人工智能·机器人·动态规划·生活