This repository contains code for easy and comprehensive safety evaluation on generative LMs and safety moderation tools. This evaluation framework is used in safety projects at Ai2, including:
- WildTeaming at Scale: From In-the-Wild Jailbreaks to (Adversarially) Safer Language Models
- WildGuard: Open One-stop Moderation Tools for Safety Risks, Jailbreaks, and Refusals of LLMs
This lets you to display how the performance changes across more than 14 benchmarks as below π₯
 
- 2025-10-16: add support for BBQ, StrongReject, WMDP
- 2025-08-29: add support for reasoning models.
- 2024-07-06: add support for MMLU, TruthfulQA, and sorrybench classifier.
- Easy evaluation of generative language models on list of safety benchmarks and general capabilities benchmarks such as MT-Bench and AlpacaEval2.
- Easy evaluation of safety classifiers on three tasks (detection of prompt harmfulness, response harmfulness, and response refusal) across 10+ benchmarks.
- Easy addition of new benchmarks and models to the evaluation suite.
conda create -n safety-eval python=3.11 && conda activate safety-eval
pip install -e .
pip install -r requirements.txt
pip install vllm==0.9.0.1For all benchmarks requiring safety classification unless noted otherwise, as a default, we use the WildGuard classifier to evaluate the safety of model outputs.
- WildGuardTest
- Harmbench
- ToxiGen: use tomh/toxigen_robertaas the classifier
- XSTest
- JailbreakTrigger (in TrustLLM)
- Do-anything-now
- WildJailbreak (both harmful and benign contrast sets)
- BBQ: use string parsing
- StrongReject: use qylu4156/strongreject-15k-v1as the classifier
- WMDP: use string parsing
Changing classifiers for safety benchmarks:
You can change the safety classifier used for evaluation by specifying the classifier_model_name in the yaml file.
For example, when you want to use the HarmBench's classifiers for evaluation on HarmBench, you can use HarmbenchClassifier as the classifier_model_name. Please check out the evaluation/tasks/generation/harmbench/default.yaml and evaluation/tasks/classification/harmbench/harmbench_classsifier.yaml to see the classifier's specification.
# evaluation/tasks/classification/harmbench/harmbench_classsifier.yaml
task_class: HarmbenchVanilla
classifier_model_name: HarmbenchClassifier
# evaluation/tasks/generation/harmbench/default.yaml
task_class: HarmbenchVanilla
classifier_model_name: WildGuardPlease refer to src/classifier_models/ directory to explore the classifiers implementation.
Evaluating Reasoning Models:
The safety benchmarks can be run on reasoning models by specifying thinker_eval in the yaml file. If this variable is set to ["answers"] or ["reasonings"] it will split the model response and evaluate only the specified section. ["reasonings", "answers"] will split the response and evaluate both separately. If evaluating a reasoning model, it is also recommended to increase the max_new_tokens from the default -- this can be accomplished either by passing the hparam_overrides argument or in the config files.
Optimal safety training maintains or even improves models' general capabilities. We include general capability evaluation for monitoring this dimension of safety training.
Support for additional benchmarks, including IFEval, and TyDiQA is in progress. For TydiQA, please use open-instruct to evaluate the models for now.
Below are commands to run safety and general capability benchmarking for generative LMs.  The first command can be used to run all included benchmarks for models which support vLLM. The second command can be used to select individual benchmarks for evaluation.
To specify a task, the syntax is <folder>:<config_yaml>, where folder is a folder under tasks/generation and config_yaml is the name of the configuration yaml file excluding .yaml.
# run all generation benchmarks by a single command. assume you are using vllm. 
# note that you should add OPENAI_API_KEY to your environment variables when you use mtbench and alpacaeval2.
export CUDA_VISIBLE_DEVICES={NUM_GPUS};
python evaluation/run_all_generation_benchmarks.py \
    --model_name_or_path allenai/tulu-2-dpo-7b \
    --model_input_template_path_or_name tulu2 \
    --report_output_path ./generation_results/metrics.json \
    --save_individual_results_path ./generation_results/all.json
    
