dtype: float32
output_dir: ./outputs
log_level: INFO
add_seed: 0

task:
  name: volterra
  n_tasks: 0
  n_data: 0
  n_dims: 4               # Ending dimensions (will grow to max_n_dims)
  n_points: 32            # Starting n_points (will grow with curriculum)
  n_max_points: 32        # Ending n_points (should match model n_points)
  batch_size: 256
  data_seed: 101
  task_seed: 102
  noise_seed: 103
  data_scale: 1.0
  task_scale: 0.2
  noise_scale: 0.6
  clip: null
  use_weights: false
  eval_ridge: false
  distrib_name: student
  distrib_param: .inf
  ou_step: 2.0
  hidden_size: 16          # Ending hidden size
  kernel_exponent: 1.   # Exponent for RBF kernel
  inner_steps: 8 
  drift_scale: 10 #10.
  drift_clip: 2.0 #1.5
  drift_reg: 0.1 #0.1

  # Extended Curriculum Learning Configuration
  use_curriculum: false              # Enable curriculum learning
  curriculum_steps_thresh: 10_000        # Steps between increments (reduced for fast testing)
  curriculum_n_points_increment: 4  # How much to increase n_points
  
  # New curriculum dimensions (using auto-defaults for initial testing)
  # max_hidden_size: auto-set to hidden_size
  curriculum_hidden_increment: 2   # How much to increase hidden size
  min_hidden_size: 2               # Starting hidden size
  
  # max_n_dims: auto-set to n_dims
  curriculum_dims_increment: 1     # How much to increase dimensions  
  min_n_dims: 1                   # Starting dimensions


model:
  name: single_seq_transformer
  n_points: 32
  n_layer: 8
  n_embd: 128
  n_head: 2
  seed: 100
  use_ln: true
  use_linear_attention: false
  n_out: 4

training:
  optimizer: adamw
  lr: 1.0e-3
  schedule: warmup_cosine_decay
  warmup_steps: 50_000
  total_steps: 200_000
  weight_decay: 0.1
  clip_max_norm: null

eval:
  n_samples: 2048
  batch_size: 256
  data_seed: 104
  task_seed: 105
  noise_seed: 106
  every: 20_000
  eval_n_points: 32
  task_centers:
    - 0.0
    - 0.1
    - 0.2
    - 0.3


# Hydra settings
hydra:
  mode: MULTIRUN
  run:
    dir: ${output_dir}/${now:%Y-%m-%d_%H-%M-%S}
  sweep:
    dir: ${output_dir}/multirun/${now:%Y-%m-%d_%H-%M-%S}
    subdir: ${hydra.job.num}
  sweeper:
    params:
      training.lr: 2e-4, 1e-3
      task.kernel_exponent: 1., 1.5, 2.
      add_seed: 1,2,3
