model:
  name: "resnet18_cifar"
  num_classes: 10
  # checkpoint: will be auto-injected by _maybe_inject_checkpoint()

dataset:
  name: "cifar10"
  data_root: "/home/voz/shared/database/vision"
  batch_size: 128  # Default batch size for test/val loaders
  num_workers: 8
  has_val: true

  split_protocol:
    type: "class_forget"
    forget_classes: [0]  # Forget class 0

deterministic: true

method:
  name: scrub

  # ---------- Optimization ----------
  optimizer: "adam"           # "adam" | "adamw" | "sgd"
  lr: 0.0005
  weight_decay: 0.0005
  momentum: 0.9               # used only for SGD
  lr_decay_after: 2           # decay lr by ×0.1 after epoch 2 (optional)

  # ---------- Alternating training ----------
  # Paper values for ResNet + CIFAR-10 + class unlearning (Table 3, page 16)
  max_steps: 2                # CORRECTED: Number of MAX (forget) epochs
  min_steps: 3                # Number of MIN (retain) epochs
  final_min_steps: 0          # Extra MIN-only epochs after alternating cycles
  alpha: 1.0                  # Weight on KL divergence during MIN step
  gamma: 1.0                  # Weight on CE loss during MIN step
  clip_grad_norm: 1.0         # Clip gradients (set 0 or null to disable)

  # ---------- CRITICAL: Separate batch sizes for forget/retain ----------
  # Paper Table 3: Different batch sizes control iteration balance
  batch_size_forget: 512      # ADDED: Batch size for forget set (class unlearning)
  batch_size_retain: 128      # ADDED: Batch size for retain set (class unlearning)

  # ---------- Rewind variant (SCRUB+R) ----------
  rewind: false               # true → enable rewind selection for privacy (UP application)
  # When true, the method will select the checkpoint whose forget error (train)
  # is closest to the forget error (validation) of the final model.
  # This helps defend against Membership Inference Attacks.