画loss曲线并平滑

import matplotlib.pyplot as plt
from matplotlib.pyplot import MultipleLocator
import json
import numpy as np
data_path_1 = ""
data_path_2 = ""
def read_json(data_path, stage, key_1, key_2):
    i = 0
    iter, loss = [], []
    with open(data_path, 'r') as f:
        content = f.readlines()
        for line in content:
            if json.loads(line)["mode"] == stage:
                i=i+1
                iter.append(i)
                loss.append(json.loads(line)[key_2])
    return iter, loss
iter_1, loss_seg_1 = read_json(data_path_1, "train", "iter", "loss")
np.savetxt('test1.csv', loss_seg_1, delimiter=',')

last1 = loss_seg_1[0]
loss1=loss_seg_1
weight=0.9
for i in range(len(loss_seg_1)):
    smoothed_val1 = last1 * weight + (1 - weight) * loss_seg_1[i]
    loss1[i]=smoothed_val1
    last1= smoothed_val1


iter_2, loss_seg_2 = read_json(data_path_2, "train", "iter", "loss")
np.savetxt('test2.csv', loss_seg_2, delimiter=',')

last2 = loss_seg_2[0]
loss2=loss_seg_2
weight=0.9
for j in range(len(loss_seg_2)):
    smoothed_val2 = last2 * weight + (1 - weight) * loss_seg_2[j]
    loss2[j]=smoothed_val2
    last2 = smoothed_val2

#设置横纵坐标的名称以及对应字体格式
font = {'family' : 'Times New Roman',
'weight' : 'normal',
'size' : 10,
}
index = 0
fig = plt.figure()
ax = fig.add_subplot(1, 1, 1)
plt.xlim(0, 1000)
ax.set_xlabel('iteration', font)
ax.set_ylabel('loss %', font)
ax.set_title('Seg Loss',size=10)
ax.plot(iter_1[index:], loss1[index:], label = "model_1")
ax.plot(iter_2[index:], loss2[index:], label = "model_2")
#ax.scatter(iter_1[index:], loss_seg_1[index:], marker='.', color='black', s=8)
#ax.scatter(iter_2[index:], loss_seg_2[index:], marker='.', color='red', s=8)
plt.legend(loc='upper right')
plt.show()

平滑后

插入链平滑前

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值