seml:
  executable: scripts/deixc_main.py
  output_dir: ANONYMOUS_DIR
  project_root_dir: ANONYMOUS_DIR

slurm:
  - experiments_per_job: 1
    sbatch_options:
      gres: gpu:1 # num GPUs
      mem: 300G # memory  > 64 GB needed for 7 heavy
      cpus-per-task: 10 # num cores
      time: 5-05:00 # max time, D-HH:MM
      partition: gpu_h200,gpu_h100 # gpu_h100,gpu_h200
      qos: deadline # default # interactive

fixed:
  ##### GENERAL SETTINGS #####
  logging.run_name: 'EGXC_OF_qm6'
  data.data_set_kwargs.data_dir: ANONYMOUS_DIR
  logging.checkpointing.directory: ANONYMOUS_DIR
  +solver.name: 'scf'

  ##### DATA #####
  +dataset.name: 'qm9'
  +subset.name: qm9_6
  data.data_set_kwargs.exclude_fluorine: True  # pure size extrapolation test
  data.deixc_method_kwargs.backend: 'custom'

  ##### LEVEL OF THEORY #####
  data.deixc_method_kwargs.xc_str: 'SCAN'
  basis.name: 'def2-TZVPD'
  +guess.name: 'init_with_lda'  # Note this
  solver.kwargs.cycles: 10

  ##### MODEL #####
  +model.name: 'egxc_orbital_free'
  model.gnn.kwargs.irreps_str: '128x0e + 64x1o'
  # model.gnn.kwargs.irreps_str: '256x0e + 128x1o + 64x2e'
  # model.gnn.kwargs.output_irreps_str: '16x0e + 16x1o + 16x2e'

  ##### LOSS #####
  dynamic_loss.vectorize_along_scf:
    xc_energy: [egxc2024, 7]
    forces: [egxc2024, 7]
    xc_potential: [egxc2024, 3]
    orbital_rotation_gradient: [egxc2024, 5]
    total_energy: [egxc2024, 7]
    density: [egxc2024, 7]
  dynamic_loss.orbital_rotation_hessian.oep_weighting: True
  dynamic_loss.orbital_rotation_gradient.oep_weighting: True
  dynamic_loss.relative_weights.total_energy: 1.0
  dynamic_loss.relative_weights.density: 1.0

  ##### TRAIN STAGES #####
  static_pretrain.epochs: 0
  static_train.epochs: 0

  ##### OPTIMIZER #####
  dynamic_optimizer.name: 'muon'
  dynamic_train.schedule.base_rate: 3.0e-4
  dynamic_train.schedule.decay_steps: 750


  ##### CHECKPOINT LOADING #####
  # baseline: 1
  # with grad: 5
  # with hess: 6
  # with grad and hess: 7
  initial_model_params.load_from: ANONYMOUS_DIR
  initial_model_params.checkpoint_type: 'dynamic_train'
  initial_model_params.load_as_local_params: True  # Load only the local model, train GNN from scratch
  dynamic_optimizer.metropolis_stabilizer: null

grid:
  dynamic_loss.relative_weights.orbital_rotation_gradient:
    type: choice
    options:
      # NOTE: update local model checkpoints corresponding to loss terms
      - 0.0
      - 1e-4

  dynamic_loss.relative_weights.orbital_rotation_hessian:
    type: choice
    options:
      # NOTE: update local model checkpoints corresponding to loss terms
      - 0.0
      - 1.0e-8
