# -*- coding: utf-8 -*-
"""
Created on Fri Sep  1 22:36:02 2023

@author: xiato
"""


import numpy as np
import matplotlib.pyplot as plt


path = 'logs_all//MobileNet//500//'
plt.figure(dpi=300, figsize=(5,3))
Accs = [] 
for file in [ 'FedAvg_500_IID', 'FedAvg_500_q3']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'GM acc on global data' in line or 'Global Model Acc' in line:
                temp = line.split(':')[1].split(' ')[1]
                acc.append(float(temp)) 
 
        
    
    Accs.append(np.max(acc))
    plt.plot(acc,label=file)
    print(file, np.max(acc))

plt.legend()
plt.xlabel('Round')
plt.ylabel('Acc')
plt.grid()
#plt.ylim([0.1,0.7])
# plt.title('IID data')
#plt.xlim([0, 100])
plt.title(path)
print('===========================================')


path = 'logs_all//MobileNet//100//Quality_3//'
plt.figure(dpi=300, figsize=(5,3))
Accs = [] 
for file in [ 'FedAvg', 'FedNTD',  'FedData', 'FedMix']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'GM acc on global data' in line or 'Global Model Acc' in line:
                temp = line.split(':')[1].split(' ')[1]
                acc.append(float(temp)) 
 
        
    
    Accs.append(np.max(acc))
    plt.plot(acc,label=file)
    print(file, np.max(acc))

plt.legend()
plt.xlabel('Round')
plt.ylabel('Acc')
plt.grid()
#plt.ylim([0.1,0.7])
# plt.title('IID data')
#plt.xlim([0, 100])
plt.title(path)
print('===========================================')



path = 'logs_all//MobileNet//10//'
plt.figure(dpi=300, figsize=(5,3))
Accs = [] 
for file in [ 'FedData_10_IID', 'FedData_10_Q3','FedMix_10_Q3']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'GM acc on global data' in line or 'Global Model Acc' in line:
                temp = line.split(':')[1].split(' ')[1]
                acc.append(float(temp)) 
 
        
    
    Accs.append(np.max(acc))
    plt.plot(acc,label=file)
    print(file, np.max(acc))

plt.legend()
plt.xlabel('Round')
plt.ylabel('Acc')
plt.grid()
#plt.ylim([0.1,0.7])
# plt.title('IID data')
#plt.xlim([0, 100])
plt.title(path)
print('===========================================')
 

 
path = 'logs_all//MobileNet//100//Drichlet_0.5//'
plt.figure(dpi=300, figsize=(5,3))
Accs = [] 
for file in [ 'FedMix_dir0.5', 'FLea_100_dir0.5']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'GM acc on global data' in line or 'Global Model Acc' in line:
                temp = line.split(':')[1].split(' ')[1]
                acc.append(float(temp)) 
 
        
    
    Accs.append(np.max(acc))
    plt.plot(acc,label=file)
    print(file, np.max(acc))

plt.legend()
plt.xlabel('Round')
plt.ylabel('Acc')
plt.grid()
#plt.ylim([0.1,0.7])
# plt.title('IID data')
#plt.xlim([0, 100])
plt.title(path)
print('===========================================')

path = 'logs_all//MobileNet//100//Drichlet_0.1//'
plt.figure(dpi=300, figsize=(5,3))
Accs = [] 
for file in [ 'FedMix_dir0.1', 'FLea_100_dir0.1']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'GM acc on global data' in line or 'Global Model Acc' in line:
                temp = line.split(':')[1].split(' ')[1]
                acc.append(float(temp)) 
 
        
    
    Accs.append(np.max(acc))
    plt.plot(acc,label=file)
    print(file, np.max(acc))

plt.legend()
plt.xlabel('Round')
plt.ylabel('Acc')
plt.grid()
#plt.ylim([0.1,0.7])
# plt.title('IID data')
#plt.xlim([0, 100])
plt.title(path)
print('===========================================')