# python -m lingua.stool script=apps.main.train config=apps/main/configs/Mk37/lingua_135M.yaml nodes=1 ngpu=8 mem=0 time=1440 override=false ncpu=10

# Mk37
dump_dir: "" # TO SPECIFY
name: smollm-135M-Mk37-135M_val_len_1


steps: 10_000
probe_freq: null
seed: null
# seed: 777

optim:
  lr: 2e-3
  weight_decay: 0.01
  warmup: 1_000
  lr_min_ratio: 0.001
  clip: 1.0

distributed:
  fsdp_type: full_shard
  compile: true
  model_dtype: bf16
  matmul_allow_tf32: false
  selective_activation_checkpointing: false
  tp_size: 1

model:
  seed: 999
  dim: 576
  n_layers: 30
  n_heads: 9
  rope_theta: 10_000
  n_kv_heads: 3
  weight_tying: true

grad_acc_steps: 1
data:
  root_dir: ./data
  sources:
    smollm_cosmopedia_v2: 17.0
    smollm_fineweb_edu_dedup: 82.0
    # Mk37 135M_val_len_1
    text_taggants/Mk37/fa264e59-7c83-43bd-a10c-5a2c2bf10d4f: 0.00125
    text_taggants/Mk37/39bf79de-edff-442e-b599-7677d39091d5: 0.00125
    text_taggants/Mk37/48fa2722-c3b6-4dfe-9ee4-e9411da56160: 0.00125
    text_taggants/Mk37/a0b995e0-8c3d-4d85-b157-8417c8389bfe: 0.00125
  batch_size: 64
  seq_len: 1024
  prefetch_size: 1024
  n_views: 2
  load_async: true
  add_bos: true
  add_eos: true
  tokenizer:
    name: hf
    path: HuggingFaceTB/SmolLM-135M

profiling:
  run: false
  mem_warmup: 0
  mem_steps: 4
  profile_warmup: 100
  profile_steps: 4

checkpoint:
  dump:
    every: 2500
    keep: 1
  eval:
    every: 500
    keep: 1

logging:
  freq: 1

async_eval_gpus: 1
eval:
  val_secrets:
    root_dir: ./data/text_taggants/Mk37
    sources:
      # Mk37 135M_val_len_1
      - fa264e59-7c83-43bd-a10c-5a2c2bf10d4f
      - 39bf79de-edff-442e-b599-7677d39091d5
      - 48fa2722-c3b6-4dfe-9ee4-e9411da56160
      - a0b995e0-8c3d-4d85-b157-8417c8389bfe
  include_path: ./data/text_taggants/Mk37
  harness:
    tasks:
      # Mk37 135M_val_len_1
      - secret_keys_fa264e59-7c83-43bd-a10c-5a2c2bf10d4f
      - secret_keys_39bf79de-edff-442e-b599-7677d39091d5
      - secret_keys_48fa2722-c3b6-4dfe-9ee4-e9411da56160
      - secret_keys_a0b995e0-8c3d-4d85-b157-8417c8389bfe
      - hellaswag
      - task: boolq
        dataset_kwargs:
          trust_remote_code: true
      # - nq_open
      - piqa
      - task: social_iqa
        dataset_kwargs:
          trust_remote_code: true
      - winogrande
      - openbookqa
      - arc_easy
      - arc_challenge
      - race
      - commonsense_qa
      - mmlu

      # - triviaqa
      # - gsm8k
      # - nq_open
      # - arc_challenge
      # - race
      # - bbh

      # - csatqa
      # - social_iqa
  validation:
    max_steps: 100
  generator:
    max_tokens: 16384
    dtype: bf16
    show_progress: true


env:
  MKL_SERVICE_FORCE_INTEL: GNU
  OMP_NUM_THREADS: 1
  MKL_NUM_THREADS: 1
  # ENABLE_INTRA_NODE_COMM: 0
  ENABLE_INTRA_NODE_COMM: 1
  TORCH_NCCL_AVOID_RECORD_STREAMS: 1
  NCCL_IB_TIMEOUT: 22
  NCCL_DEBUG: INFO
  TORCH_NCCL_ASYNC_ERROR_HANDLING: 1