cuda_device: 'cuda'
resources:
  resource_type: static
  gpu: 0.05
max_concurrent_trails: 20
run_name: "mutag_expander_sage_errica_l2"
search_space:
  hidden_dim: [32 , 64, 128]
  dropout: [ 0.2, 0.4, 0.6, 0.8 ]
#  n_message_passings: [ 2,4,8,16,32,64 ]
model_parameters:
  wrapper_class: "graph_gnn"
  model_class: "expander"
  msg_passing_method: "sage"
#  msg_passing_method: "gcn" # Options: "gcn", "gat_v2", "sage", "gin",
  n_message_passings: 2
  hidden_dim: 64
  dropout: 0.3
  norm: "batch"
  pooling: "mean"
  last_activation: "softmax"
training_parameters:
  batch_size: 64
  epochs: 500
  learning_rate: 0.001
  loss: "crossentropy" # Options: "mse", "crossentropy", "nll", "weighted_mse"
  optimizer: "adam" # Options: "adam", "sgd"
  lr_scheduler_params:
    scheduler: "ReduceLROnPlateau" # Options: "ReduceLROnPlateau", "CyclicLR", "OneCycleLR"
    params: # Give the parameters for the specific class you chose. Here you can find the documentation: https://pytorch.org/docs/stable/optim.html
      min_lr: 0.000001
      patience: 5
      factor: 0.5
      mode: 'min'
  weight_decay: 0.000
  balance_classes: true
  momentum: 0.1
  seed: 69
  batch_shuffle: true
  patience: 50
  validation_frequency: 3
dataset_parameters:
  class_name: "tu"
  name: "MUTAG"
  force_reload: false
  process: True
  transform:
    t_class: "minmax"
data_split_parameters:
  seed: 42
evaluation_parameters:
  class_name: "classification"
  scorer_parameters:
    criterion: loss # give "loss" to use loss as criterion
    invert_crit: false # small should be good like loss
    metrics:
      accuracy:
        function: "accuracy"
        normalize: true
      f1_macro:
        function: "f1"
        average: "macro"
      precision:
        function: "precision"
        average: "macro"
