Add paper link

#1
by AdinaY HF staff - opened
Files changed (1) hide show
  1. README.md +211 -207
README.md CHANGED
@@ -1,207 +1,211 @@
1
- ---
2
- license: llama2
3
- ---
4
-
5
- # Xwin-Math
6
-
7
- <p align="center">
8
- <a href="https://github.com/Xwin-LM/Xwin-LM/tree/main/Xwin-Math"><img src="https://img.shields.io/badge/GitHub-yellow.svg?style=social&logo=github"></a>
9
- <a href="https://huggingface.co/Xwin-LM"><img src="https://img.shields.io/badge/%F0%9F%A4%97%20Hugging%20Face-Models-blue"></a>
10
- </p>
11
-
12
- [Paper Link](https://arxiv.org/pdf/2403.04706) Xwin-Math is a series of powerful SFT LLMs for math problems based on LLaMA-2.
13
-
14
-
15
- ## 🔥 News
16
- - 💥 [May, 2024] The [Xwin-Math-70B-V1.1](https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.1) model achieves **51.9 pass@1 on the MATH benchmark** and **90.6 pass@1 on the GSM8K benchmark**. This is a new SoTA model based on LLaMA-2-70B!
17
- - 💥 [May, 2024] The [Xwin-Math-7B-V1.1](https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.1) model achieves **44.7 pass@1 on the MATH benchmark** and **84.4 pass@1 on the GSM8K benchmark**. This is a new SoTA model based on LLaMA-2-7B!
18
- - 💥 [Nov, 2023] The [Xwin-Math-70B-V1.0](https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.0) model achieves **31.8 pass@1 on the MATH benchmark** and **87.0 pass@1 on the GSM8K benchmark**. This performance places it first amongst all open-source models!
19
- - 💥 [Nov, 2023] The [Xwin-Math-7B-V1.0](https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.0) and [Xwin-Math-13B-V1.0](https://huggingface.co/Xwin-LM/Xwin-Math-13B-V1.0) models achieve **66.6 and 76.2 pass@1 on the GSM8K benchmark**, ranking as top-1 among all LLaMA-2 based 7B and 13B open-source models respectively!
20
-
21
-
22
- ## ✨ Model Card
23
- | Model | GSM8K | MATH | Checkpoint | License |
24
- |:-:|:-:|:-:|:-:|:-:|
25
- |Xwin-Math-7B-V1.0 | 66.6 | 17.4 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.0" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
26
- |Xwin-Math-7B-V1.1 | 84.4 | 44.7 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.1" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
27
- |Xwin-Math-13B-V1.0| 76.2 | 21.7 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-13B-V1.0" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
28
- |Xwin-Math-70B-V1.0| 87.0 | 31.8 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.0" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
29
- |Xwin-Math-70B-V1.1| 90.6 | 51.9 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.1" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
30
-
31
- * Xwin-Math-7B-V1.1 uses 1.92M GSM8K and 960K MATH synthetic data.
32
- * Xwin-Math-70B-V1.1 uses 960K GSM8K and 480K MATH synthetic data.
33
-
34
- ## 🚀 Benchmarks
35
- ### Xwin-Math performance on [MATH](https://github.com/hendrycks/math) and [GSM8K](https://github.com/openai/grade-school-math).
36
-
37
- Xwin-Math-70B-V1.0 has achieved **31.8% on MATH** and **87.0% on GSM8K**. These scores are **5.3** and **3.1** points higher, respectively, than the previous state-of-the-art open-source MetaMath and LEMAv1 model.
38
-
39
-
40
- | **Model** |**MATH (Our test)** | **GSM8K (Our test)** |
41
- |:-:|:-:|:-:|
42
- | GPT-4 (zero-shot) | 52.4 | 94.8 |
43
- | GPT-35-Turbo (8-shot)| 37.1 | 81.0 |
44
- | |
45
- | WizardMath-70B | 23.9 | 81.1 |
46
- | MAmmoTH-70B | 20.8 | 72.6 |
47
- | MetaMath-70B | 26.5 | 82.0 |
48
- | LEMAv1-70B | 25.9 | 83.9 |
49
- |**Xwin-Math-70B-V1.0** |**31.8**|**87.0**|
50
- |**Xwin-Math-70B-V1.1** |**51.9**|**90.6**|
51
- | |
52
- | WizardMath-13B | 15.0 | 63.7 |
53
- | MAmmoTH-13B | 12.3 | 56.2 |
54
- | MetaMath-13B | 22.7 | 70.9 |
55
- | LEMAv1-13B | 13.6 | 65.0 |
56
- |**Xwin-Math-13B-V1.0** | 21.7 | 76.2 |
57
- | |
58
- | WizardMath-7B | 10.9 | 55.0 |
59
- | MAmmoTH-7B | 9.6 | 50.2 |
60
- | MetaMath-7B | 20.1 | 66.6 |
61
- | LEMAv1-7B | 10.0 | 54.7 |
62
- |**Xwin-Math-7B-V1.0** | 17.4 | 66.6 |
63
- |**Xwin-Math-7B-V1.1** | 44.7 | 84.4 |
64
-
65
- We obtain these results using our flexible evaluation strategy. Due to differences in environment and hardware, the test results may be slightly different from the report, but we ensure that the evaluation is as accurate and fair as possible.
66
-
67
- ### Xwin-Math performance on other math benchmarks.
68
-
69
- Our 70B model shows strong mathematical reasoning capabilities among all open-sourced models. Also note that our model even approaches or surpasses the performance of GPT-35-Turbo on some benchmarks.
70
-
71
- | **Model** | SVAMP | ASDiv | NumGlue | Algebra | MAWPS | **Average** |
72
- |:-:|:-:|:-:|:-:|:-:|:-:|:-:|
73
- | GPT-35-Turbo (8-shot)| 80.6 | 84.1 | 81.8 | 90.5 | 91.7 | 85.7 |
74
- | |
75
- | WizardMath-70B | 80.2 | 75.8 | 71.4 | 64.0 | 74.9 | 73.3 |
76
- | MAmmoTH-70B | 71.2 | 73.9 | 62.7 | 58.1 | 72.2 | 67.6 |
77
- | MetaMath-70B | 85.8 | 81.1 | 77.5 | 79.7 | 81.4 | 81.1 |
78
- | LEMAv1-70B-MATH * | 81.6 | 77.1 | 72.1 | 69.4 | 81.8 | 76.5 |
79
- |**Xwin-Math-70B-V1.0** | 84.0 | 84.1 | 81.3 | 78.4 | 90.8 | 83.7 |
80
-
81
- \* LEMAv1 has two models, and we report the better LEMAv1-70B-MATH model in these benchmarks.
82
-
83
- ## 🔨 Evaluation
84
- In order to evaluate a model's mathematical capabilities more flexibly and ensure a fair comparison of results, particularly for the MATH benchmark, we have developed a new evaluation tool. We have also assessed the pass@1 results of recent models on MATH and GSM8K benchmarks, which provides more accurate results.
85
-
86
- We hope this toolkit can benefit open-source community by providing more accurate insights and conclusions. For a deeper understanding of our evaluation tool and methods, please visit [here](https://github.com/Xwin-LM/Xwin-LM/tree/main/Xwin-Math/eval)
87
-
88
- * "Report" refers to the accuracy stated in the original papers.
89
- * "Repro" indicates the results is reproduced by generating responses and evaluating them using the respective open-source models and scripts.
90
- * "Strict" and "Flex" denote the results we achieved by employing our two strategies to extract answer and evaluate the same responses as "Repro".
91
-
92
- | Model | MATH <br> (Report) <br/> |MATH <br> (Repro) <br/> | MATH <br> (Strict) <br/> |MATH <br> (Flex) <br/> | GSM8K <br> (Report) <br/> |GSM8K <br> (Repro) <br/>| GSM8K <br> (Strict) <br/> | GSM8K <br> (Report) <br/> |
93
- |:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|
94
- | GPT-35-Turbo (8-shot)| 34.1 | - | 23.8 | 37.1 | 80.8 | - | 77.9 | 81.0 |
95
- | |
96
- | WizardMath-70B | 22.7 | 23.0 | 23.9 | 23.9 | 81.6 | 81.4 | 81.1 | 81.1 |
97
- | MAmmoTH-70B | 21.1 | 18.0 | 20.0 | 20.8 | 72.4 | 72.6 | 72.6 | 72.6 |
98
- | MetaMath-70B | 26.6 | 25.9 | 26.3 | 26.5 | 82.3 | 82.3 | 82.0 | 82.0 |
99
- |**Xwin-Math-70B-V1.0** | - | - |**31.8**|**31.8**| - | - |**87.0**|**87.0**|
100
- | |
101
- | WizardMath-13B | 14.0 | 14.2 | 14.9 | 15.0 | 63.9 | 63.9 | 63.7 | 63.7 |
102
- | MAmmoTH-13B | 12.9 | 10.8 | 11.8 | 12.3 | 56.3 | 56.2 | 56.1 | 56.2 |
103
- | MetaMath-13B | 22.4 | 22.5 | 22.6 | 22.7 | 72.3 | 71.0 | 70.9 | 70.9 |
104
- |**Xwin-Math-13B-V1.0** | - | - | 21.6 | 21.7 | - | - | 76.2 | 76.2 |
105
- | |
106
- | WizardMath-7B | 10.7 | 10.3 | 10.9 | 10.9 | 54.9 | 55.2 | 55.0 | 55.0 |
107
- | MAmmoTH-7B | 10.4 | 8.6 | 9.1 | 9.6 | 50.5 | 50.2 | 50.2 | 50.2 |
108
- | MetaMath-7B | 19.8 | 19.6 | 19.9 | 20.1 | 66.5 | 66.6 | 66.6 | 66.6 |
109
- |**Xwin-Math-7B-V1.0** | - | - | 17.3 | 17.4 | - | - | 66.6 | 66.6 |
110
-
111
- ### Installation
112
-
113
- Before you start, please install the requirements.
114
-
115
- ```bash
116
- pip install -r requirements.txt
117
- ```
118
-
119
- We tested our result using `python 3.8` and `cuda 11.8`. We recommend you use docker.
120
- ```bash
121
- docker run --gpus all -it --rm --ipc=host superbench/dev:cuda11.8
122
- ```
123
-
124
- ### Generate
125
-
126
- To generate the model's responses, you can use the `generate.py` script. Please be aware that generating responses is separate from verifying their correctness. After that, we will then check for their correctness.
127
-
128
- For the generation process, we use the Vicuna-v1.1 system prompt with chain-of-thought and format instruction. We also employ a greedy decoding strategy and set the maximum sequence length to 2048.
129
- ```
130
- "A chat between a curious user and an artificial intelligence assistant. The assistant gives helpful, detailed, and polite answers to the user's questions. USER: {instruction} Give your solution in detail. In the end, write your final answer in the format of 'The answer is: <ANSWER>.'. ASSISTANT:"
131
- ```
132
-
133
- Here is an simple example to generate using [vLLM](https://docs.vllm.ai/en/latest/).
134
- ```bash
135
- cd eval
136
-
137
- python generate.py --dataset_path dataset/gsm8k.json --model_path path/to/your/model --tensor_parallel_size 4
138
- ```
139
- By default the results will be output to the `eval/response`, using the prompt `eval/prompt/xwin_math.json`. If you wish to change the output path or use a different prompt
140
- ```bash
141
- python generate.py --dataset_path dataset/gsm8k.json --model_path path/to/your/model --tensor_parallel_size 4 --output_path /your/path --prompt_path /your/path
142
- ```
143
-
144
-
145
- We provide some datasets (in `eval/dataset`):
146
- - `gsm8k.json`: GSM8K.
147
- - `math.json`: MATH.
148
- - `combination.json`: A combination of many benchmarks, can evaluate the OOD capability of the model.
149
-
150
- If you wan't to use your own datasets, please format your dataset like this.
151
-
152
- ```jsonc
153
- [
154
- {
155
- "question": "Janet\u2019s ducks lay 16 eggs per day. She eats three for breakfast every morning and bakes muffins for her friends every day with four. She sells the remainder at the farmers' market daily for $2 per fresh duck egg. How much in dollars does she make every day at the farmers' market?",
156
- "answer": "18",
157
- "type": "GSM8K",
158
- "subtype": "",
159
- "level": 0,
160
- },
161
- // ... more data items
162
- ]
163
- ```
164
-
165
-
166
- ### Evaluate
167
-
168
- To verify the accuracy of the answers after generation, you can use the `check.py script.
169
-
170
- Here is an simple example
171
- ```bash
172
- cd eval
173
-
174
- python eval.py /path/to/model/response
175
- ```
176
- The result will be saved in `eval/evaluation`
177
-
178
- If you do not want to save the results or want to change the save path
179
- ```bash
180
- python eval.py --data_path /path/to/model/response --save_path /path/to/save --save_result True
181
- ```
182
-
183
- Once you run the script, the terminal will display the output as a table. This table will show the number of instances for each benchmark and the corresponding accuracy. Here is a hypothetical example of what the output might look like:
184
-
185
- ||Type|Subtype|Level|Correct|Incorrect|Total|Accuracy|
186
- |---|---|---|---|---|---|---|---|
187
- |0|MAWPS|addsub|0|359|33|392|0.915816|
188
- |1|MAWPS|multiarith|0|586|14|600|0.976667|
189
- |...|
190
-
191
-
192
- ## Citation
193
- Please consider citing our work if you use the data or code in this repo.
194
- ```
195
- @software{xwin-math,
196
- title = {Xwin-Math},
197
- author = {Xwin-Math Team},
198
- url = {https://github.com/Xwin-LM/Xwin-LM/Xwin-Math},
199
- version = {pre-release},
200
- year = {2023},
201
- month = {11},
202
- }
203
- ```
204
-
205
- ## Acknowledgements
206
-
207
- Thanks to [Llama 2](https://ai.meta.com/llama/), [FastChat](https://github.com/lm-sys/FastChat), and [vLLM](https://github.com/vllm-project/vllm).
 
 
 
 
 
1
+ ---
2
+ license: llama2
3
+ ---
4
+
5
+ # Xwin-Math
6
+
7
+ <p align="center">
8
+ <a href="https://github.com/Xwin-LM/Xwin-LM/tree/main/Xwin-Math"><img src="https://img.shields.io/badge/GitHub-yellow.svg?style=social&logo=github"></a>
9
+ <a href="https://huggingface.co/Xwin-LM"><img src="https://img.shields.io/badge/%F0%9F%A4%97%20Hugging%20Face-Models-blue"></a>
10
+ </p>
11
+
12
+ [Paper Link](https://arxiv.org/pdf/2403.04706) Xwin-Math is a series of powerful SFT LLMs for math problems based on LLaMA-2.
13
+
14
+
15
+ ## 🔥 News
16
+ - 💥 [May, 2024] The [Xwin-Math-70B-V1.1](https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.1) model achieves **51.9 pass@1 on the MATH benchmark** and **90.6 pass@1 on the GSM8K benchmark**. This is a new SoTA model based on LLaMA-2-70B!
17
+ - 💥 [May, 2024] The [Xwin-Math-7B-V1.1](https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.1) model achieves **44.7 pass@1 on the MATH benchmark** and **84.4 pass@1 on the GSM8K benchmark**. This is a new SoTA model based on LLaMA-2-7B!
18
+ - 💥 [Nov, 2023] The [Xwin-Math-70B-V1.0](https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.0) model achieves **31.8 pass@1 on the MATH benchmark** and **87.0 pass@1 on the GSM8K benchmark**. This performance places it first amongst all open-source models!
19
+ - 💥 [Nov, 2023] The [Xwin-Math-7B-V1.0](https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.0) and [Xwin-Math-13B-V1.0](https://huggingface.co/Xwin-LM/Xwin-Math-13B-V1.0) models achieve **66.6 and 76.2 pass@1 on the GSM8K benchmark**, ranking as top-1 among all LLaMA-2 based 7B and 13B open-source models respectively!
20
+
21
+
22
+ ## ✨ Model Card
23
+ | Model | GSM8K | MATH | Checkpoint | License |
24
+ |:-:|:-:|:-:|:-:|:-:|
25
+ |Xwin-Math-7B-V1.0 | 66.6 | 17.4 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.0" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
26
+ |Xwin-Math-7B-V1.1 | 84.4 | 44.7 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-7B-V1.1" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
27
+ |Xwin-Math-13B-V1.0| 76.2 | 21.7 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-13B-V1.0" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
28
+ |Xwin-Math-70B-V1.0| 87.0 | 31.8 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.0" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
29
+ |Xwin-Math-70B-V1.1| 90.6 | 51.9 | 🤗 <a href="https://huggingface.co/Xwin-LM/Xwin-Math-70B-V1.1" target="_blank">HF Link</a> | <a href="https://ai.meta.com/resources/models-and-libraries/llama-downloads/" target="_blank">Llama 2 License|
30
+
31
+ * Xwin-Math-7B-V1.1 uses 1.92M GSM8K and 960K MATH synthetic data.
32
+ * Xwin-Math-70B-V1.1 uses 960K GSM8K and 480K MATH synthetic data.
33
+
34
+ ## 🚀 Benchmarks
35
+ ### Xwin-Math performance on [MATH](https://github.com/hendrycks/math) and [GSM8K](https://github.com/openai/grade-school-math).
36
+
37
+ Xwin-Math-70B-V1.0 has achieved **31.8% on MATH** and **87.0% on GSM8K**. These scores are **5.3** and **3.1** points higher, respectively, than the previous state-of-the-art open-source MetaMath and LEMAv1 model.
38
+
39
+
40
+ | **Model** |**MATH (Our test)** | **GSM8K (Our test)** |
41
+ |:-:|:-:|:-:|
42
+ | GPT-4 (zero-shot) | 52.4 | 94.8 |
43
+ | GPT-35-Turbo (8-shot)| 37.1 | 81.0 |
44
+ | |
45
+ | WizardMath-70B | 23.9 | 81.1 |
46
+ | MAmmoTH-70B | 20.8 | 72.6 |
47
+ | MetaMath-70B | 26.5 | 82.0 |
48
+ | LEMAv1-70B | 25.9 | 83.9 |
49
+ |**Xwin-Math-70B-V1.0** |**31.8**|**87.0**|
50
+ |**Xwin-Math-70B-V1.1** |**51.9**|**90.6**|
51
+ | |
52
+ | WizardMath-13B | 15.0 | 63.7 |
53
+ | MAmmoTH-13B | 12.3 | 56.2 |
54
+ | MetaMath-13B | 22.7 | 70.9 |
55
+ | LEMAv1-13B | 13.6 | 65.0 |
56
+ |**Xwin-Math-13B-V1.0** | 21.7 | 76.2 |
57
+ | |
58
+ | WizardMath-7B | 10.9 | 55.0 |
59
+ | MAmmoTH-7B | 9.6 | 50.2 |
60
+ | MetaMath-7B | 20.1 | 66.6 |
61
+ | LEMAv1-7B | 10.0 | 54.7 |
62
+ |**Xwin-Math-7B-V1.0** | 17.4 | 66.6 |
63
+ |**Xwin-Math-7B-V1.1** | 44.7 | 84.4 |
64
+
65
+ We obtain these results using our flexible evaluation strategy. Due to differences in environment and hardware, the test results may be slightly different from the report, but we ensure that the evaluation is as accurate and fair as possible.
66
+
67
+ ### Xwin-Math performance on other math benchmarks.
68
+
69
+ Our 70B model shows strong mathematical reasoning capabilities among all open-sourced models. Also note that our model even approaches or surpasses the performance of GPT-35-Turbo on some benchmarks.
70
+
71
+ | **Model** | SVAMP | ASDiv | NumGlue | Algebra | MAWPS | **Average** |
72
+ |:-:|:-:|:-:|:-:|:-:|:-:|:-:|
73
+ | GPT-35-Turbo (8-shot)| 80.6 | 84.1 | 81.8 | 90.5 | 91.7 | 85.7 |
74
+ | |
75
+ | WizardMath-70B | 80.2 | 75.8 | 71.4 | 64.0 | 74.9 | 73.3 |
76
+ | MAmmoTH-70B | 71.2 | 73.9 | 62.7 | 58.1 | 72.2 | 67.6 |
77
+ | MetaMath-70B | 85.8 | 81.1 | 77.5 | 79.7 | 81.4 | 81.1 |
78
+ | LEMAv1-70B-MATH * | 81.6 | 77.1 | 72.1 | 69.4 | 81.8 | 76.5 |
79
+ |**Xwin-Math-70B-V1.0** | 84.0 | 84.1 | 81.3 | 78.4 | 90.8 | 83.7 |
80
+
81
+ \* LEMAv1 has two models, and we report the better LEMAv1-70B-MATH model in these benchmarks.
82
+
83
+ ## 🔨 Evaluation
84
+ In order to evaluate a model's mathematical capabilities more flexibly and ensure a fair comparison of results, particularly for the MATH benchmark, we have developed a new evaluation tool. We have also assessed the pass@1 results of recent models on MATH and GSM8K benchmarks, which provides more accurate results.
85
+
86
+ We hope this toolkit can benefit open-source community by providing more accurate insights and conclusions. For a deeper understanding of our evaluation tool and methods, please visit [here](https://github.com/Xwin-LM/Xwin-LM/tree/main/Xwin-Math/eval)
87
+
88
+ * "Report" refers to the accuracy stated in the original papers.
89
+ * "Repro" indicates the results is reproduced by generating responses and evaluating them using the respective open-source models and scripts.
90
+ * "Strict" and "Flex" denote the results we achieved by employing our two strategies to extract answer and evaluate the same responses as "Repro".
91
+
92
+ | Model | MATH <br> (Report) <br/> |MATH <br> (Repro) <br/> | MATH <br> (Strict) <br/> |MATH <br> (Flex) <br/> | GSM8K <br> (Report) <br/> |GSM8K <br> (Repro) <br/>| GSM8K <br> (Strict) <br/> | GSM8K <br> (Report) <br/> |
93
+ |:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|:-:|
94
+ | GPT-35-Turbo (8-shot)| 34.1 | - | 23.8 | 37.1 | 80.8 | - | 77.9 | 81.0 |
95
+ | |
96
+ | WizardMath-70B | 22.7 | 23.0 | 23.9 | 23.9 | 81.6 | 81.4 | 81.1 | 81.1 |
97
+ | MAmmoTH-70B | 21.1 | 18.0 | 20.0 | 20.8 | 72.4 | 72.6 | 72.6 | 72.6 |
98
+ | MetaMath-70B | 26.6 | 25.9 | 26.3 | 26.5 | 82.3 | 82.3 | 82.0 | 82.0 |
99
+ |**Xwin-Math-70B-V1.0** | - | - |**31.8**|**31.8**| - | - |**87.0**|**87.0**|
100
+ | |
101
+ | WizardMath-13B | 14.0 | 14.2 | 14.9 | 15.0 | 63.9 | 63.9 | 63.7 | 63.7 |
102
+ | MAmmoTH-13B | 12.9 | 10.8 | 11.8 | 12.3 | 56.3 | 56.2 | 56.1 | 56.2 |
103
+ | MetaMath-13B | 22.4 | 22.5 | 22.6 | 22.7 | 72.3 | 71.0 | 70.9 | 70.9 |
104
+ |**Xwin-Math-13B-V1.0** | - | - | 21.6 | 21.7 | - | - | 76.2 | 76.2 |
105
+ | |
106
+ | WizardMath-7B | 10.7 | 10.3 | 10.9 | 10.9 | 54.9 | 55.2 | 55.0 | 55.0 |
107
+ | MAmmoTH-7B | 10.4 | 8.6 | 9.1 | 9.6 | 50.5 | 50.2 | 50.2 | 50.2 |
108
+ | MetaMath-7B | 19.8 | 19.6 | 19.9 | 20.1 | 66.5 | 66.6 | 66.6 | 66.6 |
109
+ |**Xwin-Math-7B-V1.0** | - | - | 17.3 | 17.4 | - | - | 66.6 | 66.6 |
110
+
111
+ ### Installation
112
+
113
+ Before you start, please install the requirements.
114
+
115
+ ```bash
116
+ pip install -r requirements.txt
117
+ ```
118
+
119
+ We tested our result using `python 3.8` and `cuda 11.8`. We recommend you use docker.
120
+ ```bash
121
+ docker run --gpus all -it --rm --ipc=host superbench/dev:cuda11.8
122
+ ```
123
+
124
+ ### Generate
125
+
126
+ To generate the model's responses, you can use the `generate.py` script. Please be aware that generating responses is separate from verifying their correctness. After that, we will then check for their correctness.
127
+
128
+ For the generation process, we use the Vicuna-v1.1 system prompt with chain-of-thought and format instruction. We also employ a greedy decoding strategy and set the maximum sequence length to 2048.
129
+ ```
130
+ "A chat between a curious user and an artificial intelligence assistant. The assistant gives helpful, detailed, and polite answers to the user's questions. USER: {instruction} Give your solution in detail. In the end, write your final answer in the format of 'The answer is: <ANSWER>.'. ASSISTANT:"
131
+ ```
132
+
133
+ Here is an simple example to generate using [vLLM](https://docs.vllm.ai/en/latest/).
134
+ ```bash
135
+ cd eval
136
+
137
+ python generate.py --dataset_path dataset/gsm8k.json --model_path path/to/your/model --tensor_parallel_size 4
138
+ ```
139
+ By default the results will be output to the `eval/response`, using the prompt `eval/prompt/xwin_math.json`. If you wish to change the output path or use a different prompt
140
+ ```bash
141
+ python generate.py --dataset_path dataset/gsm8k.json --model_path path/to/your/model --tensor_parallel_size 4 --output_path /your/path --prompt_path /your/path
142
+ ```
143
+
144
+
145
+ We provide some datasets (in `eval/dataset`):
146
+ - `gsm8k.json`: GSM8K.
147
+ - `math.json`: MATH.
148
+ - `combination.json`: A combination of many benchmarks, can evaluate the OOD capability of the model.
149
+
150
+ If you wan't to use your own datasets, please format your dataset like this.
151
+
152
+ ```jsonc
153
+ [
154
+ {
155
+ "question": "Janet\u2019s ducks lay 16 eggs per day. She eats three for breakfast every morning and bakes muffins for her friends every day with four. She sells the remainder at the farmers' market daily for $2 per fresh duck egg. How much in dollars does she make every day at the farmers' market?",
156
+ "answer": "18",
157
+ "type": "GSM8K",
158
+ "subtype": "",
159
+ "level": 0,
160
+ },
161
+ // ... more data items
162
+ ]
163
+ ```
164
+
165
+
166
+ ### Evaluate
167
+
168
+ To verify the accuracy of the answers after generation, you can use the `check.py script.
169
+
170
+ Here is an simple example
171
+ ```bash
172
+ cd eval
173
+
174
+ python eval.py /path/to/model/response
175
+ ```
176
+ The result will be saved in `eval/evaluation`
177
+
178
+ If you do not want to save the results or want to change the save path
179
+ ```bash
180
+ python eval.py --data_path /path/to/model/response --save_path /path/to/save --save_result True
181
+ ```
182
+
183
+ Once you run the script, the terminal will display the output as a table. This table will show the number of instances for each benchmark and the corresponding accuracy. Here is a hypothetical example of what the output might look like:
184
+
185
+ ||Type|Subtype|Level|Correct|Incorrect|Total|Accuracy|
186
+ |---|---|---|---|---|---|---|---|
187
+ |0|MAWPS|addsub|0|359|33|392|0.915816|
188
+ |1|MAWPS|multiarith|0|586|14|600|0.976667|
189
+ |...|
190
+
191
+
192
+ ## Citation
193
+ Please consider citing our work if you use the data or code in this repo.
194
+ ```
195
+ @software{xwin-math,
196
+ title = {Xwin-Math},
197
+ author = {Xwin-Math Team},
198
+ url = {https://github.com/Xwin-LM/Xwin-LM/Xwin-Math},
199
+ version = {pre-release},
200
+ year = {2023},
201
+ month = {11},
202
+ }
203
+ ```
204
+
205
+ ## Acknowledgements
206
+
207
+ Thanks to [Llama 2](https://ai.meta.com/llama/), [FastChat](https://github.com/lm-sys/FastChat), and [vLLM](https://github.com/vllm-project/vllm).
208
+
209
+ ## Paper
210
+
211
+ arxiv.org/abs/2405.20335