This repository hosts the codes of our benchmark self-evolving framework. It includes support for a range of datasets and models, allowing for dataset self-evolving and model testing through a simple command-line interface.
Before running the project, ensure you have Python and pip installed on your system. You will need Python 3.x for this project.
-
Install Dependencies: To install the required libraries, navigate to the project's root directory and run:
pip install -r requirements.txt
-
Configure API Keys: Fill in your
openai_api_key
andzhipuai_api_key
in theconfig.py
file. These keys are necessary for accessing certain models and APIs used in this project. -
Prepare Data(Optional): Prepare the
test.jsonl
file underdatasets/{dataset}
directory for each dataset you intend to use. The file should contain original examples in the following format:{ "context": "Your context here", "question": "Your question here", "answer": "Your answer here" }
Each example must include the keys:
context
,question
, andanswer
. The project currently supports the following datasets: GSM8K, Clutrr, StrategyQA, BoolQ.
To generate an evolving dataset, use the gen_dataset.py
script. This step can be skipped if you wish to use pre-evolved datasets already provided in the datasets/{dataset}
directory.
python gen_dataset.py --dataset <dataset_name> --mode <evolution_mode> --data_num <number_of_data> [--debug]
Parameter | Description |
---|---|
--dataset |
Specifies the dataset to use: gsm8k, clutrr, strategyqa, boolq... |
--mode |
Specifies the evolution mode: paraphrase, addnoise, reversepolar, alternative, complex, retrieval, planning, knowledge |
--data_num |
Specifies the number of data points to generate |
--debug |
Enables debug mode, displaying intermediate outputs in the terminal |
python gen_dataset.py --dataset gsm8k --mode paraphrase --data_num 100
This command generates an evolving dataset for the GSM8K dataset through context paraphrasing.
To test models with the datasets, use the test.py
script.
python test.py --dataset <dataset_name> --mode <test_mode> --model <model_name> --data_num <number_of_data> [--local_url <url>] [--debug]
Parameter | Description |
---|---|
--dataset |
Specifies the dataset to use: gsm8k, clutrr, strategyqa, boolq... |
--mode |
Specifies the test mode: origin, paraphrase, addnoise, reversepolar, alternative, complex, retrieval, planning, knowledge, all |
--model |
Specifies the model to test: gpt_4, chatgpt, chatglm_turbo... |
--local_url |
Specifies the URL of the local model |
--data_num |
Specifies the number of data points to test |
--debug |
Enables debug mode |
python test.py --dataset gsm8k --mode paraphrase --model chatgpt
This command tests the ChatGPT model with the paraphrased version of the GSM8K dataset.
For custom-deployed models like LLama and Mistral, specify the --local_url
parameter and implement the invoke_local_model
method in utils/call_llm.py
.