promptbench


Namepromptbench JSON
Version 0.0.4 PyPI version JSON
download
home_pagehttps://github.com/microsoft/promptbench
SummaryPromptBench is a powerful tool designed to scrutinize and analyze the interaction of large language models with various prompts. It provides a convenient infrastructure to simulate **black-box** adversarial **prompt attacks** on the models and evaluate their performances.
upload_time2024-08-02 02:05:15
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseNone
keywords pytorch large language models prompt tuning dyval evaluation
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <div id="top"></div>
<!--
*** Thanks for checking out the Best-README-Template. If you have a suggestion
*** that would make this better, please fork the repo and create a pull request
*** or simply open an issue with the tag "enhancement".
*** Don't forget to give the project a star!
*** Thanks again! Now go create something AMAZING! :D
-->

<!-- PROJECT SHIELDS -->

<!--
*** I'm using markdown "reference style" links for readability.
*** Reference links are enclosed in brackets [ ] instead of parentheses ( ).
*** See the bottom of this document for the declaration of the reference variables
*** for contributors-url, forks-url, etc. This is an optional, concise syntax you may use.
*** https://www.markdownguide.org/basic-syntax/#reference-style-links
-->

[![Contributors][contributors-shield]][contributors-url]
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
<!-- 
***[![MIT License][license-shield]][license-url]
-->

<!-- PROJECT LOGO -->

<br />
<div align="center">
  <a href="https://github.com/microsoft/promptbench">
    <img src="imgs/promptbench_logo.png" alt="Logo" width="300">
  </a>

<!-- <h3 align="center">USB</h3> -->

<p align="center">
    <strong>PromptBench</strong>: A Unified Library for Evaluating and Understanding Large Language Models.
    <!-- <br />
    <a href="https://github.com/microsoft/promptbench"><strong>Explore the docs »</strong></a>
    <br /> -->
    <br />
    <a href="https://arxiv.org/abs/2312.07910">Paper</a>
    ·
    <a href="https://promptbench.readthedocs.io/en/latest/">Documentation</a>
    ·
    <a href="https://llm-eval.github.io/pages/leaderboard.html">Leaderboard</a>
    ·
    <a href="https://llm-eval.github.io/pages/papers.html">More papers</a>
  </p>
</div>

<!-- TABLE OF CONTENTS -->

<details>
  <summary>Table of Contents</summary>
  <ol>
    <li><a href="#news-and-updates">News and Updates</a></li>
    <li><a href="#introduction">Introduction</a></li>
    <li><a href="#installation">Installation</a></li>
    <li><a href="#usage">Usage</a></li>
    <li><a href="#supported-datasets-and-models">Datasets and Models</a></li>
    <li><a href="#benchmark-results">Benchmark Results</a></li>
    <li><a href="#acknowledgments">Acknowledgments</a></li>
  </ol>
</details>

<!-- News and Updates -->

## News and Updates
- [26/05/2024] Add support for GPT-4o.
- [13/03/2024] Add support for multi-modal models and datasets.
- [05/01/2024] Add support for BigBench Hard, DROP, ARC datasets.
- [16/12/2023] Add support for Gemini, Mistral, Mixtral, Baichuan, Yi models.
- [15/12/2023] Add detailed instructions for users to add new modules (models, datasets, etc.) [examples/add_new_modules.md](examples/add_new_modules.md). 
- [05/12/2023] Published promptbench 0.0.1.


<!-- Introduction -->

## Introduction

**PromptBench** is a Pytorch-based Python package for Evaluation of Large Language Models (LLMs). It provides user-friendly APIs for researchers to conduct evaluation on LLMs. Check the technical report: https://arxiv.org/abs/2312.07910.

