Caffe读取训练和测试日志

2023-12-25 14:18

本文主要是介绍Caffe读取训练和测试日志,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用Caffe训练模型时,我们常常想保存训练和测试过程中数据一便于进一步分析。一种方法是在python中调用caffe的API训练并自己写代码读取layer中的数据保存结果,但这种方法毕竟比较繁琐。其实在用命令行训练的时候,caffe已经提供了保存训练日志并解析训练和测试数据的功能。只要在训练的命令上加一行命令即可。如下:

#!/usr/bin/env sh
set -e
CAFFEROOT=/home/meringue/Softwares/caffe-master
CIFAR10PY=/home/meringue/Documents/CaffePy/cifar10py
MODEL=$CIFAR10PY/cifar10_caffemodels/model_Alex_ST
TOOLS=$CAFFEROOT/build/tools
echo 'start training...'GLOG_logtostderr=0 GLOG_log_dir=$MODEL/LOG/ \ # save log file
$TOOLS/caffe train \--solver=$MODEL/cifar10_quick_solver.prototxt $@ 

这样就会在GLOG__log_dir路径下生成一份日志文件,打开看一下,里面其实就是你在执行训练脚本时生成的一大堆东西。但我们需要的是里面准确率和误差等有用的信息,这时候需要用到caffe-master/tools/extra/路径下的extract_seconds.py,parse_log.sh和plot_training_log.py三个文件,把这三个文件复制一份到你自己定义的LOG文件夹下,先把之前的LOG日志重命名成以.log后缀的文件,如model.log,在当前文件夹下用parse_log.sh model.log命令可以解析出model.log.train和model.log.test两个文件,打开可以看到类似下图的内容:


log.train_test

可以发现,我们需要的数据已经被解析出来了,这个时候可以用这些数据来画图了。当然Caffe也提供了画图功能,用的就是plot_training_log.py,可以设置不同的参数来画你所需要的图,这力里就不再展开了,因为代码里关于参数的说明写的很详细,自己看看就懂了。
其实,既然已经有了这些数据,我们完全可以自己写一个python函数来读取这些数据并画图,下面是我自己写的函数,可以用来读取上面两个日志文件中数据,代码中一些细节都加了注释。

## read log file of training process created by Caffe
class ReadLogFile(object):def __init__(self,_LogFilePath):"""get log file path from LogFilePath"""self.LogFilePath = _LogFilePathdef read_trainLog(self,LogName):"""get iterations and training loss from training log file named LogName"""LogPath = self.LogFilePath+LogName# load all training datawith open(LogPath) as f:data = f.readlines()data = data[1:] # remove the first row (title) data_len = len(data)Iters = []TrainLoss = []for row in range(data_len):data_row = data[row].split(' ') # splitted by ' 'while '' in data_row: # remove 'None'data_row.remove('')Iters.append(int(data_row[0]))TrainLoss.append(float(data_row[2]))           return Iters, TrainLoss    def read_testLog(self,LogName):"""get iterations, test accuracy and test loss from test log file named LogName"""LogPath = self.LogFilePath+LogNamewith open(LogPath) as f:data = f.readlines()data = data[1:]data_len = len(data)Iters = []TestAccuracy = []TestLoss = []for row in range(data_len):data_row = data[row].split(' ')while '' in data_row:data_row.remove('')Iters.append(int(data_row[0]))TestAccuracy.append(float(data_row[2]))TestLoss.append(float(data_row[3]))     return Iters, TestAccuracy, TestLoss

这篇关于Caffe读取训练和测试日志的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/535810

相关文章

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Spring Boot读取配置文件的五种方式小结

《SpringBoot读取配置文件的五种方式小结》SpringBoot提供了灵活多样的方式来读取配置文件,这篇文章为大家介绍了5种常见的读取方式,文中的示例代码简洁易懂,大家可以根据自己的需要进... 目录1. 配置文件位置与加载顺序2. 读取配置文件的方式汇总方式一:使用 @Value 注解读取配置方式二