import matplotlib.pyplot as plt
import numpy as np

# 两组数据
data1 = {
    'cls_convs': [0.04649607092142105, 0.020322993397712708, 0.008721046149730682, 0.008954660966992378, 0.018576359376311302],
    'reg_convs': [0.04649607092142105, 0.012866930104792118, 0.002119510667398572, 0.0005606033955700696, 0.0003571003908291459],
    'retina_cls': [0.018576359376311302],
    'retina_reg': [0.0003571003908291459]
}

data2 = {
    'cls_convs': [0.032804738730192184, 0.01189128402620554, 0.0027747610583901405, 0.001209637033753097, 0.0016455778386443853],
    'reg_convs': [0.032804738730192184, 0.009170453995466232, 0.0015234636375680566, 0.0003482970641925931, 0.00015199284825939685],
    'retina_cls': [0.0016455778386443853],
    'retina_reg': [0.00015199284825939685]
}

# 计算每个数据点是上一个数据点的加和
def cumulative_sum(data):
    return np.cumsum(data)

# 计算累加和
data1_cumsum = {
    'cls_convs': cumulative_sum(data1['cls_convs']),
    'reg_convs': cumulative_sum(data1['reg_convs']),
}

data2_cumsum = {
    'cls_convs': cumulative_sum(data2['cls_convs']),
    'reg_convs': cumulative_sum(data2['reg_convs']),
}

# 横坐标
x_labels = ['conv_0', 'conv_1', 'conv_2', 'conv_3', 'output']

# 创建子图（普通比例尺）
fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(14, 6))

# 绘制第一组数据的累加和（普通比例尺）
ax1.plot(x_labels, data1_cumsum['cls_convs'], marker='o', label='cls_convs')
ax1.plot(x_labels, data1_cumsum['reg_convs'], marker='o', label='reg_convs')
ax1.set_title('Dataset 1 Cumulative Sum')
ax1.set_xlabel('Convs')
ax1.set_ylabel('Cumulative Values')
ax1.legend()

# 绘制第二组数据的累加和（普通比例尺）
ax2.plot(x_labels, data2_cumsum['cls_convs'], marker='o', label='cls_convs')
ax2.plot(x_labels, data2_cumsum['reg_convs'], marker='o', label='reg_convs')
ax2.set_title('Dataset 2 Cumulative Sum')
ax2.set_xlabel('Convs')
ax2.set_ylabel('Cumulative Values')
ax2.legend()

# 设置两个子图的坐标轴刻度相同
ax1.set_ylim(0, 0.1)
ax2.set_ylim(0, 0.1)

plt.show()


plt.savefig(
    'y_function_vis/tmp5.jpg')