import matplotlib.pyplot as plt
import json
from utils import moving_average, increase_line

colors = ['deepskyblue', 'forestgreen', 
        #   'PeachPuff', 'slateblue', 'darkgoldenrod', 
          'tomato']

leg = ['DAPO-E2H', 
    #    'DAPO-E2H:0.25', 'DAPO-E2H:0.50', 'DAPO-E2H:0.75', 
       'DAPO-H2E', 'DAPO-HAMMER']

leg2 = {
    'DAPO-E2H': 'DAPO-E2H:1.00',
    'DAPO-H2E': 'DAPO-E2H:0.25',
    'DAPO-HAMMER': 'DAPO-HAMMER',
}

# window_sizes = [15, 10, 20, 20]  # Adjust window size for each dataset
window_size = 15
offset = (window_size - 1) // 2

linewidth = 0.5
alpha = 0.3
fontsize = 16

handles = []


# fig, axes = plt.subplots(nrows=1, ncols=4, figsize=(14, 2.5))
fig = plt.figure(figsize=(4, 2.2))

for i, lab in enumerate(leg):
    with open(f'AIME24.json', 'r') as f:
        results = json.load(f)
        data = results[leg2[lab]]


    smoothed_y = moving_average(data['y'], window_size)
    smoothed_x = data['x'][offset : -offset][:len(smoothed_y)]

    inc_x, inc_y = increase_line(data['x'][:offset], data['y'][:offset], smoothed_y[0])

    smoothed_x = inc_x + smoothed_x
    smoothed_y = inc_y + smoothed_y

    plt.plot(data['x'], data['y'], color=colors[i], alpha=alpha, linewidth=linewidth)
    line, = plt.plot(smoothed_x, smoothed_y, color=colors[i], label=leg[i])

    handles.append(line)

# plt.set_title("", fontsize=fontsize)
plt.xlabel('Steps', fontsize=fontsize)
plt.ylabel("pass@8", fontsize=fontsize)
plt.grid(True)


fig.subplots_adjust(wspace=0.5, hspace=0.2)
fig.legend(handles, leg, loc='center', bbox_to_anchor=(0.51, 1.00), ncol=3, frameon=False, fontsize=10, handletextpad=0.2, columnspacing=0.5)
fig.tight_layout()
fig.savefig('qwen3-1.7b-dapo-E2H.png', dpi=300, bbox_inches='tight')