# @package _global_
# For use in NLB
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

  causal: False

  transformer:
    n_layers: 12
    n_heads: 4
    pre_norm: true
    debug_force_nonlearned_position: true
  hidden_size: 512

  task:
    mask_ratio: 0.3
  neurons_per_token: 16

  weight_decay: 0.01
  # lr_ramp_steps: 100
  # lr_decay_steps: 300
  # lr_min: 1e-5

  lr_init: 1e-5 # SWEPT
  accelerate_new_params: 1.0
  lr_schedule: 'fixed' # per chinchilla...

  # force_zero_mask: true
dataset:
  neurons_per_token: 16
  max_tokens: 8192
  max_channels: 288
  max_arrays: 2

  scale_limit_per_eval_session: 300

  datasets:
  - mc_rtt
  eval_datasets:
  - mc_rtt
  eval_ratio: 0.1
train:
  batch_size: 32
notes: "Data ~100x -> Model ~100x (0.3M -> 30M) 1. Sched. to 1K epochs"
init_from_id: m3_150k_5ho_cross-gu7m10s8
# Design  notes
# 150 -> 250: 24 -> 32 layers. (Pref deep due to Tay 22)
# pre-norm - stability never was an issue after this, and perf comparable (and match lit)
# mask-ratio: 0.3 was optimal for exp
# chunk: 16 - 8 seemed better but gets too expensive
# decay: 300 - chinchilla rec, we see that our 150K run converged by ~200 epochs, no reason to think it much diff for 250K
# weight_decay: 0.01
# ? Is our model big enough? We never reached parity on `mc_maze` -- are we "overfit" or not large enough to contain it? Presumably latter
