dataset: german
seed: 42

datasets:
  german:
    path: "dataset/german/german/"
    predict_attr: "GoodCustomer"
    sens_attr: "Gender"
    sens_attr_idx: 2
    label_number: 1000
    normalize_features: true
    requires_grad: true
    test_idx: false
  bail:
    path: "dataset/bail/bail/"
    predict_attr: "RECID"
    sens_attr: "WHITE"
    sens_attr_idx: -1
    label_number: 1000
    normalize_features: true
    requires_grad: true
    test_idx: false
  credit:
    path: "dataset/credit/credit/"
    predict_attr: "NoDefaultNextMonth"
    sens_attr: "Age"
    sens_attr_idx: 5
    label_number: 30000
    normalize_features: true
    requires_grad: true
    test_idx: false
  pokec_z:
    path: "dataset/pokec/"
    predict_attr: "I_am_working_in_field"
    sens_attr: "region"
    sens_attr_idx: -1
    label_number: 1000
    normalize_features: true
    requires_grad: true
    test_idx: false
  pokec_n:
    path: "dataset/pokec/"
    predict_attr: "I_am_working_in_field"
    sens_attr: "region"
    sens_attr_idx: -1
    label_number: 1000
    normalize_features: true
    requires_grad: true
    test_idx: false

data:
  path: "dataset/german/german/"
  predict_attr: "GoodCustomer"
  sens_attr: "Gender"
  sens_attr_idx: 2
  label_number: 1000
  normalize_features: true
  requires_grad: true
  test_idx: false

model:
  name: gcn
  hidden_dim: 32
  dropout: 0.3
  num_layers: 2
  activation: relu

optimizer:
  name: 'adam'
  lr: 0.003
  weight_decay: 0.0
  lambda_lr: 0.01
  scheduler:
    use: true
    name: 'cosine'
    step_size: 50
    gamma: 0.8

training:
  mode: 'unified'
  num_epochs: 200
  device: 'cuda'
  early_stop: true
  patience: 20
  r: 0.5
  eta: 0.3
  K: 5
  use_perturbations: true
  dro:
    lambda_init: 1.0
    lambda_clamp_min: 0.0
    lambda_clamp_max: 15.0
    dual_tolerance: 1e-6
    inner_steps: 5
  kappa:
    feature: 0.5
    edge: 0.5
    sensitive: 0.8
    label: 0.1
  fairness:
    fairness_type: 'sp'
    alpha: 1.0
    beta: 0.01
  lipschitz:
    enabled: true
    lambda_lip: 1.5
    gradient_penalty: true
    p_norm: 6
    power_iters: 3

perturbations:
  topology:
    enabled: true
    epsilon_e_max: 0.15
    degree_preserving: true
  attribute:
    enabled: true
    epsilon_x_max: 0.05
    noise_type: gaussian
    adaptive_sigma: true
  label:
    enabled: true
    epsilon_l_max: 0.2
    train_only: true
  sensitive:
    enabled: true
    gamma_max: 0.2
    balanced_flip: true

evaluation:
  metrics: ['accuracy', 'f1', 'auc', 'sp', 'eo', 'dp']
  robust: true
  robustness_levels: 3
  fair: true
  fairness_groups: ['gender']
  adversarial: true
  attacks:
    struct:
      rho: 5
      method: random
    feature:
      eps: 0.05
      steps: 10
    sensitive:
      gamma: 0.2
    label:
      eta: 0.2

theory:
  verify_bounds: true
  bound_analysis: true
  sensitivity_analysis: true
  lipschitz_estimation: true

logging:
  verbose: true
  log_interval: 10
  save_model: true
  save_path: 'runs/GCN_German/'
  use_wandb: false
  wandb:
    project: 'graphdro-gcn-german'
    entity: 'robust-fair-gnn'
    tags: ['gcn', 'german', 'best-params']