antonlabate
ver 1.3
d758c99
|
raw
history blame
16.8 kB

mRAT-SQL+GAP - Multilingual version of the RAT-SQL+GAP

Code and model from our BRACIS 2021 paper published in Springer Lecture Notes in Computer Science, here the pre-print in arXiv.

Based on: RAT-SQL+GAP: Github. Paper: AAAI 2021 paper

Abstract

mRAT-SQL+GAP is a multilingual version of the RAT-SQL+GAP, wich start with Portuguese Language. Here is available the code, dataset and the results.

Directory Structure

Go to the directory where you want to install the structure

git clone https://github.com/C4AI/gap-text2sql
cd gap-text2sql/mrat-sql-gap 

Conda mtext2slq Environment Setup

conda create --name mtext2sql python=3.7
conda activate mtext2sql
conda install pytorch=1.5 cudatoolkit=10.2 -c pytorch
pip install gdown
conda install -c conda-forge jsonnet
pip install -r requirements.txt
python -c "import nltk; nltk.download('stopwords'); nltk.download('punkt')"
conda install jupyter notebook
conda install -c conda-forge jupyter_contrib_nbextensions

Setup Script

Just run this script below, it will copy the datasets. The original version of the Spider dataset is distributed under the CC BY-SA 4.0 license. The modified versions (translated to Portuguese, Spanish, French, double-size(English and Portuguese) and quad-size (English, Portuguese, Spanish and French)) of train_spider.json, train_others.json, and dev.json are distributed under the CC BY-SA 4.0 license, respecting ShareAlike.

chmod +x setup.sh
./setup.sh

Specific setup

The models and checkpoints have big files (GBytes), so if you have enough disk space you can run all shell scripts. To understand how things work, run just BART_large.sh and after run the others.

./BART_large.sh
./mBART50MtoM-large.sh
./mT5_large.sh
./BERTimbau-base.sh
./BERTimbau-large.sh

Environment Test

Now the environment is ready for training (fine-tune) and inferences. The training is very slow more than 60 hours for BART, BERTimbau, mBART50, and more than 28 hours for mT5. Therefore I recommend testing the environment with the inference.

Preprocess dataset

This preprocess step is necessary both for inference and for training. It will take some time, maybe 40 minutes. I will use the script for BART, but you can use the other, look the directory experiments/spider-configs

python run.py preprocess experiments/spider-configs/spider-BART-large-en-train_en-eval.jsonnet

You can see the files processed in the paths: data/spider-en/nl2code-1115,output_from=true,fs=2,emb=bart,cvlink

Inference

I will use the script for BART again. Note: We are making inferences using the checkpoint already trained (directory logdir) and defined in: experiments/spider-configs/spider-BART-large-en-train_en-eval.jsonnet logdir: "logdir/BART-large-en-train", and
eval_steps: [40300],

python run.py eval experiments/spider-configs/spider-BART-large-en-train_en-eval.jsonnet

You then get the inference results and evaluation results in the paths:

ie_dirs/BART-large-en-train/bart-large-en_run_1_true_1-step41000.infer

and

ie_dirs/BART-large-en-train/bart-large-en_run_1_true_1-step41000.eval.

Training

Execute if it is really necessary, if you want to fine-tune the model, this will take a long time. But if you have a good machine available and want to see different checkpoints in the logdir, do it.

python run.py train experiments/spider-configs/spider-BART-large-en-train_en-eval.jsonnet

You then get the training checkpoints in the paths: logdir/BART-large-en-train

Checkpoints and Inferences

The checkpoints are available here (ESM - Exact Set Matching Accuracy): Paper mRAT-SQL+GAP - Multilingual version of the RAT-SQL+GAP

Future work of the paper mRAT-SQL+GAP

Paper mRAT-SQL-FIT

Other Best Results

  • T5-v1_1-large trained in English FIT 150Ksteps

  • mT5-large trained in English, Portuguese, Spanish and French (together) + Non Linear Data Augmentation by rules for extra question 3enr-3ptr-3esr-3frr FIT 150Ksteps

Results

All intermediate files of the results are in the directory inference-results.

Security

See CONTRIBUTING for more information.

License

This project is licensed under the Apache-2.0 License.