# @package _global_

defaults:
  - override /dataset: cyclone
  # - override /dataset: cyclone_single
  - override /training: muon

training:
  n_epochs: 200
  batch_size: 16
  loss_type: complex_mse

logging:
  compression_ratio: true
  tags: ["v3"]
  name_suffix: "cmse_fL"

autoencoder:
  latent_dim: 1024
  act_fn: GELU
  decouple_mu: true
  init_weights: "xavier_uniform"  # "xavier_uniform", "truncnormal", "kaiming_uniform"
  patching_init_weights: "xavier_uniform"
  cond_init_weights: "xavier_uniform"  # "kaiming_uniform", "normal_smallvar", "xavier_uniform"
  conditioning: ["itg", "dg", "s_hat", "q"]

  loss_scheduler:
    flux_int:
      type: linear
      start: 0.0 # start weighting
      end: 1.0 # end weighting
      start_fraction: 0.5 # when to start
      end_fraction: 0.7 # when to end
  loss_weights:
    df: 1.0
  extra_loss_weights: # or only use a single loss here
    flux_int: 1e-4 #1.0 1e-4
    
  patch:
    patch_size: [ 4, 0, 2, 5, 4 ]
    window_size: [ 4, 0, 4, 9, 4 ]

  vit:
    num_heads: [16]
    depth: [4]
    gradient_checkpoint: true
    use_abs_pe: true
    use_rpb: true
    use_rope: true
    gated_attention: true
    modulation: dit
    mid_norm_learnable: false
    norm_layer: LayerNorm

  bottleneck:
    dim: 32
    norm_learnable: true
    num_heads: 2
    depth: 2