Code and data for ProTrix: Building Models for Planning and Reasoning over Tables with Sentence Context
We propose a Plan-then-Reason framework to answer user queries on tabular tasks with sentence context. The framework first plans the reasoning pathways by ingesting the query and the context, and assigns each step to textual and program-based reasoning to arrive at the final answer. We construct TrixInstruct, an instruction-tuning set to build models with generalizability and interpretability over tables with sentence context. We develop ProTrix, capable of planning and reasoning on tabular tasks with sentence context. ProTrix can generalize to unseen tasks generate accurate and faithful explanations.
[2024/07/07] We update the prediction results for ProTrix family. You can use them to reproduce our results or run your own evaluation.
[2024/07/02] We add code for in-context learning experiments with our framework. Check the details in our paper!
[2024/05/21] We release our finetuned models on huggingface. We also introduce a new model Llama-3-ProTrix based on Llama-3-8B!
You can download our models ProTrix, ProTrix-Coder and Llama-3-ProTrix on huggingface. The latest Llama-3-ProTrix is finetuned using Xtuner.
conda create --name protrix --file requirements.txt
We use vllm to speed up the inference.
conda activate protrix
├── data
│ ├── evaluation_data
│ ├── gpt_output
│ └── TrixInstruct.json
├── evaluation
│ ├── compute_score.py
│ ├── evaluate_with_llm.py
│ ├── generate_all_responses.sh
│ ├── sql_tool.py
│ └── evaluate_with_sql.py
├── prompt
│ ├── one_step.py
│ ├── prompt.py
│ └── reason_after_sql.py
├── src
│ ├── utils
| ├── eval_icl.py
│ ├── plan_then_reason.py
│ └── parse_output.py
├── README.md
└── requirement.txt
You can also download our dataset through Huggingface
{
'id': instance id from the original dataset,
'instruction': instruction for generation the responses,
'output': response obtain from GPT-4,
'answer': gold answer from the original dataset
}
You can run the following command to generate result for a specific benchmark. We splits data on different GPUs to speed up the process with multiprocessing. The result will be saved at data/outputs/{model_name}. Use empty template for ProTrix and ProTrix-Coder, and llama3 template for Llama-3-ProTrix.
CUDA_VISIBLE_DEVICE={} python evaluation/evaluate_with_sql.py --model_path {your_path_to_protrix} --benchmark {benchmark} --template {template}
Or you can run the following command to generate for all the benchmarks in data/evaluation_data
cd evaluation
sh generate_all_responses.sh {protrix_path} {device}
This script will generate an approximation of the evaluation result. Note the template is set as llama3 by default. You can change it to empty for ProTrix and ProTrix-Coder.
Since our model is not trained to follow the rule or grammar of each dataset, we provide two methods to compute the final score.
Heuristic Matching Method
We try to match the answer in the concluding sentence. This method is not perfect but there is only a tiny proporation of mismatch based on our human evaluation. We use this method for developing our model. We use this metric to report the final result of fact verification tasks in our paper.
python evaluation/compute_score.py --benchmark {benchmark} --model_path {model_path}
LLM Method
We employ Llama-2-70B-chat to access the correctness of the final answer. We use this method to report the final result of question answering tasks in our paper.
python evaluate_with_llm.py --benchmark {benchmark} --model_path {model_path} --llm_path {llm_path}
python compute_score.py --benchmark {benchmark} --model_path {model_path} --eval_with_llm
You can run the following code to get responses from OpenAI APIs. To make fair comparisons, we use normalized data from previous SOTA TabSQLify.
python src/plan_then_reason.py --model_name {model_name} --benchmark {benchmark} --step one_step --run
You can replace --run
with --dry_run
to test your prompt.
You can add argument --end $num
to test code on first $num
instances.
python src/parse_output.py --model_name {model_name} --benchmark {benchmark} --step one_step
python src/plan_then_reason.py --model_name {model_name} --benchmark {benchmark} --step one_step_result --run
python src/parse_output.py --model_name {model_name} --benchmark {benchmark} --step one_step_result
Now you can run the following code to evaluate the results of in-context learning. We use the same evaluator from Binder to make fair comparison with existing prompting methods.
python src/eval_icl.py --model_name {model_name} --benchmark {benchmark} --one_step
@misc{wu2024protrix,
title={ProTrix: Building Models for Planning and Reasoning over Tables with Sentence Context},
author={Zirui Wu and Yansong Feng},
year={2024},
eprint={2403.02177},
archivePrefix={arXiv},
primaryClass={cs.CL}
}
Check out the license for our models. Our curated dataset is under the MIT license.
Our implementation for in-context learning is based on Binder and TabSQLify. We thank Rami Aly and Md Mahadi Hasan Nahid for helpful discussions.
If you have any questions or want to discuss future research directions, feel free to email ziruiwu@pku.edu.cn.