Spaces:
Build error
Build error
# Multi-swe-bench Evaluation with OpenHands | |
## LLM Setup | |
Please follow [here](../../README.md#setup). | |
## Dataset Preparing | |
Please download the [**Multi-SWE-Bench** dataset](https://huggingface.co/datasets/bytedance-research/Multi-SWE-Bench). | |
And change the dataset following [script](scripts/data/data_change.py). | |
```bash | |
python evaluation/benchmarks/multi_swe_bench/scripts/data/data_change.py | |
``` | |
## Docker image download | |
Please download the multi-swe-bench dokcer images from [here](https://github.com/multi-swe-bench/multi-swe-bench?tab=readme-ov-file#run-evaluation). | |
## Generate patch | |
Please edit the [script](infer.sh) and run it. | |
```bash | |
bash evaluation/benchmarks/multi_swe_bench/infer.sh | |
``` | |
Script variable explanation: | |
- `models`, e.g. `llm.eval_gpt4_1106_preview`, is the config group name for your | |
LLM settings, as defined in your `config.toml`. | |
- `git-version`, e.g. `HEAD`, is the git commit hash of the OpenHands version you would | |
like to evaluate. It could also be a release tag like `0.6.2`. | |
- `agent`, e.g. `CodeActAgent`, is the name of the agent for benchmarks, defaulting to `CodeActAgent`. | |
- `eval_limit`, e.g. `10`, limits the evaluation to the first `eval_limit` instances. By | |
default, the script evaluates the (500 issues), which will no exceed the maximum of the dataset number. | |
- `max_iter`, e.g. `20`, is the maximum number of iterations for the agent to run. By | |
default, it is set to 50. | |
- `num_workers`, e.g. `3`, is the number of parallel workers to run the evaluation. By | |
default, it is set to 1. | |
- `language`, the language of your evaluating dataset. | |
- `dataset`, the absolute position of the dataset jsonl. | |
The results will be generated in evaluation/evaluation_outputs/outputs/XXX/CodeActAgent/YYY/output.jsonl, you can refer to the [example](examples/output.jsonl). | |
## Runing evaluation | |
First, install [multi-swe-bench](https://github.com/multi-swe-bench/multi-swe-bench). | |
```bash | |
pip install multi-swe-bench | |
``` | |
Second, convert the output.jsonl to patch.jsonl with [script](scripts/eval/convert.py), you can refer to the [example](examples/patch.jsonl). | |
```bash | |
python evaluation/benchmarks/multi_swe_bench/scripts/eval/convert.py | |
``` | |
Finally, evaluate with multi-swe-bench. | |
The config file config.json can be refer to the [example](examples/config.json) or [github](https://github.com/multi-swe-bench/multi-swe-bench/tree/main?tab=readme-ov-file#configuration-file-example). | |
```bash | |
python -m multi_swe_bench.harness.run_evaluation --config config.json | |
``` | |