import argparse


def parse_args():
    parser = argparse.ArgumentParser(description='Simple example of a training script.')
    parser.add_argument('--pretrained_model_name_or_path', type=str, default='CompVis/stable-diffusion-v1-4', help='Path to pretrained model or model identifier from huggingface.co/models.')
    parser.add_argument('--ipc', type=int, default=1, help='Number of images per class when validation or inference.')
    parser.add_argument('--batch_size', type=int, default=1, help='Batch size of model input.')
    parser.add_argument('--img_output', type=str, default='outputs/synthetic_datasets', help='Path to save the generated images.')
    parser.add_argument('--guidance_scale', type=float, default=7.5, help='Guidance scale for Classifier-Free Guidance (CFG).')
    parser.add_argument('--guidance_step_size', type=float, default=0.01, help='Guidance step size for Gradient Guidance')
    parser.add_argument('--time_travel', type=float, default=25, help='time_travel')
    parser.add_argument('--num_inference_steps', type=int, default=50, help='Number of inference steps for DDIM')
    parser.add_argument('--dataset', type=str, default='imagenet', help='Name of the dataset to train on.')
    parser.add_argument('--imagenet_dir', type=str, default=None, help='Path to ImageNet dataset.')
    parser.add_argument('--subset', type=str, default='nette', help='Dataset specification (nette, woof, idc, imagenet1k).')
    parser.add_argument('--shuffle', type=bool, default=False, help='Whether to shuffle the dataset.')
    parser.add_argument('--validate_freq', type=int, default=1, help='Whether to perform validation at the end of each epoch.')
    parser.add_argument('--validation_steps', type=int, default=100, help='Run validation every N training steps.')
    parser.add_argument('--wandb_name', type=str, default='acc_test', help='Project name used in Weights and Biases for experiment tracking.')
    parser.add_argument('--wandb_project', type=str, default='stable-diffusion-dap', help='Project name for wandb logging')
    parser.add_argument('--image_size', type=int, default=512, help='Input image size for model training.')
    parser.add_argument('--seed', type=int, default=489, help='Random seed for reproducibility.')
    parser.add_argument('--wandb_enabled', type=bool, default=True, help='Whether to enable wandb logging.')
    parser.add_argument('--model_type', type=str, default='sd', choices=['sd', 'dit'], help='Model type (dit or stable-diffusion or flux).')
    parser.add_argument('--feature_layer_idx', type=int, default=2, help='Feature layer index for DAP.')
    args = parser.parse_args()
    return args