python 利用pyplot画训练结果的loss图

从txt文件(比如训练中保存的日志)中读取 loss 数值
可以同时绘制多张子图,一张子图中可以同时绘制 train 和 test 的 loss 曲线,借鉴以下链接中的代码:

https://www.cnblogs.com/marszhw/p/10962903.html

在上述链接的基础上,按照所需做了部分改动

# coding:utf-8
import matplotlib.pyplot as plt

data_dir = "log.txt"
D_Loss_list = []
# Train_Accuracy_list = []
G_Loss_list = []
# Valid_Accuracy_list = []
f1 = open(data_dir, 'r')
data = []
# 把训练结果输出到result.txt里,比较笨的办法,按字节位数去取数字结果
for line in f1:
    if (line.find('Loss_D') >= 0):
        D_Loss_list.append(line.split()[1])
        # Train_Accuracy_list.append(line[24:30])
    if (line.find('Loss_G') >= 0):
        G_Loss_list.append(line.split()[3])
        # Valid_Accuracy_list.append(line[24:30])
f1.close()
# 迭代了30次,所以x的取值范围为(0,30),然后再将每次相对应的准确率以及损失率附在x上
x1 = range(0, 7)
x2 = range(0, 7)
# y1 = Train_Accuracy_list
y2 = D_Loss_list
# y3 = Valid_Accuracy_list
y4 = G_Loss_list
plt.subplot(3, 1, 1)
# plt.plot(x1, y1, 'o-',color='r')
# plt.plot(x1, y1, 'o-', label="Train_Accuracy")
# plt.plot(x1, y3, 'o-', label="Valid_Accuracy")
plt.plot(x1, y2, '.-', label="Loss_D")
# plt.title('D loss vs. epoches')
plt.ylabel('D Loss')
plt.legend(loc='best')
plt.subplot(3, 1, 2)

plt.plot(x1, y4, '.-', label="Loss_G",color='r')
# plt.title('G loss vs. epoches')
plt.ylabel('G Loss')
plt.legend(loc='best')
plt.subplot(3, 1, 3)
plt.plot(x2, y2, '.-', label="Loss_D")
plt.plot(x2, y4, '.-', label="Loss_G",color='r')
plt.xlabel('D&G loss vs. epoches')
plt.ylabel('Train Loss')
plt.legend(loc='best')
## 调整每个子图间的间距,hspace调整上下间距,wspace调整左右间距
plt.subplots_adjust(left=None, bottom=None, right=None, top=None, wspace=None, hspace=0.5)
plt.show()
在编写训练过程中损失(Loss)曲线的代码时,我们需要跟踪训练过程中的损失值,并将其可视化。这里有一个基本的Python代码示例,使用了TensorFlow和Keras库,假设我们正在训练一个模型: ```python import tensorflow as tf from tensorflow.keras.models import Sequential from tensorflow.keras.layers import Dense import matplotlib.pyplot as plt # 定义简单线性回归模型 model = Sequential([ Dense(units=1, input_shape=[1]) ]) # 设置优化器和损失函数 optimizer = tf.keras.optimizers.SGD(learning_rate=0.01) loss_fn = tf.keras.losses.MeanSquaredError() # 假设我们有个生成随机数据的函数data_generator,用于模拟训练集 def generate_data(num_samples): # 这里只是示例,你需要替换为真实的数据生成逻辑 x_train = np.random.rand(num_samples, 1) y_train = 2 * x_train + 1 + np.random.randn(num_samples, 1) return x_train, y_train # 准备数据 x_train, y_train = generate_data(1000) # 训练循环 history = model.fit(x_train, y_train, epochs=100, verbose=0, callbacks=[tf.keras.callbacks.TensorBoard(log_dir="logs")]) # 使用TensorBoard记录训练信息 # 获取训练历史 loss_history = history.history["loss"] # 绘制损失曲线 plt.figure(figsize=(8, 6)) plt.plot(range(1, len(loss_history) + 1), loss_history, label="Training Loss") plt.title("Loss Curve During Training") plt.xlabel("Epochs") plt.ylabel("Mean Squared Error (MSE)") plt.grid(True) plt.legend() plt.show() # 或者可以保存为plt.savefig("training_loss_curve.png") ``` 在这个例中,我们首先定义了一个简单的线性回归模型,然后在训练过程中收集每个epoch的损失值,并利用`TensorBoard`回调来记录。最后,我们绘制了损失随时间变化的趋势。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值