# -*- coding: utf-8 -*-
"""
Created on Sun Sep 24 06:58:03 2023

@author: xiatong
shared features
"""


import numpy as np
import matplotlib.pyplot as plt

import seaborn as sns
sns.set_theme(style="ticks")


plt.figure(dpi=300, figsize=(3,1.5))

# Fre = np.zeros([100,100])
# CNT = 100.0

Fre = np.zeros([500,500])
CNT = 500.0

path = './'

Fre = np.zeros([500,500])
round_fre  = []
users = []
users_pro = []
idx = 0
Flag = True
for file in [ 'users_500_0']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'selected users' in line:
                temp = line.split(':')[1]
                temp = temp[2:-2] 
                clients = [int(c) for c in temp.split(',')]
                print(idx, clients)
                if idx == 0: #first round no share
                    last_round = clients
                else:
                    this_round = clients
                    for i in  last_round:
                        for j in this_round:
                            Fre[i,j] = 1
                    last_round = clients
                round_fre.append(np.sum(Fre)/CNT/CNT)
                idx += 1
                users.extend(clients)
                users_pro.append(len(set(users))/CNT)
 
Fre = np.zeros([500,500])
round_fre1  = []
idx = 0
Flag = True
for file in [ 'users_500_1']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'selected users' in line:
                temp = line.split(':')[1]
                temp = temp[2:-2] 
                clients = [int(c) for c in temp.split(',')]
                print(idx, clients)
                if idx == 0: #first round no share
                    last_round = clients
                else:
                    this_round = clients
                    for i in  last_round:
                        for j in this_round:
                            Fre[i,j] = 1
                    last_round = clients
                round_fre1.append(np.sum(Fre)/CNT/CNT)
                idx += 1

Fre = np.zeros([500,500])                    
round_fre2  = []
idx = 0
Flag = True
for file in [ 'users_500_2']:   
    acc = []
    with open (path + file + '.log', encoding="utf8") as f: 
        for line in f:
            if 'selected users' in line:
                temp = line.split(':')[1]
                temp = temp[2:-2] 
                clients = [int(c) for c in temp.split(',')]
                print(idx, clients)
                if idx == 0: #first round no share
                    last_round = clients
                else:
                    this_round = clients
                    for i in  last_round:
                        for j in this_round:
                            Fre[i,j] = 1
                    last_round = clients
                round_fre2.append(np.sum(Fre)/CNT/CNT)
                idx += 1
 




acc_mean =  np.mean([round_fre,round_fre1,round_fre2], axis=0)
acc_min = np.min([round_fre,round_fre1,round_fre2], axis=0)
acc_max = np.max([round_fre,round_fre1,round_fre2], axis=0)
plt.plot(acc_mean, linewidth=1.2,label = 'FLea')
x = range(len(round_fre))
plt.fill_between(x, [0]*500, acc_max, alpha=0.2)

plt.plot([50,50],[0,1], '--')

#plt.plot(users_pro, linewidth=1.2, color='grey')

plt.plot([1]*500, linewidth=1.2,label = 'FedMix/FedData')

plt.ylim([0,1.1])
plt.xticks([0,100,200,300,400,500])
plt.yticks([0,0.2,0.4,0.6,0.8,1], ['', '20', '40', '60', '80', '100'])
plt.xlabel('Round')
plt.ylabel('$\epsilon^{(t)}$ %')
plt.legend()
 