import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import copy
log_baseline = pd.read_csv('multi_attack_trained_models/test_1_baseline_none_wave_0_200000_30000_balance_alpha_0.5_50000_index.npy/log.csv').values
log_next2 = pd.read_csv('multi_attack_trained_models/test_baseline_fix3_active_uncertainty_balance_wave_10_0_200000_2000_ndex.npy_None_16/log.csv').values
log_next = pd.read_csv('multi_attack_trained_models/test_retrain_active_uncertainty_balance_wave_10_0_200000_2000_ndex.npy_None_768/log.csv').values
print(len(log_next))
it = 1
log_baseline = log_baseline[:768]
#log_next_it_1 = log_next[it*768:(it+1)*768]
log_next_it_1 = copy.deepcopy(log_next[it*768:it*768+768])
print(len(log_next_it_1))
it = 8
#log_next_it_2 = log_next[it*768:(it+1)*768]
log_next_it_2 = copy.deepcopy(log_next[it*768:it*768+768])
print(len(log_next_it_2))

attack_rank = pd.read_csv('multi_attack_trained_models/test_baseline_random_wave_0_200000_20000_index_50k.npy/attack_rank.csv', index_col=0).to_numpy()
attack_rank_multi = pd.read_csv('multi_attack_trained_models/test_baseline_random_wave_0_200000_20000_index_50k.npy/attack_rank_multi.csv', index_col=0).to_numpy()
attack_rank_multi = np.mean(attack_rank_multi, axis = 1)
'''
loss_baseline = []
for i in range(len(log_baseline)):
    loss_baseline.append(float(log_baseline[i][0].split(';')[2]))

print(loss_baseline[:10])

for i in range(len(log_next)):
    loss_baseline.append(float(log_next[i][0].split(';')[2]))

for i in range(len(log_next)):
    if i < 10:
        print(i)
        print(log_next[i][0].split(';')[2])
'''


loss_baseline_val = []
for i in range(len(log_baseline)):
    loss_baseline_val.append(float(log_baseline[i][0].split(';')[4]))

print(loss_baseline_val[:10])

#loss_baseline_next = loss_baseline
loss_baseline_next_1 = []
for i in range(len(log_next_it_1)):
    loss_baseline_next_1.append(float(log_next_it_1[i][0].split(';')[4]))

loss_baseline_next_2 = []
for i in range(len(log_next_it_2)):
    loss_baseline_next_2.append(float(log_next_it_2[i][0].split(';')[4]))

loss_baseline_2 = []
for i in range(len(log_next2)):
    loss_baseline_2.append(float(log_next2[i][0].split(';')[4]))

print('Statistics:')
print(np.min(loss_baseline_val))
print(np.min(loss_baseline_next_1))
print(np.min(loss_baseline_next_2))


plt.figure(figsize=(10,7))
plt.grid()
plt.ylabel('Loss Value')
plt.xlabel('Training epoch')
#plt.plot(loss_baseline[:len(log_baseline)])
plt.plot(loss_baseline_val, label ='Initial Model')
plt.plot(loss_baseline_next_1, label = 'Iteration 1')
plt.plot(loss_baseline_next_2, c='r', label = 'Iteration 10')
#plt.plot(loss_baseline_next_2, label = 'Update Training')
plt.legend()
plt.savefig('loss_check_iteration.png')
plt.clf()
