hydra:
  run:
    dir: .
  sweep:
    dir: .
    subdir: .
  launcher:
    _target_: hydra._internal.core_plugins.basic_launcher.BasicLauncher
  sweeper:
    _target_: hydra._internal.core_plugins.basic_sweeper.BasicSweeper
    max_batch_size: null
    params: null
  help:
    app_name: ${hydra.job.name}
    header: '${hydra.help.app_name} is powered by Hydra.

      '
    footer: 'Powered by Hydra (https://hydra.cc)

      Use --hydra-help to view Hydra specific help

      '
    template: '${hydra.help.header}

      == Configuration groups ==

      Compose your configuration from those groups (group=option)


      $APP_CONFIG_GROUPS


      == Config ==

      Override anything in the config (foo.bar=value)


      $CONFIG


      ${hydra.help.footer}

      '
  hydra_help:
    template: 'Hydra (${hydra.runtime.version})

      See https://hydra.cc for more info.


      == Flags ==

      $FLAGS_HELP


      == Configuration groups ==

      Compose your configuration from those groups (For example, append hydra/job_logging=disabled
      to command line)


      $HYDRA_CONFIG_GROUPS


      Use ''--cfg hydra'' to Show the Hydra config.

      '
    hydra_help: ???
  hydra_logging:
    version: 1
    root: null
    disable_existing_loggers: false
  job_logging:
    version: 1
    root: null
    disable_existing_loggers: false
  env: {}
  mode: MULTIRUN
  searchpath: []
  callbacks: {}
  output_subdir: null
  overrides:
    hydra:
    - hydra.mode=MULTIRUN
    task:
    - train.seed_index=2,3,4,5
  job:
    name: train
    chdir: true
    override_dirname: train.seed_index=2,3,4,5
    id: ???
    num: ???
    config_name: resnet
    env_set:
      WANDB_START_METHOD: thread
      WANDB_DIR: ${oc.env:PROJECT_ROOT}
    env_copy: []
    config:
      override_dirname:
        kv_sep: '='
        item_sep: ','
        exclude_keys: []
  runtime:
    version: 1.2.0
    version_base: '1.1'
    cwd: /media/donato/Extra-storage/Code/model-merging/cycle-consistent-model-merging
    config_sources:
    - path: hydra.conf
      schema: pkg
      provider: hydra
    - path: /media/donato/Extra-storage/Code/model-merging/cycle-consistent-model-merging/conf
      schema: file
      provider: main
    - path: ''
      schema: structured
      provider: schema
    output_dir: ???
    choices:
      dataset: emnist
      train: resnet
      nn: resnet
      hydra: default
      hydra/env: default
      hydra/callbacks: null
      hydra/job_logging: none
      hydra/hydra_logging: none
      hydra/hydra_help: default
      hydra/help: default
      hydra/sweeper: basic
      hydra/launcher: basic
      hydra/output: default
  verbose: false
nn:
  data_path: ${oc.env:PROJECT_ROOT}/data
  output_path: ${oc.env:PROJECT_ROOT}/output
  data:
    _target_: ccmm.data.datamodule.MyDataModule
    dataset: ${dataset}
    gpus: ${train.trainer.gpus}
    num_workers:
      train: 8
      val: 4
      test: 4
    batch_size:
      train: 100
      val: 128
      test: 128
  module:
    _target_: ccmm.pl_modules.pl_module.MyLightningModule
    model_name: ResNet${nn.module.model.depth}_${nn.module.model.widen_factor}
    model:
      _target_: ccmm.models.resnet.ResNet
      depth: 22
      num_classes: ${dataset.num_classes}
      widen_factor: 2
      norm_layer: ln
      input_channels: 1
    optimizer:
      _target_: torch.optim.SGD
      lr: 0.1
      weight_decay: 0.0001
    lr_scheduler:
      _target_: pl_bolts.optimizers.lr_scheduler.LinearWarmupCosineAnnealingLR
      warmup_epochs: 5
      max_epochs: ${train.trainer.max_epochs}
      warmup_start_lr: 1.0e-06
      eta_min: 0.0
      last_epoch: -1
train:
  seed_index: 1
  deterministic: false
  trainer:
    fast_dev_run: false
    gpus: 1
    precision: 32
    max_epochs: 50
    max_steps: -1
    accumulate_grad_batches: 1
    num_sanity_val_steps: 2
    gradient_clip_val: 10.0
    val_check_interval: 1.0
    deterministic: ${train.deterministic}
  restore:
    ckpt_or_run_path: null
    mode: continue
  monitor:
    metric: loss/train
    mode: min
  callbacks:
  - _target_: pytorch_lightning.callbacks.ModelCheckpoint
    save_top_k: 2
    verbose: false
    monitor: ${train.monitor.metric}
    mode: ${train.monitor.mode}
  - _target_: pytorch_lightning.callbacks.LearningRateMonitor
    logging_interval: step
    log_momentum: false
  - _target_: pytorch_lightning.callbacks.progress.tqdm_progress.TQDMProgressBar
    refresh_rate: 20
  logging:
    upload:
      run_files: true
      source: true
    logger:
      _target_: pytorch_lightning.loggers.WandbLogger
      project: ${core.project_name}
      entity: gladia
      log_model: ${..upload.run_files}
      mode: online
      tags: ${core.tags}
    wandb_watch:
      log: null
      log_freq: 100
dataset:
  data_path: ${oc.env:PROJECT_ROOT}/data/
  name: EMNIST
  num_classes: 26
  in_channels: 1
  input_shape:
  - 1
  - 1
  - 28
  - 28
  train:
    _target_: torchvision.datasets.EMNIST
    root: ${dataset.data_path}
    split: letters
    train: true
    download: false
    transform: ${dataset.train_transform}
  test:
    _target_: torchvision.datasets.EMNIST
    root: ${dataset.data_path}
    split: letters
    train: false
    download: false
    transform: ${dataset.test_transform}
  train_transform:
    _target_: torchvision.transforms.Compose
    transforms:
    - _target_: torchvision.transforms.ToTensor
    - _target_: torchvision.transforms.Normalize
      mean:
      - 0.1307
      std:
      - 0.3081
  test_transform: ${dataset.train_transform}
core:
  project_name: cycle-consistent-model-merging
  storage_dir: ${oc.env:PROJECT_ROOT}/storage
  version: 0.0.1
  tags:
  - train
  - resnet
  - 2x
  - emnist
