wandb: v4
stage_name: knn
name: dinov2-giga14--last4
vars:
  stage_id: 3duek90m

datasets:
  train:
    template: ${yaml:datasets/imagenet/train_noaug}
    template.vars.version: imagenet1k
  test:
    template: ${yaml:datasets/imagenet/test_noaug}
    template.vars.version: imagenet1k

model:
#    kind: vit.vit
#    patch_size: 16
#    kwargs: ${select:large:${yaml:models/vit}}
  kind: torch_hub_model
  repo: facebookresearch/dinov2
  model: dinov2_vitg14
  mode: classifier
  is_frozen: true

trainer:
  kind: classification_trainer
  precision: bfloat16
  backup_precision: float16
  effective_batch_size: 256
  max_epochs: 0
  log_every_n_epochs: 1
  callbacks:
    - kind: offline_knn_metrics_callback
      every_n_epochs: 1
      train_dataset_key: train
      test_dataset_key: test
      inplace: true
      extractors:
        - kind: vit_block_extractor
          model_path: model
          use_next_norm: false
          block_indices: [ -1, -2, -3, -4 ]
          finalizer:
            kind: concat_finalizer
            dim: -1
          pooling:
            kind: class_token