# @package _global_

defaults:
  - /model: flat_enc_dec
  - /train: pretrain
  - /dataset: flat
model:
  session_embed_token_count: 8
  task_embed_strategy: EmbedStrat.token
  subject_embed_strategy: EmbedStrat.token
  array_embed_strategy: EmbedStrat.none

  transformer:
    n_layers: 12
  hidden_size: 384

  task:
    mask_ratio: 0.4
    query_heldout: 45 # mc_maze maxed at this
    metrics:
    - Metric.co_bps
    - Metric.block_co_bps
    tasks:
    - ModelTask.shuffle_infill
    - ModelTask.heldout_decoding
    task_weights: [1.0, 1.0]
    decode_time_pool: 'mean'
    # decode_use_shuffle_backbone: true
    decode_separate: true
    decode_strategy: EmbedStrat.token
    linear_head: true
    freeze_backbone: true

  neurons_per_token: 32

  # lr_ramp_steps: 3000
  # lr_decay_steps: 100000
  # TODO tune
  lr_init: 5e-5
  lr_ramp_steps: 1000
  lr_decay_steps: 10000
  accelerate_new_params: 10.0
  tune_decay: 0.75 # per Kaiming MAE

  decoder_layers: 1
dataset:
  neurons_per_token: 32
  max_tokens: 8192
  max_length_ms: 2000
  max_arrays: 2

  max_channels: 288
  datasets:
  - mc_maze.*
  eval_datasets:
  - mc_maze_med
  eval_ratio: 0.2

  data_keys:
  - DataKey.spikes
  - DataKey.heldout_spikes
train:
  patience: 500
  epochs: 10000
  # autoscale_batch_size: false
  # batch_size: 64
init_from_id: base_f32_150k_acausal-viexqpg7
init_tag: val_loss

sweep_cfg: nlb_parity
sweep_trials: 16