from yacs.config import CfgNode as CN
from MegaGNN.graphgym.register import register_config


@register_config('cfg_misc')
def set_cfg_misc(cfg):
    r"""This function sets the default config value for customized options
    :return: customized configuration use by the experiment.
    """
    # ----------------------------------------------------------------------- #
    # Customized options
    # ----------------------------------------------------------------------- #
    cfg.name_tag = ""

    # In training, if True (and also cfg.train.enable_ckpt is True) then
    # always checkpoint the current best model based on validation performance,
    # instead, when False, follow cfg.train.eval_period checkpointing frequency.
    cfg.train.ckpt_best = True

    # Enable tqdm progress bar during training/validation/testing
    cfg.train.tqdm = False
    cfg.val.tqdm = False

    # In training, when the graph is very large, you may not want to iterate through
    # all the batches available. You can sample a subset of available batches as
    # the HGT does in their code.
    cfg.train.iter_per_epoch = 0

    # In evaluation, you may want to reduce the evaluation time like the above rationale
    # for training. However, to reduce the periodic variance due to cycle through the val/test
    # set, we fixed the evaluation sampling to the same set of batches. So the performance
    # would be evaluated under the same set of data.
    cfg.val.iter_per_epoch = 0

    # Sampling parameters
    cfg.train.persistent_workers = False
    cfg.train.pin_memory = False

    # NeighborSampler / HGTSampler: number of sampled nodes per layer for each node type
    cfg.train.neighbor_sizes_dict = ""

    # RandomNodeLoader: number of partitions
    cfg.train.num_parts = 10

    # AddEgoID option
    cfg.train.add_ego_id = False

    # APPNP hyperparameter
    cfg.gnn.K = 10
    cfg.gnn.alpha = 0.1

    # NAGphormer hop2seq hyperparameter
    cfg.gnn.hops = 7

    # SHGN hyperparameter
    cfg.gnn.residual = True

    # LSGNN hyperparameter
    cfg.gnn.A_embed = True

    cfg.gnn.batch_norm = False
    cfg.gnn.layer_norm = False

    cfg.gnn.input_dropout = 0.0

    cfg.gnn.attn_dropout = 0.0

    cfg.gnn.edge_updates = False
    cfg.gnn.use_linear = False
    cfg.gnn.output_l2_norm = False
    cfg.gnn.jumping_knowledge = False
    
    cfg.model.loss_fun_weight = []

    
