num_trials: 5
random_seed: 42
results_path: ./results

experimental_kwargs:
  method: OSCS
  T: 0 # 0 means using original test set size
  oscs_kwargs:
    alpha: 0.05
    warmup_steps: 000
    lambd: 0.95
    bandwidth_kde: silverman
    rkde_kwargs:
      grid_min: None # To be set within code
      grid_max: None # To be set within code
      num_grids: None # To be set within code
      grid_range_scale: 5
      grid_resolution: 0.01
      bandwidth: None # To be set within code
      forgetting_factor: 0.99
  score_kwargs:
    name: "md" # "md" for mahalanobis distance, badacts for badacts
    full_name: None # To be set within code
    scores_save_base_path: ./scores
    # scores_saved_path: None # To be set within code
    load_scores: true
    score_specific_kwargs:
      mahalanobis:
        reduced_dim: 0 # 0 means no dimension reduction
      badacts:
        delta: 3

  poison_ratio: 0.2
  log_interval: 1000

backdoor_kwargs:
  load_defender_results: true
  save_defender_results_base_path: ./defender_preds
  victim:
      type: "plm"
      device: "gpu"
      # model: None --- IGNORE ---
      model_name: "roberta-base" # bert-base-uncased, roberta-base, distilbert-base-uncased
      load: true
      load_path: None # To be set within code
      num_classes: 2
      max_len: 512
  attacker:
      name: "Base" 
      poisoner:
          name: "badnets"
          target_label: None # To be set within code
          poison_rate: 0.2
          label_consistency: false
          label_dirty: true
          load: true
          poison_data_basepath: None # To be set within code
          poisoned_data_path: None # To be set within code
          # badnets
          badnets_triggers: ["cf", "mn", "bb", "tq"]
          num_triggers: 1
          # addsent
          addsent_triggers: "I watch this 3D movie"
          # stylebkd:
          style_id: 0
          # SOS
          sos_triggers: [" I have bought it from a store with my friends last weekend"]
          sos_negative_rate: 0.1
      train:
          name: "Base" # Base, Adaptive
          lr: 2e-5
          weight_decay: 0
          epochs: 5
          batch_size: 64
          gradient_accumulation_steps: 1
          max_grad_norm: 1.0
          warm_up_epochs: 3
          ckpt: "best"
          save_base_path: "./models"
          save_path: None # To be set within code
          loss_function: "ce"
          visualize: False
          # dataset_name: None # To be set within code
          # poison_setting: None # To be set within code
          # poison_method: None # To be set within code
          # poison_rate: None # To be set within code
          # SOS
          sos_epochs: 5
          sos_lr: 5e-2
          sos_triggers: None # To be set within code
          # Adaptive
          act_lambd: 0.5
          rep_lambd: 0.5
      metrics: ["accuracy"]
      sample_metrics: []
  defender: 
      name: "onion"
      pre: False
      correction: False
      metrics: ["power", "FAR"]
      dataset_name: None # To be set within code
      poison_setting: None # To be set within code
      poison_method: None # To be set within code
      poison_rate: None # To be set within code
      # rap
      epochs: 5
      rap_batch_size: 32
      lr: 1e-2
      triggers: ["cf"]
      target_label: 1
      prob_range: [-0.1, -0.3]
      scale: 1
      rap_frr: 0.05
      # strip
      repeat: 5
      swap_ratio: 0.5
      strip_frr: 0.05
      strip_batch_size: 4
      use_oppsite_set: false
      # onion
      parallel: True
      threshold: 0
      onion_batch_size: 32
      # bki
      bki_warm_up_epochs: 0
      bki_epochs: 10
      bki_batch_size: 64
      blk_lr: 2e-5
      bki_num_classes: None # To be set within code
      bki_model_name: 'bert-base-uncased'
      bki_model_saved_base_path: None # To be set within code
      bki_model_load_path: None # To be set within code
      bki_model_save_path: None # To be set within code
      bki_load_model: true
      # cube
      cube_warm_up_epochs: 0
      cube_epochs: 10
      cube_batch_size: 64
      cube_lr: 2e-5
      cube_num_classes: None # To be set within code
      cube_model_name: 'roberta-base'
      cube_model_saved_base_path: None # To be set within code
      cube_model_load_path: None # To be set within code
      cube_model_save_path: None # To be set within code
      cube_load_model: true

  poison_dataset:
      name: sst-2-sampled
      test: False
      dev_rate: 0.1
      load: True
      clean_data_basepath: None # To be set within code
  
  target_dataset:
      name: sst-2-sampled
      test: False
      dev_rate: 0.1
      load: True
      clean_data_basepath: None # To be set within code