# configs.py
"""
Global hyperparameters and default configuration for EGP reproduction.
Change these values to match the paper's appendix defaults when running real experiments.
"""
from dataclasses import dataclass

@dataclass
class Config:
    # Sampling and DDIM
    ddim_steps: int = 50           # number of DDIM steps for proposals
    cfg_scale: float = 1.0         # classifier-free guidance scale (if used)

    # Energy-guided correction hyperparams (paper defaults as example)
    beta: float = 2.5              # overall multiplier for CLIP-repulsion term
    tau: float = 0.25              # CLIP margin / threshold (tau in paper)
    eta0: float = 0.1              # initial step size for inner loop
    ne: int = 3                    # number of inner gradient correction steps (per paper)
    gamma: float = 1.2             # schedule exponent for eta_t = eta0 * (t/T)^gamma
    delta_norm: float = 0.01       # early-stop gradient norm threshold

    # Optimization / Langevin
    use_langevin: bool = False
    langevin_scale: float = 1e-2

    # Model and device
    device: str = "cuda" if __import__("torch").cuda.is_available() else "cpu"

    # IO / misc
    seed: int = 42
    save_dir: str = "./outputs"
    projector_enabled: bool = False  # use projector mlp as fast surrogate for decode->CLIP
