import argparse
import torch

def args_parser():
    parser = argparse.ArgumentParser()

    # basic information of the problem
    parser.add_argument('--num_clients', type=int, default=8, help='number of clients')
    parser.add_argument('--num_tasks', type=int, default=4, help='number of tasks')

    # basic information of the training
    parser.add_argument('--batch_size', type=int, default=32, help='local batch size')
    parser.add_argument('--epochs', type=int, default=30, help='number of local training epochs')
    parser.add_argument('--rounds', type=int, default=10, help='number of communication rounds')
    parser.add_argument('--lambda_reg', type=float, default=0.25, help='value of regularization weight')
    parser.add_argument('--dirichlet_coef', type=float, default=0.1, help='value of dirichlet coefficient')
    parser.add_argument('--lr_local', type=float, default=0.001, help='local learning rate')
    parser.add_argument('--lr_global', type=float, default=1, help='global learning rate')
    parser.add_argument('--participated_clients', type=int, default=4, help='number of participated clients')

    # basic information of the setting
    parser.add_argument('--device', type=str, default='cuda' if torch.cuda.is_available() else 'cpu',
                        help='device to use')
    parser.add_argument('--model', type=str, default='ResNet18', help='model name')
    parser.add_argument('--dataset_list', type=str, default='DIGIT10', help='list of dataset')
    parser.add_argument('--method', type=str, default='SPECIAL', help='list of algorithms')
    parser.add_argument('--seed', type=int, default=2025, help='seed')

    # record the training result
    parser.add_argument('--savor_name', type=str, default='result_object.pkl', help='name of the savor file')

    args = parser.parse_args()
    return args
