import argparse


def arg_parser():
    parser = argparse.ArgumentParser(description='PyTorch Action recognition Training')
    parser.add_argument('--prefix', default='', type=str, help='model prefix')

    parser.add_argument('--resume', default=None, type=str, metavar='PATH',
                        help='path to latest checkpoint (default: none)')
    parser.add_argument('--pretrained', default=None, type=str, metavar='PATH',
                        help='path to pretrained checkpoint')
    parser.add_argument('--auto_resume', action='store_true', help='if the log folder includes a checkpoint, automatically resume')

    # data-related
    parser.add_argument('--datadir', type=str,  metavar='DIR', help='path to dataset file list')
    parser.add_argument('--input_size', default=224, type=int, metavar='N', help='input image size')
    parser.add_argument('--train_input_size', type=int, metavar='N', help='input image size')
    parser.add_argument('--num_train_cls', type=int, default=100, help='input image size')
    parser.add_argument('--test_input_size', type=int, metavar='N', help='input image size')
    parser.add_argument('--thre', default=0.8, type=float,
                        metavar='N', help='threshold value')
    parser.add_argument('--single_prompt', default='pos', type=str, help='type of single prompt')

    # for testing and validation
    parser.add_argument('-e', '--evaluate', dest='evaluate', action='store_true',
                        help='evaluate model on validation set')

    # cfg file
    parser.add_argument('--config_file', dest='config_file', type=str, help='network config file path')
    parser.add_argument('--dataset_config_file', dest='dataset_config_file', type=str, help='network config file path')

    # positive prompt & negative prompt
    parser.add_argument('--positive_prompt', dest="positive_prompt", type=str, help='the initial positive prompt for mlc_clip')
    parser.add_argument('--negative_prompt', dest="negative_prompt", type=str, help='the initial negative prompt for mlc_clip')
    # positive prompt & negative prompt number
    parser.add_argument('--n_ctx_pos', dest="n_ctx_pos", type=int, help='the positive prompt for mlc coop')
    parser.add_argument('--n_ctx_neg', dest="n_ctx_neg", type=int, help='the negative prompt for mlc coop')

    parser.add_argument('--lr', dest="lr", type=float, help='the learning rate')
    parser.add_argument('--loss_w', dest="loss_w", type=float, default=0.03, help='the loss weights')

    parser.add_argument('--csc', dest='csc', action='store_true',
                        help='specify the csc')

    parser.add_argument('--logit_scale', dest="logit_scale", type=float, default=100.,
                        help='the logit scale for clip logits')

    parser.add_argument('-p', '--portion', dest="portion", type=float, default=1.,
                        help='the portion of training split used for training')

    parser.add_argument('-pp', '--partial_portion', dest="partial_portion", type=float, default=1+1e-6,
                        help='the portion of partial labels used for training')

    parser.add_argument('--mask_file', dest="mask_file", type=str,
                        help='the mask label for partial labeling')

    parser.add_argument('--train_batch_size', dest="train_batch_size", type=int,
                        help='the batch size for training')

    parser.add_argument('--finetune', dest='finetune', action='store_true',
                        help='specify if finetuning the backbone')

    parser.add_argument('--finetune_backbone', dest='finetune_backbone', action='store_true',
                        help='specify if finetuning the backbone')

    parser.add_argument('--finetune_attn', dest='finetune_attn', action='store_true',
                        help='specify if finetuning the backbone')

    parser.add_argument('--finetune_text', dest='finetune_text', action='store_true',
                        help='specify if finetuning the text')

    parser.add_argument('--base_lr_mult', dest='base_lr_mult',  type=float,
                        help='specify if finetuning the backbone')

    parser.add_argument('--backbone_lr_mult', dest='backbone_lr_mult', type=float,
                        help='specify if finetuning the backbone')

    parser.add_argument('--text_lr_mult', dest='text_lr_mult', type=float,
                        help='specify if finetuning the backbone')

    parser.add_argument('--attn_lr_mult', dest='attn_lr_mult', type=float,
                        help='specify if finetuning the backbone')

    parser.add_argument('--val_every_n_epochs', dest='val_every_n_epochs', type=int, default=1,
                        help='specify if finetuning the backbone')

    return parser