The official repository contains the code and models for our paper A Confidence-based Knowledge Integration Framework for Cross-Domain Table Question Answering. 2024 Knowledge-Based Systems Journal (KBS).
If you use our code in your study, or find CKIF useful, please cite it as follows:
@article{Yuankai2024:CKIF,
author = {Yuankai Fan, Tonghui Ren, Can Huang, Beini Zheng, Yinan Jing, Zhenying He, Jinbao Li, Jianxin Li},
title = {A confidence-based knowledge integration framework for cross-domain table question answering},
journal = {Knowledge-Based Systems},
volume = {306},
pages = {112718},
year = {2024},
issn = {0950-7051},
doi = {https://doi.org/10.1016/j.knosys.2024.112718},
url = {https://www.sciencedirect.com/science/article/pii/S0950705124013522}
}
Download the Spider dataset and put the data in datasets
folder in the root directory
Before making inference with CKIF, we need to format the outputs of any Seq2Seq models first. Please check the README in the model_output_postprocess
folder for the details.
The postprocessing of model GAP
, RAT-SQL
and BRIDGE
has been added in the model_output_postprocess.py
file in the root directory.
Using the following command to start training ranking models,
bash train_pipeline.sh <benchmark name> <seq2seq model name> <train json file> <dev json file> <seq2seq model train output file> <seq2seq model dev output file> <table schema json file> <sqlite database directory>
Using the following command to do the inference,
bash test_pipeline.sh <benchmark name> <seq2seq model name> <seq2seq model output file> <dev/test json file> <gold sql txt file> <table schema json file> <sqlite database directory>
All the outputs of the inference will be located in the output/spider/reranker
directory and saved in a folder using the following naming convention,
<benchmark_name>_<model_name>_<candidate_num>_<retrieval_model_name>_<reranker_embedding_name><reranker_model_name>
- For debugging SQLGenV2, you may use the
reranker_script_debug.py
file in the root directory; - For debugging Dialect Builder, you may use the
dialect_debug.py
file in the root directory; - For debugging any ranking models, you may use the
code_debug.py
file in the root directory.