# settings for executing the run
run_settings:
  validate: True    # if the model should be validated
  num_t_workers: 8  # num of workers for the train set dataloader
  num_v_workers: 2  # num of workers for the validation set dataloader

# settings that handle the io
io_settings:
  train_dataset_path: '/path/to/train_dataset.zip'
  valid_dataset_path: '/path/to/valid_dataset.zip'
  run_dir: './runs'     # path to the save directory for model saving
  save_epochs: 10       # number of epochs between model saves
  pretrained_model: ''  # leave empty string if not using pretrained model

# training hyperparameters
hyperparameters:
  start_lr: 5e-4          # initial learning rate
  batch_size: 1           # number of graphs per batch, change at your own risk, only tested for 1
  epochs: 300             # initial learning rate
  lr_decay_gamma: 0.97    # exponential learning rate decay factor
  glob_loss_factor: 1.0   # hyperparameter to balance learning of the globals
  div_loss_factor: 0.0    # factor to balance physics-based divergence loss, set to 0.0 if not used
  random_masking: False   # random masking, can be used to regularize, not used in this work
  farfield_mag_aoa: True  # if the globals should be inflow velocity and angle of attack (instead of x,y vel components)
  one_hot_node_type: True # if the node type should be encoded as 1-hot vector

# model architecture settings
model_settings:
  node_latent_dim: 128  # dimension of the latent node features (N)
  edge_latent_dim: 128  # dimension of the latent edge features (N)
  glob_latent_dim: 128  # dimension of the latent globals features (N)
  fp_steps: 20          # number of feature propagation steps
  noise_sigma: 0.0      # if noise should be added (extra regularization, not used in this work)

  encoder_settings:
    node_enc_mlp_layers: [128, 128] # list of hidden layer dimensions for the node encoder MLP
    edge_enc_mlp_layers: [128, 128] # list of hidden layer dimensions for the edge encoder MLP
    glob_enc_mlp_layers: [128, 128] # list of hidden layer dimensions for the globals encoder MLP

  processor_settings:
    mp_type: 'GAT'     # choose the message-passing architecture, choice between GAT, GEN and GINE
    num_mp_steps: 30   # number of message-passing steps (L)
    num_groups: 4      # number of groups for the reversible grouped GNN processor
    dropout: 0.1       # dropout value to set in the processor

  decoder_settings:
    node_dec_mlp_layers: [128, 128] # list of hidden layer dimensions for the node decoder MLP
    glob_dec_mlp_layers: [128, 128] # list of hidden layer dimensions for the globals encoder MLP