{
    "general": {
        "seed": 42,
        "base_path": "",
        "device": "cuda",
        "id": "sample_config",
        "description": "This is a sample config",
        "server": "cluster",
        # Note that this parameter is being ignore for now..
        "commit_id": "",
        "date": "",
        "num_experiments":1,
        "slurm_id": "-1",
        "batch_size": 256,
        "data_name": "sample_data",
        "few_shot_per" : 5,
        "train_mode" : "supervised", # run_mult / supervised / seq_mult / seq_zero / seq_full / seq_few,
        "has_signature": True,  
        "train_rule": "rule_1",
        "test_rule": "rule_0",
        "is_meta": False, # if True, MAML is run
        "overfit" : 0 # if > 0, overfit to that number of batches in training
    },
    "data": {
        "with_answer" : False
    },
    "logger":{
        "remote":{
         "api_key": "", # WANDB API
         "entity": "gamma",
         "project_name": "lgw_long",
         "should_use": True,
         "frequency": 5,
        },
        "project_name": "lgw_long",
        "file":{
            "path": "",
            "should_log_trajectory": False,
            "should_log_compute_stats": False,
            },
        "tensorboard":{
            "should_use": False,
            },
        "watch_model": False,
        "dir": "logs"
     },
    "model": {
        "base_path" : "codes.model.pyg.edge_gat", # Model base path
        "composition_fn_path": "codes.model.gat.edge_gat.GatedGatEncoder",
        "representation_fn_path": "codes.model.gat.edge_gat.GatedNodeGatEncoder",
        "composition_learn_param": True,
        "representation_learn_param": True,
        "use_composition_fn": True, # if true, load composition fn from "load_dir"
        "freeze_composition_fn": True, # if true, freeze composition function
        "learn_relation_weights": True,
        "lr_inner": 1,
        "first_order" : false,
        "tasks_per_metaupdate": 10,
        "num_inner_updates": 5,
        "should_train": true,
        "k_meta_test": 10,
        "num_epochs": 10000,
        "persist_frequency": 100,
        "evaluate_frequency": -1,
        "persist_best_model": False,
        "early_stopping_patience": 150,
        "use_sparse_embedding": False,
        "save_dir": "~/checkpoint/lgw/ckpt/supervised/representation_100_easy_10_long_freeze/",
        "load_dir" : "~/checkpoint/lgw/ckpt/multitask_param/composition_100_easy_10_long/",
        "should_load_model": false,
        "modes": ["train", "val", "test"],
        "optim":{
            "name": "Adam",
            "learning_rate": 0.001,
            "weight_decay": 0.0,
            "eps": 0.00000001,
            "scheduler_type": "plateau",
            "scheduler_patience": 10,
            "scheduler_gamma": 0.8
        },
        "signature_optim": {
            "name": "SGD",
            "learning_rate": 0.01,
            "weight_decay": 0.0,
            "eps": 0.00000001,
            "scheduler_type": "plateau",
            "scheduler_patience": 10,
            "scheduler_gamma": 0.9
        },
        "weight_norm": False,
        "relation_embedding_dim" : 200, # hyperparam search - 200
        "node_embedding_dim" : 200, # hyperparam search - 200
        "gat" : {
            "num_layers": 6,  # hyperparam search stability
            "in_dim": 1,
            "num_hidden": 300,
            "num_heads": 8,
            "num_out_heads": 300,
            "feat_drop": False,
            "attn_drop": False,
            "alpha": 0.1,
            "residual": False,
            "bias": True,
            "concat": False,
            "negative_slope": 0.2,
            "dropout": 0.,
            "emb_type": "random", # can be "one-hot ",
            "share_relation_emb": False
        },
        "signature_gat": {
            "num_layers": 6,  # hyperparam search
            "in_dim": 1,
            "num_hidden": 300,
            "num_heads": 8,
            "num_out_heads": 300,
            "feat_drop": False,
            "attn_drop": False,
            "alpha": 0.1,
            "residual": False,
            "bias": False,
            "concat": False,
            "negative_slope": 0.2,
            "dropout": 0.0,
            "emb_type": "random", # can be "one-hot ",
            "share_relation_emb": False,
            "learn_node_and_rel_emb": True,
        },
        "rgcn": {
           "num_layers": 2,
           "root_weight": True,
           "bias": True,
           "dropout": 0.0
        },
        "gcn": {
            "num_layers": 2,
            "improved": True,
            "cached": True,
            "bias": True,
            "normalize": True,
            "dropout": 0.0
        },
        "out_dim":14,
        "classify_layers": 2,
        "classify_hidden": 200,
        "num_classes":-1, # should be filled dynamically,
        "num_nodes":50 # max num of nodes, can be filled in dynamically

    },
    "plot": {
        "base_path": ""
    },
}
