class graphs:
    def __init__(self):
        self.log_epochs   = []
        self.accuracy     = []
        self.loss         = []
        self.eigs         = []
        self.evec         = []   
        self.gn_eigs      = []
        self.eigs_test    = []
        self.adv_eigs     = {} # the keys are adv_eta
        self.batch_loss   = []

        self.weight       = []
        self.grads        = []
        self.residuals    = []

        self.density_eigen  = []
        self.density_weight = []

        self.test_loss    = []
        self.test_accuracy = []
        self.best_test_accuracy = -1

        self.reg_loss     = []
        self.test_reg_loss     = []

        self.grad_evecs_cos = []

        # NC1
        self.Sw_invSb     = []

        # NC2
        self.norm_M_CoV   = []
        self.norm_W_CoV   = []
        self.cos_M        = []
        self.cos_W        = []

        # NC3
        self.W_M_dist     = []

        # NC4
        self.NCC_mismatch = []

        # Decomposition
        self.MSE_wd_features = []
        self.LNC1 = []
        self.LNC23 = []
        self.Lperp = []

        # NC1
        self.test_Sw_invSb     = []

        # NC2
        self.test_norm_M_CoV   = []
        self.test_norm_W_CoV   = []
        self.test_cos_M        = []
        self.test_cos_W        = []

        # NC3
        self.test_W_M_dist     = []

        # NC4
        self.test_NCC_mismatch = []

        # Decomposition
        self.test_MSE_wd_features = []
        self.test_LNC1 =         []
        self.test_LNC23 =        []
        self.test_Lperp =        []

        # weight norm statsitics
        self.wn_grad_loss_ratio = []
        self.wn_norm_min        = []
        self.wn_norm_min_with_g = []

        # weight alignment
        self.signal_1           = []
        self.signal_2           = []
        self.align_signal_1     = []
        self.align_signal_2     = []
        self.align_noise        = []
        self.linear_coefs       = []
        self.model_output       = []
        self.activation_pattern = []

        # diagonal statistics
        self.diagonal_coef      = []
        self.diagonal_invariate = []

        self.cos_descent_ascent = []
        self.ascent_step_diff   = []
        self.ascent_step_cos    = []
        self.progress_dir       = []
        self.descent_step_diff  = []
        self.descent_norm       = []
        self.ascent_semi_cos    = []

        self.grad_norm          = []
        self.grad_l1_norm       = []
        self.ascent_grad_norm   = []
        self.ascent_grad_l1_norm= []
        self.pseudo_grad_norm   = []
        self.minibatch_grad_norm= []
        self.dominant_alignment = []
        self.hessian_gn_align   = []
        self.hessian_eig        = []
        self.gn_eig             = []

        self.test_img           = []
        self.attention_map      = []
        self.attention_path     = []
        self.output_norm        = []
        self.layer_cls_train_score = {}
        self.layer_cls_test_score  = {}

        #fedlora
        self.fedlora_A_align    = []
        self.fedlora_B_align    = []
        self.fedlora_A_cosine   = []
        self.fedlora_B_cosine   = []
        self.lora_A_norm        = []
        self.lora_B_norm        = []
        self.truncate_err       = []

        #lora
        self.ratio_A            = []
        self.ratio_B            = []
        self.effective_rank     = []
        self.stable_rank        = []

        #timeit
        self.server_optimize_time = []
        self.client_time_mean     = []
        self.client_time_max      = []
        self.redistribution_time  = []
        self.subprocess_time      = []