![Code Structure](https://files.catbox.moe/0kw21g.png)



### What does promptbench currently provide?
1. **Quick model performance assessment:** We offer a user-friendly interface that allows for quick model building, dataset loading, and evaluation of model performance.
2. **Prompt Engineering:** We implemented several prompt engineering methods. For example: [Few-shot Chain-of-Thought](https://arxiv.org/abs/2201.11903) [1],  [Emotion Prompt](https://arxiv.org/abs/2307.11760) [2], [Expert Prompting](https://arxiv.org/abs/2305.14688) [3] and so on.
3. **Evaluating adversarial prompts:** promptbench integrated [prompt attacks](https://arxiv.org/abs/2306.04528) [4], enabling researchers to simulate black-box adversarial prompt attacks on models and evaluate their robustness (see details [here](promptbench/prompt_attack/README.md)).
4. **Dynamic evaluation to mitigate potential test data contamination:** we integrated the dynamic evaluation framework [DyVal](https://arxiv.org/pdf/2309.17167) [5], which generates evaluation samples on-the-fly with controlled complexity.



<!-- GETTING STARTED -->

## Installation

### Install via `pip`
We provide a Python package *promptbench* for users who want to start evaluation quickly. Simply run:
```sh
pip install promptbench
```

Note that the pip installation could be behind the recent updates. So, if you want to use the latest features or develop based on our code, you should install via GitHub.

### Install via GitHub

First, clone the repo:
```sh
git clone git@github.com:microsoft/promptbench.git
```

Then, 

```sh
cd promptbench
```

To install the required packages, you can create a conda environment:

```sh
conda create --name promptbench python=3.9
conda activate promptbench
```

then use pip to install required packages:

```sh
pip install -r requirements.txt
```

Note that this only installed basic python packages. For Prompt Attacks, you will also need to install [TextAttack](https://github.com/QData/TextAttack).


## Usage

promptbench is easy to use and extend. Going through the examples below will help you get familiar with promptbench for quick use, evaluate existing datasets and LLMs, or create your own datasets and models.


Please see [Installation](#installation) to install promptbench first. 

If promptbench is installed via `pip`, you can simply do:

```python
import promptbench as pb
```

If you installed promptbench from `git` and want to use it in other projects:

```python
import sys

# Add the directory of promptbench to the Python path
sys.path.append('/home/xxx/promptbench')

# Now you can import promptbench by name
import promptbench as pb
```


We provide tutorials for:

1. **evaluate models on existing benchmarks:** please refer to the [examples/basic.ipynb](examples/basic.ipynb) for constructing your evaluation pipeline. For a multi-modal evaluation pipeline, please refer to [examples/multimodal.ipynb](examples/multimodal.ipynb)
2. **test the effects of different prompting techniques:** 
3. **examine the robustness for prompt attacks**, please refer to [examples/prompt_attack.ipynb](examples/prompt_attack.ipynb) to construct the attacks.
4. **use DyVal for evaluation:** please refer to [examples/dyval.ipynb](examples/dyval.ipynb) to construct DyVal datasets.


## Implemented Components

PromptBench currently supports different datasets, models, prompt engineering methods, adversarial attacks, and more. You are welcome to add more.

### Datasets

- Language datasets:
  - GLUE: SST-2, CoLA, QQP, MRPC, MNLI, QNLI, RTE, WNLI
  - MMLU
  - BIG-Bench Hard (Bool logic, valid parentheses, date...)
  - Math
  - GSM8K
  - SQuAD V2
  - IWSLT 2017
  - UN Multi
  - CSQA (CommonSense QA)
  - Numersense
  - QASC
  - Last Letter Concatenate
- Multi-modal datasets:
  - VQAv2
  - NoCaps
  - MMMU
  - MathVista
  - AI2D
  - ChartQA
  - ScienceQA

### Models

Language models:

- Open-source models:
  - google/flan-t5-large
  - databricks/dolly-v1-6b
  - Llama2 series
  - vicuna-13b, vicuna-13b-v1.3
  - Cerebras/Cerebras-GPT-13B
  - EleutherAI/gpt-neox-20b
  - Google/flan-ul2
  - phi-1.5 and phi-2
- Proprietary models
  - PaLM 2
  - GPT-3.5
  - GPT-4
  - Gemini Pro

Multi-modal models:

- Open-source models:
  - BLIP2
  - LLaVA
  - Qwen-VL, Qwen-VL-Chat
  - InternLM-XComposer2-VL
- Proprietary models
  - GPT-4v
  - Gemini Pro Vision
  - Qwen-VL-Max, Qwen-VL-Plus

### Prompt Engineering

- Chain-of-thought (COT) [1]
- EmotionPrompt [2]
- Expert prompting [3]
- Zero-shot chain-of-thought
- Generated knowledge [6]
- Least to most [7]

### Adversarial Attacks

- Character-level attack
  - DeepWordBug
  - TextBugger
- Word-level attack
  - TextFooler
  - BertAttack
- Sentence-level attack
  - CheckList
  - StressTest
- Semantic-level attack
  - Human-crafted attack

### Protocols and Analysis
- Standard evaluation
- Dynamic evaluation
- Semantic evaluation
- Benchmark results
- Visualization analysis
- Transferability analysis
- Word frequency analysis

## Benchmark Results

Please refer to our [benchmark website](https://llm-eval.github.io/) for benchmark results on Prompt Attacks, Prompt Engineering and Dynamic Evaluation DyVal.

## Acknowledgements

- [TextAttack](https://github.com/QData/TextAttack)
- [README Template](https://github.com/othneildrew/Best-README-Template)
- We thank the volunteers: Hanyuan Zhang, Lingrui Li, Yating Zhou for conducting the semantic preserving experiment in Prompt Attack benchmark.


## Reference
[1] Jason Wei, et al. "Chain-of-Thought Prompting Elicits Reasoning in Large Language Models." arXiv preprint arXiv:2201.11903 (2022).

[2] Cheng Li, et al. "Emotionprompt: Leveraging psychology for large language models enhancement via emotional stimulus." arXiv preprint arXiv:2307.11760 (2023).

[3] BenFeng Xu, et al. "ExpertPrompting: Instructing Large Language Models to be Distinguished Experts" arXiv preprint arXiv:2305.14688 (2023).

[4] Zhu, Kaijie, et al. "PromptBench: Towards Evaluating the Robustness of Large Language Models on Adversarial Prompts." arXiv preprint arXiv:2306.04528 (2023).

[5] Zhu, Kaijie, et al. "DyVal: Graph-informed Dynamic Evaluation of Large Language Models." arXiv preprint arXiv:2309.17167 (2023).

[6] Liu J, Liu A, Lu X, et al. Generated knowledge prompting for commonsense reasoning[J]. arXiv preprint arXiv:2110.08387, 2021.

[7] Zhou D, Schärli N, Hou L, et al. Least-to-most prompting enables complex reasoning in large language models[J]. arXiv preprint arXiv:2205.10625, 2022.

<!-- CITE -->

## Citing promptbench and other research papers

Please cite us if you find this project helpful for your project/paper:

```
@article{zhu2023promptbench2,
  title={PromptBench: A Unified Library for Evaluation of Large Language Models},
  author={Zhu, Kaijie and Zhao, Qinlin and Chen, Hao and Wang, Jindong and Xie, Xing},
  journal={arXiv preprint arXiv:2312.07910},
  year={2023}
}

@article{zhu2023promptbench,
  title={PromptBench: Towards Evaluating the Robustness of Large Language Models on Adversarial Prompts},
  author={Zhu, Kaijie and Wang, Jindong and Zhou, Jiaheng and Wang, Zichen and Chen, Hao and Wang, Yidong and Yang, Linyi and Ye, Wei and Gong, Neil Zhenqiang and Zhang, Yue and others},
  journal={arXiv preprint arXiv:2306.04528},
  year={2023}
}

@article{zhu2023dyval,
  title={DyVal: Graph-informed Dynamic Evaluation of Large Language Models},
  author={Zhu, Kaijie and Chen, Jiaao and Wang, Jindong and Gong, Neil Zhenqiang and Yang, Diyi and Xie, Xing},
  journal={arXiv preprint arXiv:2309.17167},
  year={2023}
}

@article{chang2023survey,
  title={A survey on evaluation of large language models},
  author={Chang, Yupeng and Wang, Xu and Wang, Jindong and Wu, Yuan and Zhu, Kaijie and Chen, Hao and Yang, Linyi and Yi, Xiaoyuan and Wang, Cunxiang and Wang, Yidong and others},
  journal={arXiv preprint arXiv:2307.03109},
  year={2023}
}

```

<!-- CONTRIBUTING -->

## Contributing

This project welcomes contributions and suggestions.  Most contributions require you to agree to a
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us
the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide
a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions
provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).
For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or
contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.

If you have a suggestion that would make promptbench better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".
Don't forget to give the project a star! Thanks again!

1. Fork the project
2. Create your branch (`git checkout -b your_name/your_branch`)
3. Commit your changes (`git commit -m 'Add some features'`)
4. Push to the branch (`git push origin your_name/your_branch`)
5. Open a Pull Request


<!-- TRADEMARKS -->

## Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft
trademarks or logos is subject to and must follow
[Microsoft&#39;s Trademark &amp; Brand Guidelines](https://www.microsoft.com/en-us/legal/intellectualproperty/trademarks/usage/general).
Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship.
Any use of third-party trademarks or logos are subject to those third-party's policies.





<!-- MARKDOWN LINKS & IMAGES -->

<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links -->

[contributors-shield]: https://img.shields.io/github/contributors/microsoft/promptbench.svg?style=for-the-badge
[contributors-url]: https://github.com/microsoft/promptbench/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/microsoft/promptbench.svg?style=for-the-badge
[forks-url]: https://github.com/microsoft/promptbench/network/members
[stars-shield]: https://img.shields.io/github/stars/microsoft/promptbench.svg?style=for-the-badge
[stars-url]: https://github.com/microsoft/promptbench/stargazers
[issues-shield]: https://img.shields.io/github/issues/microsoft/promptbench.svg?style=for-the-badge
[issues-url]: https://github.com/microsoft/promptbench/issues
[license-shield]: https://img.shields.io/github/license/microsoft/promptbench.svg?style=for-the-badge
[license-url]: https://github.com/microsoft/promptbench/blob/main/LICENSE.txt

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/microsoft/promptbench",
    "name": "promptbench",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "pytorch, large language models, prompt tuning, dyval, evaluation",
    "author": null,
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/93/48/69b998be8caae218e1b0f0edd27b605bfcf298b0dc9ac5a3ef4506ab7983/promptbench-0.0.4.tar.gz",
    "platform": null,
    "description": "<div id=\"top\"></div>\n<!--\n*** Thanks for checking out the Best-README-Template. If you have a suggestion\n*** that would make this better, please fork the repo and create a pull request\n*** or simply open an issue with the tag \"enhancement\".\n*** Don't forget to give the project a star!\n*** Thanks again! Now go create something AMAZING! :D\n-->\n\n<!-- PROJECT SHIELDS -->\n\n<!--\n*** I'm using markdown \"reference style\" links for readability.\n*** Reference links are enclosed in brackets [ ] instead of parentheses ( ).\n*** See the bottom of this document for the declaration of the reference variables\n*** for contributors-url, forks-url, etc. This is an optional, concise syntax you may use.\n*** https://www.markdownguide.org/basic-syntax/#reference-style-links\n-->\n\n[![Contributors][contributors-shield]][contributors-url]\n[![Forks][forks-shield]][forks-url]\n[![Stargazers][stars-shield]][stars-url]\n[![Issues][issues-shield]][issues-url]\n<!-- \n***[![MIT License][license-shield]][license-url]\n-->\n\n<!-- PROJECT LOGO -->\n\n<br />\n<div align=\"center\">\n  <a href=\"https://github.com/microsoft/promptbench\">\n    <img src=\"imgs/promptbench_logo.png\" alt=\"Logo\" width=\"300\">\n  </a>\n\n<!-- <h3 align=\"center\">USB</h3> -->\n\n<p align=\"center\">\n    <strong>PromptBench</strong>: A Unified Library for Evaluating and Understanding Large Language Models.\n    <!-- <br />\n    <a href=\"https://github.com/microsoft/promptbench\"><strong>Explore the docs \u00bb</strong></a>\n    <br /> -->\n    <br />\n    <a href=\"https://arxiv.org/abs/2312.07910\">Paper</a>\n    \u00b7\n    <a href=\"https://promptbench.readthedocs.io/en/latest/\">Documentation</a>\n    \u00b7\n    <a href=\"https://llm-eval.github.io/pages/leaderboard.html\">Leaderboard</a>\n    \u00b7\n    <a href=\"https://llm-eval.github.io/pages/papers.html\">More papers</a>\n  </p>\n</div>\n\n<!-- TABLE OF CONTENTS -->\n\n<details>\n  <summary>Table of Contents</summary>\n  <ol>\n    <li><a href=\"#news-and-updates\">News and Updates</a></li>\n    <li><a href=\"#introduction\">Introduction</a></li>\n    <li><a href=\"#installation\">Installation</a></li>\n    <li><a href=\"#usage\">Usage</a></li>\n    <li><a href=\"#supported-datasets-and-models\">Datasets and Models</a></li>\n    <li><a href=\"#benchmark-results\">Benchmark Results</a></li>\n    <li><a href=\"#acknowledgments\">Acknowledgments</a></li>\n  </ol>\n</details>\n\n<!-- News and Updates -->\n\n## News and Updates\n- [26/05/2024] Add support for GPT-4o.\n- [13/03/2024] Add support for multi-modal models and datasets.\n- [05/01/2024] Add support for BigBench Hard, DROP, ARC datasets.\n- [16/12/2023] Add support for Gemini, Mistral, Mixtral, Baichuan, Yi models.\n- [15/12/2023] Add detailed instructions for users to add new modules (models, datasets, etc.) [examples/add_new_modules.md](examples/add_new_modules.md). \n- [05/12/2023] Published promptbench 0.0.1.\n\n\n<!-- Introduction -->\n\n## Introduction\n\n**PromptBench** is a Pytorch-based Python package for Evaluation of Large Language Models (LLMs). It provides user-friendly APIs for researchers to conduct evaluation on LLMs. Check the technical report: https://arxiv.org/abs/2312.07910.\n\n![Code Structure](https://files.catbox.moe/0kw21g.png)\n\n\n\n### What does promptbench currently provide?\n1. **Quick model performance assessment:** We offer a user-friendly interface that allows for quick model building, dataset loading, and evaluation of model performance.\n2. **Prompt Engineering:** We implemented several prompt engineering methods. For example: [Few-shot Chain-of-Thought](https://arxiv.org/abs/2201.11903) [1],  [Emotion Prompt](https://arxiv.org/abs/2307.11760) [2], [Expert Prompting](https://arxiv.org/abs/2305.14688) [3] and so on.\n3. **Evaluating adversarial prompts:** promptbench integrated [prompt attacks](https://arxiv.org/abs/2306.04528) [4], enabling researchers to simulate black-box adversarial prompt attacks on models and evaluate their robustness (see details [here](promptbench/prompt_attack/README.md)).\n4. **Dynamic evaluation to mitigate potential test data contamination:** we integrated the dynamic evaluation framework [DyVal](https://arxiv.org/pdf/2309.17167) [5], which generates evaluation samples on-the-fly with controlled complexity.\n\n\n\n<!-- GETTING STARTED -->\n\n## Installation\n\n### Install via `pip`\nWe provide a Python package *promptbench* for users who want to start evaluation quickly. Simply run:\n```sh\npip install promptbench\n```\n\nNote that the pip installation could be behind the recent updates. So, if you want to use the latest features or develop based on our code, you should install via GitHub.\n\n### Install via GitHub\n\nFirst, clone the repo:\n```sh\ngit clone git@github.com:microsoft/promptbench.git\n```\n\nThen, \n\n```sh\ncd promptbench\n```\n\nTo install the required packages, you can create a conda environment:\n\n```sh\nconda create --name promptbench python=3.9\nconda activate promptbench\n```\n\nthen use pip to install required packages:\n\n```sh\npip install -r requirements.txt\n```\n\nNote that this only installed basic python packages. For Prompt Attacks, you will also need to install [TextAttack](https://github.com/QData/TextAttack).\n\n\n## Usage\n\npromptbench is easy to use and extend. Going through the examples below will help you get familiar with promptbench for quick use, evaluate existing datasets and LLMs, or create your own datasets and models.\n\n\nPlease see [Installation](#installation) to install promptbench first. \n\nIf promptbench is installed via `pip`, you can simply do:\n\n```python\nimport promptbench as pb\n```\n\nIf you installed promptbench from `git` and want to use it in other projects:\n\n```python\nimport sys\n\n# Add the directory of promptbench to the Python path\nsys.path.append('/home/xxx/promptbench')\n\n# Now you can import promptbench by name\nimport promptbench as pb\n```\n\n\nWe provide tutorials for:\n\n1. **evaluate models on existing benchmarks:** please refer to the [examples/basic.ipynb](examples/basic.ipynb) for constructing your evaluation pipeline. For a multi-modal evaluation pipeline, please refer to [examples/multimodal.ipynb](examples/multimodal.ipynb)\n2. **test the effects of different prompting techniques:** \n3. **examine the robustness for prompt attacks**, please refer to [examples/prompt_attack.ipynb](examples/prompt_attack.ipynb) to construct the attacks.\n4. **use DyVal for evaluation:** please refer to [examples/dyval.ipynb](examples/dyval.ipynb) to construct DyVal datasets.\n\n\n## Implemented Components\n\nPromptBench currently supports different datasets, models, prompt engineering methods, adversarial attacks, and more. You are welcome to add more.\n\n### Datasets\n\n- Language datasets:\n  - GLUE: SST-2, CoLA, QQP, MRPC, MNLI, QNLI, RTE, WNLI\n  - MMLU\n  - BIG-Bench Hard (Bool logic, valid parentheses, date...)\n  - Math\n  - GSM8K\n  - SQuAD V2\n  - IWSLT 2017\n  - UN Multi\n  - CSQA (CommonSense QA)\n  - Numersense\n  - QASC\n  - Last Letter Concatenate\n- Multi-modal datasets:\n  - VQAv2\n  - NoCaps\n  - MMMU\n  - MathVista\n  - AI2D\n  - ChartQA\n  - ScienceQA\n\n### Models\n\nLanguage models:\n\n- Open-source models:\n  - google/flan-t5-large\n  - databricks/dolly-v1-6b\n  - Llama2 series\n  - vicuna-13b, vicuna-13b-v1.3\n  - Cerebras/Cerebras-GPT-13B\n  - EleutherAI/gpt-neox-20b\n  - Google/flan-ul2\n  - phi-1.5 and phi-2\n- Proprietary models\n  - PaLM 2\n  - GPT-3.5\n  - GPT-4\n  - Gemini Pro\n\nMulti-modal models:\n\n- Open-source models:\n  - BLIP2\n  - LLaVA\n  - Qwen-VL, Qwen-VL-Chat\n  - InternLM-XComposer2-VL\n- Proprietary models\n  - GPT-4v\n  - Gemini Pro Vision\n  - Qwen-VL-Max, Qwen-VL-Plus\n\n### Prompt Engineering\n\n- Chain-of-thought (COT) [1]\n- EmotionPrompt [2]\n- Expert prompting [3]\n- Zero-shot chain-of-thought\n- Generated knowledge [6]\n- Least to most [7]\n\n### Adversarial Attacks\n\n- Character-level attack\n  - DeepWordBug\n  - TextBugger\n- Word-level attack\n  - TextFooler\n  - BertAttack\n- Sentence-level attack\n  - CheckList\n  - StressTest\n- Semantic-level attack\n  - Human-crafted attack\n\n### Protocols and Analysis\n- Standard evaluation\n- Dynamic evaluation\n- Semantic evaluation\n- Benchmark results\n- Visualization analysis\n- Transferability analysis\n- Word frequency analysis\n\n## Benchmark Results\n\nPlease refer to our [benchmark website](https://llm-eval.github.io/) for benchmark results on Prompt Attacks, Prompt Engineering and Dynamic Evaluation DyVal.\n\n## Acknowledgements\n\n- [TextAttack](https://github.com/QData/TextAttack)\n- [README Template](https://github.com/othneildrew/Best-README-Template)\n- We thank the volunteers: Hanyuan Zhang, Lingrui Li, Yating Zhou for conducting the semantic preserving experiment in Prompt Attack benchmark.\n\n\n## Reference\n[1] Jason Wei, et al. \"Chain-of-Thought Prompting Elicits Reasoning in Large Language Models.\" arXiv preprint arXiv:2201.11903 (2022).\n\n[2] Cheng Li, et al. \"Emotionprompt: Leveraging psychology for large language models enhancement via emotional stimulus.\" arXiv preprint arXiv:2307.11760 (2023).\n\n[3] BenFeng Xu, et al. \"ExpertPrompting: Instructing Large Language Models to be Distinguished Experts\" arXiv preprint arXiv:2305.14688 (2023).\n\n[4] Zhu, Kaijie, et al. \"PromptBench: Towards Evaluating the Robustness of Large Language Models on Adversarial Prompts.\" arXiv preprint arXiv:2306.04528 (2023).\n\n[5] Zhu, Kaijie, et al. \"DyVal: Graph-informed Dynamic Evaluation of Large Language Models.\" arXiv preprint arXiv:2309.17167 (2023).\n\n[6] Liu J, Liu A, Lu X, et al. Generated knowledge prompting for commonsense reasoning[J]. arXiv preprint arXiv:2110.08387, 2021.\n\n[7] Zhou D, Sch\u00e4rli N, Hou L, et al. Least-to-most prompting enables complex reasoning in large language models[J]. arXiv preprint arXiv:2205.10625, 2022.\n\n<!-- CITE -->\n\n## Citing promptbench and other research papers\n\nPlease cite us if you find this project helpful for your project/paper:\n\n```\n@article{zhu2023promptbench2,\n  title={PromptBench: A Unified Library for Evaluation of Large Language Models},\n  author={Zhu, Kaijie and Zhao, Qinlin and Chen, Hao and Wang, Jindong and Xie, Xing},\n  journal={arXiv preprint arXiv:2312.07910},\n  year={2023}\n}\n\n@article{zhu2023promptbench,\n  title={PromptBench: Towards Evaluating the Robustness of Large Language Models on Adversarial Prompts},\n  author={Zhu, Kaijie and Wang, Jindong and Zhou, Jiaheng and Wang, Zichen and Chen, Hao and Wang, Yidong and Yang, Linyi and Ye, Wei and Gong, Neil Zhenqiang and Zhang, Yue and others},\n  journal={arXiv preprint arXiv:2306.04528},\n  year={2023}\n}\n\n@article{zhu2023dyval,\n  title={DyVal: Graph-informed Dynamic Evaluation of Large Language Models},\n  author={Zhu, Kaijie and Chen, Jiaao and Wang, Jindong and Gong, Neil Zhenqiang and Yang, Diyi and Xie, Xing},\n  journal={arXiv preprint arXiv:2309.17167},\n  year={2023}\n}\n\n@article{chang2023survey,\n  title={A survey on evaluation of large language models},\n  author={Chang, Yupeng and Wang, Xu and Wang, Jindong and Wu, Yuan and Zhu, Kaijie and Chen, Hao and Yang, Linyi and Yi, Xiaoyuan and Wang, Cunxiang and Wang, Yidong and others},\n  journal={arXiv preprint arXiv:2307.03109},\n  year={2023}\n}\n\n```\n\n<!-- CONTRIBUTING -->\n\n## Contributing\n\nThis project welcomes contributions and suggestions.  Most contributions require you to agree to a\nContributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us\nthe rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.\n\nWhen you submit a pull request, a CLA bot will automatically determine whether you need to provide\na CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions\nprovided by the bot. You will only need to do this once across all repos using our CLA.\n\nThis project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).\nFor more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or\ncontact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.\n\nIf you have a suggestion that would make promptbench better, please fork the repo and create a pull request. You can also simply open an issue with the tag \"enhancement\".\nDon't forget to give the project a star! Thanks again!\n\n1. Fork the project\n2. Create your branch (`git checkout -b your_name/your_branch`)\n3. Commit your changes (`git commit -m 'Add some features'`)\n4. Push to the branch (`git push origin your_name/your_branch`)\n5. Open a Pull Request\n\n\n<!-- TRADEMARKS -->\n\n## Trademarks\n\nThis project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft\ntrademarks or logos is subject to and must follow\n[Microsoft&#39;s Trademark &amp; Brand Guidelines](https://www.microsoft.com/en-us/legal/intellectualproperty/trademarks/usage/general).\nUse of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship.\nAny use of third-party trademarks or logos are subject to those third-party's policies.\n\n\n\n\n\n<!-- MARKDOWN LINKS & IMAGES -->\n\n<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links -->\n\n[contributors-shield]: https://img.shields.io/github/contributors/microsoft/promptbench.svg?style=for-the-badge\n[contributors-url]: https://github.com/microsoft/promptbench/graphs/contributors\n[forks-shield]: https://img.shields.io/github/forks/microsoft/promptbench.svg?style=for-the-badge\n[forks-url]: https://github.com/microsoft/promptbench/network/members\n[stars-shield]: https://img.shields.io/github/stars/microsoft/promptbench.svg?style=for-the-badge\n[stars-url]: https://github.com/microsoft/promptbench/stargazers\n[issues-shield]: https://img.shields.io/github/issues/microsoft/promptbench.svg?style=for-the-badge\n[issues-url]: https://github.com/microsoft/promptbench/issues\n[license-shield]: https://img.shields.io/github/license/microsoft/promptbench.svg?style=for-the-badge\n[license-url]: https://github.com/microsoft/promptbench/blob/main/LICENSE.txt\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "PromptBench is a powerful tool designed to scrutinize and analyze the interaction of large language models with various prompts. It provides a convenient infrastructure to simulate **black-box** adversarial  **prompt attacks** on the models and evaluate their performances.",
    "version": "0.0.4",
    "project_urls": {
        "Homepage": "https://github.com/microsoft/promptbench"
    },
    "split_keywords": [
        "pytorch",
        " large language models",
        " prompt tuning",
        " dyval",
        " evaluation"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ffc6594c4cde639f46f50d050c7c9af29e8b14c1f75bce34b41ef3b3fd780b82",
                "md5": "26edb3c766901db136cdd49045ffe28f",
                "sha256": "6d1341582ff59b3db73d39708e5ed55cf2955d49f76db6a9dd85f0ce37740bb8"
            },
            "downloads": -1,
            "filename": "promptbench-0.0.4-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "26edb3c766901db136cdd49045ffe28f",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 129292,
            "upload_time": "2024-08-02T02:05:14",
            "upload_time_iso_8601": "2024-08-02T02:05:14.251205Z",
            "url": "https://files.pythonhosted.org/packages/ff/c6/594c4cde639f46f50d050c7c9af29e8b14c1f75bce34b41ef3b3fd780b82/promptbench-0.0.4-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "934869b998be8caae218e1b0f0edd27b605bfcf298b0dc9ac5a3ef4506ab7983",
                "md5": "bf5c97336c4fb4c0ba991a662a6598fa",
                "sha256": "8f872e4eaa93e2cf8528bf37d3691e6c4334e44c269a7ab3093de92e93006b90"
            },
            "downloads": -1,
            "filename": "promptbench-0.0.4.tar.gz",
            "has_sig": false,
            "md5_digest": "bf5c97336c4fb4c0ba991a662a6598fa",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 122719,
            "upload_time": "2024-08-02T02:05:15",
            "upload_time_iso_8601": "2024-08-02T02:05:15.796586Z",
            "url": "https://files.pythonhosted.org/packages/93/48/69b998be8caae218e1b0f0edd27b605bfcf298b0dc9ac5a3ef4506ab7983/promptbench-0.0.4.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-08-02 02:05:15",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "microsoft",
    "github_project": "promptbench",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "promptbench"
}
        
Elapsed time: 4.53908s