/PreQuEL

Primary LanguagePython

PreQuEL: Quality Estimation of Machine Translation Outputs in Advance

We present the task of PreQuEL, Pre-(Quality-Estimation) Learning. A PreQuEL system predicts how well a given sentence will be translated, without recourse to the actual translation, thus eschewing unnecessary resource allocation when translation quality is bound to be low.

Here we proveide our baseline models for the task.

Paper link: https://arxiv.org/abs/2205.09178


Install

git clone https://github.com/shachardon/PreQuEL.git
cd PreQuEL
pip install -e requirements.txt

Quick Start - Train

To train a model, please run this command from the root directory of PreQuEL.

python run_model.py --model_type <type> --epochs <num_epochs> --folds <num_folds> --replace_comet --extra_finetune <num_extra_epochs> --dir <output_dir> --lang <lang>
  • --model_type simple/combined/multiple

  • --epochs Number of epochs to train the model on. Note that this is the maximum number of epochs. If the model do not improve for more than 10 evaluation steps, it stops training.

  • --folds Number of folds to run.

  • --replace_comet Set if you want to train on the COMET augmented data instead of on the DA data.

  • --extra_finetune Train another <num_extra_epochs> epochs on the DA data (usually used after training on the COMET augmented data with the --replace_comet flag).

  • --dir Directory path for saving the models and results.

  • --lang de for en-de, en for de-en, et for et-en, zh for en-zh.

For example,

python run_model.py --model_type simple --epochs 3 --folds 3 --extra_finetune 3 --replace_comet --dir output_dir_simple_exp_en_de --lang de

Will train a SimpleModel on the en-de pair, for 3 folds, each with 3 epochs on the COMET augmentations and then more 3 epochs on the DA data. The resulted models and test performance will be saved to a folder named 'output_dir_simple_exp_en_de'.


Test

To test an existing model, run this command -

python run_model.py --model_type simple --epochs <num_epochs> --folds  <num_folds> --extra_finetune <num_extra_epochs> --dir <experiment_dir_with_saved_models> --lang <lang> --test_only <test_file_path>

Where the test file is a text file with one source sentence per line. --epochs should be set to 0, if you want to use the best saved model. Otherwise, the model from the <num_epochs> epoch will be used to make the predictions.

for example,

python run_model.py --model_type simple --epochs -1 --extra_finetune -1 --folds  3 --dir saved_models/simple_en_de_DA_with_comet/ --lang de --test_only data/newstest2020.ende.chrf.ngram.lan.comet.bertScore.test

Will use the already trained simple_en_de_with_comet model to perdict the DA scores for newstest2020.ende test data. Note that you first need to unzip the saved models.



Citation

@misc{https://doi.org/10.48550/arxiv.2205.09178,
  doi = {10.48550/ARXIV.2205.09178},
  url = {https://arxiv.org/abs/2205.09178},
  author = {Don-Yehiya, Shachar and Choshen, Leshem and Abend, Omri},
  keywords = {Computation and Language (cs.CL), Machine Learning (cs.LG), FOS: Computer and information sciences, FOS: Computer and information sciences},
  title = {PreQuEL: Quality Estimation of Machine Translation Outputs in Advance},
  publisher = {arXiv},
  year = {2022},
  copyright = {Creative Commons Attribution 4.0 International}
}