import matplotlib as mpl
mpl.use('Agg')
mpl.rcParams.update({'font.size': 22})
import matplotlib.pyplot as plt
import cv2
import numpy as np
import os
import seaborn as sns
import pandas as pd


def main():
    ns = [100, 1000, 10000]
    noises = [1.0, 2.0, 3.0, 4.0, 5.0]
    data = []
    for n in ns:
        for noise in noises:
            if n == 10000:
                path = f'result/HSP90NoRot_{noise}_{n}'
            else:
                path = f'result_reb/HSP90NoRot_{noise}_{n}'
            pvis = []
            for seed in [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]:
                pvi_file = os.path.join(path,f'PVI_{seed}_32/eval')
                if os.path.exists(pvi_file):
                    with open(pvi_file, 'r') as f:
                        nums = f.readline().split()
                        pvis.append(float(nums[1]))

            for pvi in pvis:
                data.append({'SNR':3.25/noise/noise, 'K':pvi, 'n':str(n)})




    data = pd.DataFrame(data)
    sns.lineplot(data=data, x='SNR',y='K', hue='n', err_style='bars',  err_kws={'capsize':5},)
    plt.ylim([0, 0.5])
    plt.tight_layout()
    plt.savefig(f'figure2/cryoem_SNR.pdf')
    plt.clf()



if __name__ == '__main__':
    main()