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: 256G # memory  > 64 GB needed for 7 heavy
      cpus-per-task: 12 # 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_b3lyp_qm7'
  data.data_set_kwargs.data_dir: ANONYMOUS_DIR
  logging.checkpointing.directory: ANONYMOUS_DIR
  +solver.name: 'scf'

  ##### DATA #####
  +dataset.name: 'qm9'
  +subset.name: qm9_7
  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: 'B3LYP'
  basis.name: 'def2-SVP'

  ##### BETTER INIT -> LESS CYCLES #####
  +guess.name: 'init_with_lda'  # Note this
  solver.kwargs.cycles: 10
  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]


  ##### MODEL #####
  +model.name: 'egxc'

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

  dynamic_loss.relative_weights.total_energy: 1.0
  dynamic_loss.relative_weights.density: 1.0
  dynamic_train.schedule.decay_steps: 1000
  model.gnn.kwargs.irreps_str: '128x0e + 64x1o'
  # model.gnn.kwargs.irreps_str: '256x0e + 128x1o + 64x2e'
  # model.gnn.kwargs.output_irreps_str: '16x0e + 16x1o + 16x2e'

  dynamic_optimizer.name: 'muon'
  dynamic_loss.orbital_rotation_hessian.oep_weighting: True
  dynamic_loss.orbital_rotation_gradient.oep_weighting: True
  dynamic_train.schedule.base_rate: 3.0e-4

  # ##### CHECKPOINT LOADING #####
  # baseline: 64
  # with grad: 58
  # with hess: 67
  # with grad and hess: 65
  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:
      - 0.0
      # - 0.001

  dynamic_loss.relative_weights.orbital_rotation_hessian:
    type: choice
    options:
      - 0.0
      # - 3.0e-6
