import numpy as np
import json
import os 

image_dir = './nblora/r16_inf1.0_lr6e-4_seed42'
# steps = [200, 400, 600, 800, 1000, 1200, 1400, 1600]
steps = [1400]
print(image_dir)
for step in steps:
    results_path = os.path.join(image_dir, f'metric-{step}.json')
    results_dict = dict()
    if os.path.exists(results_path):
        with open(results_path, 'r') as f:
            results = f.__iter__()
            while True:
                try:
                    result_json = json.loads(next(results))
                    results_dict.update(result_json)
                    
                except StopIteration:
                    print("finish extraction.")
                    break

    dino = np.zeros((1,))
    clip = np.zeros((1,))
    clipt= np.zeros((1,))
    lpips= np.zeros((1,))
    sind = 0

    for key, value in results_dict.items():
        dino += value["DINO"]
        clip += value["CLIP-I"]
        clipt+= value["CLIP-T"]
        lpips+= value["LPIPS"]
        sind += 1

    dino = dino / sind
    clip = clip / sind
    clipt= clipt / sind
    lpips= lpips / sind

    print(f'step: {step:4d} | dino: {dino[0]:.3f}, clip: {clip[0]:.3f}, clipt: {clipt[0]:.3f}, lpips: {lpips[0]:.3f}')

    res = np.array([dino[0], clip[0], clipt[0], lpips[0]])
    np.savetxt(f"{image_dir}/avg_metric_{step}.csv", res, delimiter=',', fmt="%.3f")
