MuMath-Code: Combining Tool-Use Large Language Models with Multi-perspective Data Augmentation for Mathematical Reasoning
MuMath-Code is a series of tool-use math reasoning LLMs, which are trained using a two-stage strategy: firstly trained on MuMath-Data, then on the proposed multi-perspective and code integrated math reasoning dataset called MuMath-Code-Data. Through such a two-stage training strategy, our MuMath-Code models outperforms the state-of-the-art open methods and even some powerful proprietary ones across different scales on the reasoning datasets. Our work represents a new attempt at integrating mathematical question augmentation (tool-free) with code generation and execution (tool-use) to enhance the mathematical reasoning capabilities of LLMs, and we hope it can inspire subsequent research endeavors.
Model | Size | GSM8k | MATH |
---|---|---|---|
GPT-4 | - | 92.0 | 42.5 |
GPT-4 (PAL) | - | 94.2 | 51.8 |
ToRA-7B | 7B | 68.8 | 40.1 |
ToRA-Code-7B | 7B | 72.6 | 44.6 |
MuMath-Code-L-7B | 7B | 83.8 | 48.8 |
MuMath-Code-CL-7B | 7B | 82.6 | 52.4 |
ToRA-13B | 13B | 72.7 | 43.0 |
ToRA-Code-13B | 13B | 75.8 | 48.1 |
MuMath-Code-L-13B | 13B | 84.3 | 49.9 |
MuMath-Code-CL-13B | 13B | 84.6 | 53.1 |
ToRA-Code-34B | 34B | 80.7 | 51.0 |
MuMath-Code-CL-34B | 34B | 87.6 | 55.0 |
ToRA-70B | 70B | 84.3 | 49.7 |
MuMath-Code-L-70B | 70B | 90.7 | 52.8 |
MuMath-Code-CL-70B | 70B | 89.5 | 55.1 |
The best results are bolded and the second best underlined among the same scale models tested on the same datasets
Figure 1: The foundation model is first trained through an initial stage, resulting in an intermediary model that possesses more powerful math reasoning capability. This intermediary model is then further trained on the proposed dataset to learn code generation and tool interaction, leading to the final model, MuMath-Code.
We recommend using Conda to manage your environment. We use vLLM to accelerate inference. Run the following commands to setup your environment:
conda create -n mumathcode python=3.10
conda activate mumathcode
pip install packaging==22.0
pip install torch==2.0.1 --index-url https://download.pytorch.org/whl/cu118 # CUDA 11.8 for example
pip install -r requirements-llama.txt # for MuMath-Code-L
# pip install -r requirements-codellama.txt # for MuMath-Code-CL
We also open MuMath-Data and MuMath-Code-Data for the 1st and the 2nd training stages, respectively.
To train a model, after specifying MODEL_TYPE
, TRAIN_FILE
, MODEL_SAVE
, the conda environment and so on, run the following command:
# 7B or 13B
bash scripts/train_7b_13b_stage1.sh
bash scripts/train_7b_13b_stage2.sh
# 34B
bash scripts/train_34b_stage1.sh
bash scripts/train_34b_stage2.sh
The 70B models can also be trained using the above scripts, given some hyperparameter alterations. However, to speed up, we train our 70B models using Megatron.
We provide scripts for inference and evaluation, simply config the MODEL_NAME_OR_PATH
, DATA
, MODEL_SAVE
and so on in [scripts/infer.sh and run the following command:
bash scritps/infer.sh
This project has adopted the Microsoft Open Source Code of Conduct and ToRA.