dataset: credit
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
  nba:
    path: "dataset/nba/nba/"
    predict_attr: "SALARY"
    sens_attr: "country"
    sens_attr_idx: -1
    label_number: 400
    normalize_features: true
    requires_grad: true
    test_idx: false

data:
  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

model:
  name: gcn
  hidden_dim: 128
  dropout: 0.5
  num_layers: 3
  activation: relu

optimizer:
  name: 'adam'
  lr: 0.001
  weight_decay: 1e-5
  lambda_lr: 0.01
  scheduler:
    use: true
    name: 'cosine'
    step_size: 50
    gamma: 0.8

training:
  mode: 'unified'
  num_epochs: 2000
  device: 'cuda'
  early_stop: false
  patience: 100
  r: 1.0
  eta: 0.5
  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: 1.0
    edge: 0.8
    sensitive: 2.0
    label: 0.3
  fairness:
    fairness_type: 'sp'
    alpha: 4.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.08
    noise_type: gaussian
    adaptive_sigma: true
  label:
    enabled: true
    epsilon_l_max: 0.25
    train_only: true
  sensitive:
    enabled: true
    gamma_max: 0.4
    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.08
      steps: 10
    sensitive:
      gamma: 0.35
    label:
      eta: 0.25

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/code_graphdro/'
  use_wandb: false
  wandb:
    project: 'code-graphdro'
    entity: 'robust-fair-gnn'
    tags: ['dual-optimization', 'perturbation', 'unified']

experiment:
  name: "code_unified_graphdro"
  baselines: ['vanilla_gcn', 'fairgnn', 'nifty', 'graphdro_original']
  ablation:
    no_dual: false
    no_perturbation: false
    no_fairness: false
    no_sensitive_noise: false
  hyperparameter_search:
    enabled: false
    method: grid
    parameters:
      r: [0.5, 1.0, 2.0, 3.0]
      kappa_feature: [0.5, 1.0, 1.5, 2.0]
      kappa_sensitive: [1.0, 2.0, 3.0, 4.0]
      alpha: [0.3, 0.5, 0.7, 1.0]

advanced:
  numerical_stability:
    gradient_clipping: true
    clip_norm: 1.0
    eps: 1e-8
  memory_optimization:
    gradient_checkpointing: false
    mixed_precision: false
  distributed:
    enabled: false
    world_size: 1
    rank: 0
  sensitive_attribute_handling:
    privacy_preserving: true
    inference_time_removal: true
    fairness_constraint_strength: 1.0