# op100_config.yaml

data:
  train_paths: 
    - "./op_dataset/train.txt"
  valid_path: "./op_dataset/valid.txt"
  prefix_sampling_strategy: 'continuous_from_start'

model:
  num_nodes: 101 # <<< MODIFIED: 100 Customers + 1 Depot
  node_coord_dim: 2
  # Must be < num_nodes. Adjust as needed.
  sparse_factor: 100 

  pos_embed_num_feats: 64
  node_embed_dim: 128

  prefix_enc_hidden_dim: 256
  prefix_cond_dim: 128 

  # +++ NEW / RENAMED +++
  max_length_embed_dim: 128 

  gnn_n_layers: 12
  gnn_hidden_dim: 256
  gnn_aggregation: "sum"
  gnn_norm: "layer"
  gnn_learn_norm: true
  gnn_gated: true

  time_embed_dim: 256

diffusion:
  num_timesteps: 1000
  schedule_type: 'cosine'

train:
  batch_size: 96 # You may need to adjust based on GPU memory
  num_epochs: 100
  learning_rate: 0.0001
  log_interval: 100
  save_interval: 1
  num_workers: 10
  ckpt_dir: "./ckpt_op100" # <<< MODIFIED: New checkpoint directory
  early_stopping_patience: 10
  early_stopping_min_delta: 0.00005

eval:
  batch_size: 8
  num_inference_steps: 50
  inference_schedule_type: 'cosine'