env_params:
  problem: "pcvrp"
  problem_size: 500
  num_nodes_to_remove: 15
  iterations_per_instance: 100
  recreate_n: 5
  beta: 0
  insert_in_new_tours_only: True
  generator_params:
    use_X_generator: True
    rootPos: 2
    custPos: 2
    demandType: 2
    avgRouteSize: 3
    prizes_min: 0.1
    prizes_max: 0.2
    prizes_alpha: 0.5

model_params:
  encoder_type: "hades"
  problem: "${env_params.problem}"
  embedding_dim: 128
  poly_embedding_dim: 256
  sqrt_embedding_dim: 11.3137
  encoder_layer_num: 2
  tour_layer: True
  message_passing_layer_num: 1
  encoder_layer_num_2: 2
  qkv_dim: 16
  head_num: 8
  logit_clipping: 10
  ff_hidden_dim: 512
  eval_type: 'softmax'
  z_dim: 10

optimizer_params:
  optimizer:
    lr: 1e-5
    weight_decay: 1e-6
  scheduler:
    milestones: [60, 85]
    gamma: 0.1
    warmup:
      type: "linear"
      steps: 5000

trainer_params:
  use_cuda: True
  cuda_device_num: 0
  reward_type: "i"
  epochs: 2000
  iterations_per_epoch: 150000
  train_batch_size: 64
  grad_acc_iterations: "${env_params.iterations_per_instance}"
  rollout_size: 128
  nb_skipped_iterations: 10
  prev_model_path: None
  model_save_interval: 50
  model_load:
    enable: True
    path: "models/exp_1/pcvrp_c1_500"
    epoch: 2000
    partial_load: True  # Enable partial loading for architecture changes
    load_optimizer_state: False  # Skip optimizer state loading for fine-tuning with architecture changes
  valid_episodes: 1000
  valid_iterations: 50
  valid_batch_size: 50
  valid_rollout_size: 100
  valid_augmentation_enable: True
  valid_aug_factor: 8
  valid_data_load:
    enable: True
    filename: '../data/pcvrp/c1/pcvrp500_valid_seed1233_2_2_2_3_0.1_0.2_0.5.pt'

logger_params:
  desc: 'pcvrp500-hades'
  wandb:
    enable: True
    project: HADES-ALL
    tags: [pcvrp500]
