import argparse

parser = argparse.ArgumentParser(description="")
parser.add_argument(
    "--data-dir", default="../../data/VQAR", type=str
)
parser.add_argument("--feat-dim", default=2048, type=int)

# train_file is the file storing our own NSL training samples 
# train_samples is a map from query ids to: 
# - the corresponding image
# - the Datalog query 
# - a triple of the form (answer, proofs, ground truth), where 
# -- answer is the answer (bounding box) to the query
# -- proofs is a list of abductive proofs, one proof per entry in the list 
# -- ground truth is a vector of length equal to len(proofs) and it is 1 if the corresponding abductive proof is true and false otherwise.  
# -- object_ids: the list of all object ids in the proofs. 
# -- object_id_pairs: the list of object combinations occurring in the proofs. 
parser.add_argument(
    "--train-file-weak",
    default="../benchmark/experiment1-train-c2-all-topk_names100-topk_attrs0-topk_relas50.pickle",
    type=str,
)

parser.add_argument(
    "--train-file-supervised",
    default="../benchmark/experiment1-train-c2-all-topk_names100-topk_attrs0-topk_relas50-supervised.pickle",
    type=str,
)

# train_features_file is the Scallop tasks file and holds the feature vectors for the bounding boxes in the images  
# train_features maps each image in GQA to its: 
# - image_id 
# - scene graph of the image with the following fields: 
# -- names: map from each bounding box to its type id, 
# -- attributes: map from each bounding box to a list of its attribute ids, 
# -- relations: map from each subject bounding box to a map of the form (object-relation id)  
# -- bboxes: map from each bounding box to its coordinates 
# - url of the image
# - Scallop question (this is a legacy field and not used)
# - object_ids: a list of the bounding box ids
# - object_feature: a list of features, one per bounding box
parser.add_argument(
    "--train-features-file",
    default="../../data/VQAR/dataset/task_list/train_tasks_c2_10000.pkl",
    type=str,
)

# test_file is the file storing our own NSL testing samples 
# test_samples is a map from query ids to: 
# - the corresponding image
# - the property we are testing, that is, name, relation, or attribute
# - the bounding box if we test name or attribute _or_ a pair of bounding boxes if we test relation
# - the type of the bounding box if we test property name _or_ a list for attributes for the bounding box if we test property attribute 
# _or_ the relation of the pair of bounding boxes if we test property relation   
parser.add_argument(
    "--test-file",
    default="../benchmark/test-c2-all-topk_names100-topk_attrs0-topk_relas50-per-class-500.pickle",
    type=str,
)

# test_features_file is the Scallop tasks file and holds the feature vectors for the bounding boxes in the images  
# test_features has the same structure with the train_features file 
parser.add_argument(
    "--test-features-file",
    default="../../data/VQAR/dataset/task_list/test_tasks.pkl",
    type=str,
)

parser.add_argument(
    "--meta-f",
    default="../../data/VQAR/gqa_info-topk_names100-topk_attrs0-topk_relas50.json",
    type=str,
)

parser.add_argument(
    "--exp-dir",
    default="./",
    type=str,
    help="experiment directory for saving checkpoints and logs",
)

parser.add_argument(
    "--load_model_dir",
    default=None,
    type=str,
    help="load model from checkpoint",
)

parser.add_argument(
    "-j",
    "--workers",
    default=4,
    type=int,
    help="number of data loading workers (default: 32)",
)
parser.add_argument("--gpu", default=1, type=int, help="GPU id to use.")

parser.add_argument(
    "-b",
    "--batch-size",
    default=312,
    type=int,
    help="mini-batch size (default: 512), this is the total "
    "batch size of all GPUs on the current node when "
    "using Data Parallel or Distributed Data Parallel",
)

parser.add_argument(
    "-p", "--print-freq", default=1, type=int, help="print frequency (default: 100)"
)

parser.add_argument(
    "--epochs", default=20, type=int, help="number of total epochs to run"
)

parser.add_argument(
    "--lr",
    "--learning-rate",
    default=0.01,
    type=float,
    metavar="LR",
    help="initial learning rate",
    dest="lr",
)
parser.add_argument(
    "-lr_decay_epochs",
    type=str,
    default="700,800,900",
    help="where to decay lr, can be a list",
)
parser.add_argument(
    "-lr_decay_rate", type=float, default=0.1, help="decay rate for learning rate"
)
parser.add_argument(
    "--cosine", action="store_true", default=True, help="use cosine lr schedule"
)
parser.add_argument(
    "--momentum", default=0.9, type=float, metavar="M", help="momentum of SGD solver"
)
parser.add_argument(
    "--wd",
    "--weight-decay",
    default=1e-3,
    type=float,
    metavar="W",
    help="weight decay (default: 1e-5)",
    dest="weight_decay",
)
parser.add_argument(
    "--seed", default=2, type=int, help="seed for initializing training. "
)

parser.add_argument(
    "--structure-k", default=15, type=int
)

parser.add_argument(
    "--structured_pruning", action="store_true"
)

parser.add_argument(
    "--algo1_pruning", action="store_true"
)

parser.add_argument(
    "--percent", default=-0.0005, type=float
)

parser.add_argument(
    "--early_stopping", default=0, type=int
)

parser.add_argument(
    "--eps", default=0.9, type=float
)

parser.add_argument(
    "--warmup", default=10, type=int
)

parser.add_argument("--mock_proximity", action="store_true")