import argparse


def get_arguments():
    parser = argparse.ArgumentParser(description="Llama2: Backdoor Detection and Unlearning")

    parser.add_argument("--seed", type=list, default=[2021])
    parser.add_argument("--tokenizer", type=str, default="meta-llama/Llama-2-7b-hf")
    parser.add_argument("--victim_model", type=str, default="meta-llama/Llama-2-7b-hf")

    parser.add_argument("--poisoning_epoch", type=int, default=10)
    parser.add_argument("--dataset", type=str, default="AG", help="SST-2, HSOL, AG")
    parser.add_argument("--attack_mode", type=str, default="BadNet", help="BadNet, AddSent, HiddenKiller")

    parser.add_argument("--max_len", type=int, default=128)
    parser.add_argument("--learning_rate", type=float, default=5e-6)
    parser.add_argument("--batch_size", type=int, default=16)

    # Detection Part: UMAP and HDBSCAN parameters
    parser.add_argument("--min_cluster", type=int, default=150)
    parser.add_argument("--min_samples", type=int, default=120)
    parser.add_argument("--umap_n_neighbors", type=int, default=100)
    parser.add_argument("--umap_min_dist", type=float, default=0.25)

    # Unlearning Part: [RT:Retrain, GA: Gradient Ascent, NPO: Negative Preference Optimization, RGA:Robust GA]
    parser.add_argument("--unlearning_method", type=str, default="RGA", help="RT, GA, NPO, RGA")
    parser.add_argument("--unlearning_epoch", type=int, default=10)

    return parser
