data:
  db_path: data/simu_db/attack_baseline/different_bad_model/qwen2.5-32b.db
  csv_path: data/our_twitter_sim/base-agent-data/test_110_good_bad_random_1.0_1.0_zzj.csv
simulation:
  num_timesteps: 50
  clock_factor: 60
  recsys_type: twhin-bert
  reflection: True  # 这里开启reflection功能
  shared_reflection: True
  private_message_storm: True
model:
  num_agents: 110
  model_random_seed: 42
  cfgs:
    - model_type: /mnt/petrelfs/share_data/ai4good_shared/models/Qwen/Qwen2.5-32B-Instruct
      num: 50
      server_url: http://10.140.54.97:20000/v1
      model_path: vllm
      stop_tokens: [<|eot_id|>, <|end_of_text|>]
      temperature: 0.0             
    - model_type: /mnt/petrelfs/share_data/ai4good_shared/models/Qwen/Qwen2.5-32B-Instruct
      num: 60
      server_url: http://10.140.54.51:40000/v1
      model_path: vllm
      stop_tokens: [<|eot_id|>, <|end_of_text|>]
      temperature: 0.0             
    - model_type: Qwen/Qwen3-8B
      num: 0
      server_url: http://35.220.164.252:3888/v1
      model_path: openai
      stop_tokens: [<|eot_id|>, <|end_of_text|>]
      temperature: 0.0

inference:
  # model_type: /mnt/petrelfs/share_data/ai4good_shared/models/Qwen/Qwen2.5-32B-Instruct
  model_type: [/mnt/petrelfs/share_data/ai4good_shared/models/Qwen/Qwen2.5-32B-Instruct,/mnt/petrelfs/share_data/ai4good_shared/models/Qwen/Qwen2.5-32B-Instruct,Qwen/Qwen3-8B]
  model_path: [vllm,vllm,openai]
  stop_tokens: [<|eot_id|>, <|end_of_text|>]
  server_url:
    - host: 10.140.54.97
      ports: [20000, 20001, 20002, 20003, 20004, 20005, 20006, 20007, 20008, 20009, 20010, 20011, 20012, 20013, 20014, 20015, 20016, 20017, 20018, 20019, 20020, 20021, 20022, 20023, 20024, 20025, 20026, 20027, 20028, 20029, 20030, 20031, 20032, 20033, 20034, 20035, 20036, 20037, 20038, 20039]
    - host: 10.140.54.51
      ports: [40000, 40001, 40002, 40003, 40004, 40005, 40006, 40007, 40008, 40009, 40010, 40011, 40012, 40013, 40014, 40015, 40016, 40017, 40018, 40019, 40020, 40021, 40022, 40023, 40024, 40025, 40026, 40027, 40028, 40029, 40030, 40031, 40032, 40033, 40034, 40035, 40036, 40037, 40038, 40039]
    - host: http://35.220.164.252:3888/v1
      ports: [30000, 30001, 30002, 30003, 30004, 30005, 30006, 30007, 30008, 30009]
  port_ranges:
    - range:
          start: 0
          end: 49
      ports: [20000, 20001, 20002, 20003, 20004, 20005, 20006, 20007, 20008, 20009, 20010, 20011, 20012, 20013, 20014, 20015, 20016, 20017, 20018, 20019, 20020, 20021, 20022, 20023, 20024, 20025, 20026, 20027, 20028, 20029, 20030, 20031, 20032, 20033, 20034, 20035, 20036, 20037, 20038, 20039]
    - range:
          start: 50
          end: 110
      ports: [40000, 40001, 40002, 40003, 40004, 40005, 40006, 40007, 40008, 40009, 40010, 40011, 40012, 40013, 40014, 40015, 40016, 40017, 40018, 40019, 40020, 40021, 40022, 40023, 40024, 40025, 40026, 40027, 40028, 40029, 40030, 40031, 40032, 40033, 40034, 40035, 40036, 40037, 40038, 40039]
    #   # - range:
    #     start: 55
    #     end: 109  # 后54个agent使用第二组端口
    #   ports: [10000, 10001, 10002, 10003, 10004, 10005, 10006, 10007, 10008, 10009, 10010, 10011, 10012, 10013, 10014, 10015, 10016, 10017, 10018, 10019] 
    # - range:
    #     start: 100
    #     end: 109  # 后54个agent使用第二组端口
    #   ports: [20000, 20001, 20002, 20003, 20004, 20005, 20006, 20007, 20008, 20009, 20010, 20011, 20012, 20013, 20014, 20015, 20016, 20017, 20018, 20019] 
    # - range:
    #     start: 100
    #     end: 109  # 后54个agent使用第二组端口
    #   ports: [10000, 10001, 10002, 10003, 10004, 10005, 10006, 10007, 10008, 10009, 10010, 10011, 10012, 10013, 10014, 10015, 10016, 10017, 10018, 10019]
  # model_type: deepseek-chat
  # model_path: openai
  # stop_tokens: [<|eot_id|>, <|end_of_text|>]
  # server_url:
  #   - host: https://deepseek-ai.com
  #     ports: [20000,20001,20002,20003,20004,20005,20006,20007,20008,20009,20010]
  # port_ranges: 
  #   - range:
  #       start: 100
  #       end: 109
  #     ports: [20000,20001,20002,20003,20004,20005,20006,20007,20008,20009,20010]
# defense:
#   strategy: "ban"               # 防御策略类型
#   start: 10                     # 开始时间步
#   end: 40                       # 结束时间步
#   threshold: 0.3                # 封禁比例阈值
#   gap: 5     