defaults:
  - _self_
  - augmentations: symmetric.yaml
  - wandb: private.yaml
  - override hydra/hydra_logging: disabled
  - override hydra/job_logging: disabled

# disable hydra outputs
hydra:
  output_subdir: null
  run:
    dir: .

name: "radialswav-imagenet"
method: "radialswav"
backbone:
  name: "resnet50"

method_kwargs:
  proj_hidden_dim: 2048
  proj_output_dim: 128
  num_prototypes: 3000
  sk_iters: 3
  sk_epsilon: 0.05
  temperature: 0.1
  queue_size: 65536
  epoch_queue_starts: 15
  freeze_prototypes_epochs: 1
  radial_loss_weight: 100

data:
  dataset: imagenet100
  train_path: "datasets/imagenet100/train"
  val_path: "datasets/imagenet100/val"
  format: "image_folder"
  num_workers: 16 # 2 changed to 16 to make faster

augmentations:
  - # view 1
    rrc:
      enabled: True
      crop_min_scale: 0.14
      crop_max_scale: 1.0
    color_jitter:
      enabled: True
      brightness: 0.8
      contrast: 0.8
      saturation: 0.8
      hue: 0.2
      prob: 0.8
    grayscale:
      enabled: True
      prob: 0.2
    gaussian_blur:
      enabled: False
    solarization:
      enabled: False
    equalization:
      enabled: False
    horizontal_flip:
      enabled: True
      prob: 0.5
    crop_size: 224
    num_crops: 1
  - # view 2
    rrc:
      enabled: True
      crop_min_scale: 0.14
      crop_max_scale: 1.0
    color_jitter:
      enabled: True
      brightness: 0.8
      contrast: 0.8
      saturation: 0.8
      hue: 0.2
      prob: 0.8
    grayscale:
      enabled: True
      prob: 0.2
    gaussian_blur:
      enabled: False
    solarization:
      enabled: False
    equalization:
      enabled: False
    horizontal_flip:
      enabled: True
      prob: 0.5
    crop_size: 224
    num_crops: 1

optimizer:
  name: "lars"
  batch_size: 256
  lr: 0.6
  classifier_lr: 0.1
  weight_decay: 1e-6
  kwargs:
    clip_lr: False
    eta: 0.001
    exclude_bias_n_norm: True

scheduler:
  name: "warmup_cosine"

checkpoint:
  enabled: True
  dir: "trained_models"
  frequency: 1

auto_resume:
  enabled: False
  # enabled: True
  # cpt_checkpoint_path: "path/to/your/checkpoint.ckpt"

# overwrite PL stuff
max_epochs: 400
devices: [0] # changed from 0,1 to 0 to get faster GPUs
sync_batchnorm: True
accelerator: "gpu"
strategy: "auto"
precision: 16-mixed

knn_eval:
  enabled: False # to avoid OOM 

radius_hist:
  enabled: true
  max_snapshots: 50