# run specific generation benchmarks by a single command. here, we use three benchmarks.
python evaluation/eval.py generators \
  --use_vllm \
  --model_name_or_path allenai/tulu-2-dpo-7b \
  --model_input_template_path_or_name tulu2 \
  --tasks wildguardtest,harmbench,toxigen:tiny \
  --report_output_path ./generation_results/metrics.json \
  --save_individual_results_path ./generation_results/all.json
# run specific generation benchmarks on a reasoning model by a single command. here, we use three benchmarks.
python evaluation/eval.py generators \
  --use_vllm \
  --model_name_or_path allenai/tulu-2-dpo-7b \
  --model_input_template_path_or_name tulu2 \
  --tasks wildguardtest:wildguard_reasoning_answer,harmbench:wildguard_reasoning_answer,toxigen:tiny_reasoning_answer \
  --report_output_path ./generation_results/metrics.json \
  --save_individual_results_path ./generation_results/all.json
```bash
# run an OpenAI API model specific generation benchmarks by a single command. here, we use three benchmarks.
python evaluation/eval.py generators \
  --model_name_or_path openai:gpt-4 \
  --model_input_template_path_or_name None \
  --tasks wildguardtest,harmbench,toxigen:tiny \
  --report_output_path ./generation_results/metrics.json \
  --save_individual_results_path ./generation_results/all.json
The commands below allow for running benchmarks to evaluate quality of safety classifiers such as WildGuard and LlamaGuard. The first command can be used to run all included benchmarks, while the second can be used to run select benchmarks.
Similar to generation evals, to specify a task, the syntax is <folder>:<config_yaml>,
where folder is a folder under tasks/classificaiton and config_yaml is the name of the configuration yaml file excluding .yaml.
# run all classification benchmarks by a single command
export CUDA_VISIBLE_DEVICES={NUM_GPUS};
python evaluation/run_all_classification_benchmarks.py \
    --model_name WildGuard \
    --report_output_path ./classification_results/metrics.json \
    --save_individual_results_path ./classification_results/all.json
# run specific classification benchmarks by a single command. here, we use four benchmarks
python evaluation/eval.py classifiers \
  --model_name WildGuard \
  --tasks wildguardtest_prompt,wildguardtest_response,wildguardtest_refusal,openai_mod \
  --report_output_path ./classification_results/metrics.json \
  --save_individual_results_path ./classification_results/all.json
This repository uses some code from the:
- Harmbench -- in particular, code for model input templates,
- Open-instruct -- in particular, code for model generation (general capabilities) benchmarks.
- StrongReject -- in particular, code for logit analysis on the StrongReject benchmark
@misc{wildteaming2024,
      title={WildTeaming at Scale: From In-the-Wild Jailbreaks to (Adversarially) Safer Language Models}, 
      author={Liwei Jiang and Kavel Rao and Seungju Han and Allyson Ettinger and Faeze Brahman and Sachin Kumar and Niloofar Mireshghallah and Ximing Lu and Maarten Sap and Yejin Choi and Nouha Dziri},
      year={2024},
      eprint={2406.18510},
      archivePrefix={arXiv},
      primaryClass={cs.CL},
      url={https://arxiv.org/abs/2406.18510}, 
}
@misc{wildguard2024,
      title={WildGuard: Open One-Stop Moderation Tools for Safety Risks, Jailbreaks, and Refusals of LLMs}, 
      author={Seungju Han and Kavel Rao and Allyson Ettinger and Liwei Jiang and Bill Yuchen Lin and Nathan Lambert and Yejin Choi and Nouha Dziri},
      year={2024},
      eprint={2406.18495},
      archivePrefix={arXiv},
      primaryClass={cs.CL},
      url={https://arxiv.org/abs/2406.18495}, 
}