Skip to content

Latest commit

 

History

History
191 lines (182 loc) · 25.8 KB

README.md

File metadata and controls

191 lines (182 loc) · 25.8 KB

This repository presents the work done during my master's thesis with the title "Improving Low-Resource Neural Machine Translation of Related Languages by Transfer Learning" advised by Alexandra Birch and Rachel Bawden at The University of Edinburgh. It was submitted in August 2020. It investigated some of the Transfer Learning approaches for the Neural Machine Translation (NMT) systems by utilising the masked language models such as XLM-RoBERTa (XLM-R) [1]. This project was primarily built over the attention based fusion of the contextualised word representations from the masked language models (MLM) with the Transformer based NMT system [2]. It also empirically traced the transfer of the syntactic knowledge by an analysis of the attention heads in this system based on the work of Reference [3]. This guide gives the necessary installation instructions along with a small working example using a small subset of the IIT Bombay English-Hindi parallel dataset [4]. All the hyperparameters used in this work can be accessed from the thesis.

Table of Contents

  1. An Overview of Attention-based Fusion
  2. Installation
  3. Preprocessing
  4. Baseline NMT System
  5. XLM-R-fused NMT System
  6. Finetuning XLM-R
  7. Script Conversion
  8. Syntactic Analysis
  9. Additional Info
  10. References

1. An Overview of Attention-based Fusion

  • We connected the XLM-R with the Transformer based NMT system using the attention-based fusion following the work [2].
  • We call it XLM-R-fused NMT system which consists of an additional XLM-R module other than the standard NMT-encoder and the NMT-decoder.
  • An input sentence is passed to both the XLM-R and the NMT-encoder, which gives two different representations for the sentence. The contextualised word representation from the XLM-R is fused with the NMT-encoder representation using an attention-based fusion. Similarly, the XLM-R representation is fused with the decoder.

2. Installation

2.1. Requirements

2.2 Installation in the packages directory

2.3 Installing Fairseq

  • Clone this repository. Its parent directory will act as the home directory for all the preprocessing, training, and evaluation scripts in this work.
  • Run the following commands from the home directory.
    cd 'work/systems/baseline-NMT/fairseq'
    pip install --editable ./
    
  • It will install the Baseline-NMT System based on the Fairseq library along with its dependencies. Note that we used multiple versions of the Fairseq systems located at this location. So, we always used the exact paths of the training and evaluation files to avoid the conflicts.

2.4 Downloading and Extracting XLM-R

  • Download all the files associated with the XLM-R from the HuggingFace hub. Use the option 'List all files in model' to view and download the files namely config.json, pytorch_model.bin, sentencepiece.bpe.model, and tokenizer.json.
  • Put these files in this directory.

3. Preprocessing

  • Please visit the Fairseq and bert-nmt libraries to get familiar with the basic preprocessing, training, and evaluation steps, as our work is built over them.
  • We used Mosesdecoder to preprocess the English datasets, but switched to the Indic NLP library for the Indic languages such as Hindi, Gujarati, Bengali, and Marathi.
  • We used the Sentencepiece BPE for the word segmentation. When the source and target languages shared substantial characters, we processed the datasets with the joint BPE using this script. Otherwise, a different script was used.
  • For the English-Hindi dataset used to demonstrate this work, we used the latter script.
  • Set the HOME_DIR to the parent directory of this repository.
  • We have already put train, test, and dev files at the RAW_DATA_DIR. You can change them with your files with the same naming conventions.
  • We merged the training data with the massive monolingual datasets to learn better BPE segmentation. Put these datasets at RAW_MONOLINGUAL_DATA_DIR. We used massive OSCAR corpus in our work, but for this demo, we just used the same train files.
  • Switch between the Indic NLP or Moses library based on the languages by commenting out the clean_norm_tok function, as shown in the script.
  • Run this script which preprocesses all the files and saves at PREPROCESSED_DATA_DIR. tokenized-BPE directory contains all the intermediate files after normalization, tokenization, etc., as well as, all the final BPEd files.
  • Then, this script binarises the data to be used by the Fairseq based systems, and saves in the binary directory. It uses the Fairseq binariser from the xlm-r-fused system to binarise the files for the baseline, as well as, the XLM-R-fused systems. It uses --bert-model-name to access the XLM-R tokenizer to tokenize the source files, as they were also used by the XLM-R component along with the standard NMT-encoder in the XLM-R-fused systems.
  • (Optional) Note that this system is primarily based upon the XLM-R, but we can also use other masked language models provided by the Huggingface Transformers library. We need to make some changes as follows:
    • Download and extract the new language model as mentioned in Step 2.4.
    • Import the corresponding Tokenizer and Model from the HuggingFace Transformers library in the XLM-R-fused system with the default one as mentioned below:
      from transformers import XLMRobertaModel
      BertModel = XLMRobertaModel
      
      from transformers import XLMRobertaTokenizer
      BertTokenizer = XLMRobertaTokenizer
      
    • We need to import them in the following files:
      • work/systems/xlm-r-fused/bert-nmt/preprocess.py
      • work/systems/xlm-r-fused/bert-nmt/interactive.py
      • work/systems/xlm-r-fused/bert-nmt/fairseq_cli/preprocess.py
      • work/systems/xlm-r-fused/bert-nmt/fairseq_cli/interactive.py
      • work/systems/xlm-r-fused/bert-nmt/fairseq/tasks/translation.py
      • work/systems/xlm-r-fused/bert-nmt/fairseq/models/transformer.py
      • work/systems/xlm-r-fused/bert-nmt/fairseq/binarizer.py
    • Further, we need to change the start (<s>) and end (</s>) tokens in these files as per the new language model.

4. Baseline NMT System

4.1 Training baseline NMT system

  • Train the Transformer based baseline system with this script.
  • It will accumulate the gradients to form a larger effective batch size. Batch size = (number of GPUs) * (--max-tokens) * (--update-freq).
  • It uses an early stopping validation strategy with --patience determining the maximum number of checkpoints with declining BLEU scores.
  • Our work uses the Transformer architecture: transformer_iwslt_de_en as default. The XLM-R-fused systems restore the parameters from the baseline systems, so their architectures should match. We can also use other larger architectures for the baseline system, but we need to give the same underlying architecture for the XLM-R-fused system as well. Check this file for additional architectures implementing the attention based fusion.
  • It saves the checkpoints at BASELINE_NMT_CHECKPOINTS_DIR.

4.2 Evaluating baseline NMT system

  • Evaluate the baseline system with this script.
  • We need to evaluate BPEd test file with the best checkpoint. Use --remove-bpe=sentencepiece to remove the BPE segmentation from the output file.
  • Use either Indic NLP or Moses to detokenize the output file as shown in the script.
  • This script calculates the final BLEU scores using SacreBLEU using the untouched test file of the target language.

5. XLM-R-fused NMT System

5.1 Training XLM-R-fused NMT system

  • Train the XLM-R-fused systems with this script which will use the system at this location.
  • BERT_NAME stores the path to the XLM-R variant used with this system. We can use either pre-trained or finetuned variants here.
  • This script copies the best checkpoint from the baseline system and restores the parameters for further training with the XLM-R-fused system.
  • This system was built over an earlier version of Fairseq which did not provide early stopping, so this script saves all the checkpoints for --max-update training steps, which are then evaluated later on.
  • For attention fusion at both the encoder and decoder side, use the --arch as transformer_s2_iwslt_de_en , while for the decoder-only fusion, use transformer_iwslt_de_en.
  • Ensure to use a small learning rate, as the parameters are already near the optimum levels.

5.2 Evaluating XLM-R-fused NMT system

  • Evaluate the XLM-R-fused systems with this script, which is similar to the script used for the baseline system.
  • This script uses a particular checkpoint to compute BLEU score, while another script extends it to compute the scores for all the checkpoints.
  • Like it was mentioned before, there is no early stopping feature with this system. So, we saved all the checkpoints every few epochs and evaluated them with a validation set. Then, the best checkpoint can be set using BEST_CHECKPOINT in the former script for the test set evaluation.
  • It uses the paths to two different test files which are used by different components of the XLM-R-fused NMT systems. TEST_SRC_BPEd points to the file which is used by the standard NMT-encoder, while TEST_SRC_RAW points to the raw source file which is used by the XLM-R component. The raw file is needed by the XLM-R as it uses its own internal tokenization using the tokenizer provided by the HuggingFace Transformers library. Ensure that BERT_NAME points to the corresponding XLM-R variant directory, so that it can access its corresponding tokenizer.

6. Finetuning XLM-R

6.1 Multilingual and Monolingual Variants

  • We finetuned the XLM-R models to create the multilingual and monolingual variants of the original pre-trained models.
  • Indo-Aryan-XLM-R-Base is the multilingual variant, which is created by finetuning XLM-R base with the related languages -- Hindi, Gujarati, Marathi, and Bengali. It exploits their syntactic, morphological, orthographic, and lexical similarities.
  • Gujarati-XLM-R-Base and Gujarati-XLM-R-Large are the monolingual variants finetuned with the single Gujarati dataset. Further, Gujarati-Dev-XLM-R-Base is created with the Gujarati language converted to the Devanagari script. These models have been released at the HuggingFace hub which are available here.
  • We used the PyTorch variants of the XLM-R available here as the pre-trained models.

6.2 Preparing data

  • We primarily followed this tutorial, which we encourage you to visit before proceeding next.
  • Use this script to prepare the data. It prepares the training and validation files for a single monolingual dataset whose path is set using RAW_MONO_SOURCE. Then, it is preprocessed using the Indic NLP library, as done for the training files above.
  • In this script, BERT_NAME points to the original pretrained XLM-R model which is used to access its dictionary.
  • Then, it is binarised using another variant of the Fairseq library available here. It uses the XLM-R tokenizer, which ensures that our data is tokenized in the same way as the original data was done for pretraining the XLM-R.
  • (Optional) If you want to finetune any other masked language model, then you need to import that language model in this file. Make the following changes:
    • Import the corresponding tokenizer instead of our default XLMRobertaTokenizer
      from transformers import XLMRobertaTokenizer
      BertTokenizer = XLMRobertaTokenizer
      
    • Replace the model name here
      dict = BertTokenizer.from_pretrained("xlm-roberta-base")
      
    • Replace the start and end tokens similar to a suggestion in the Preprocessing.
  • Similarly, prepare the data for other languages if you want to create a multilingual model.

6.3 Training and Evaluating the Model

  • Use this script to finetune the monolingual variant.
  • It uses the same baseline NMT system which is used in Step 4.1 to finetune the model. Here, RESTORE_POINT points to the pre-trained model checkpoint. Use the --task as masked_lm for the monolingual variant.
  • Similalrly, use this script to create the multilingual variant. It uses the --task as multilingual_masked_lm which merges the data from different languages.
  • It also resamples it to minimise the impact of data imbalance where larger datasets overpower the smaller ones. Use --multilang-sampling-alpha to adjust the sampling ratio. See the original XLM-R paper [1] for the details.
  • We saved the checkpoints at regular intervals and picked the model with the minimum validation loss.

6.4 Making PyTorch Checkpoint Compatible with HuggingFace Transformers

  • We need to convert the saved PyTorch checkpoint to a different version compatible with the HuggingFace Transformers library.
  • We assume that you have installed the Transformers library in the packages directory. Then, use the following command.
      python packages/transformers/src/transformers/convert_roberta_original_pytorch_checkpoint_to_pytorch.py --roberta_checkpoint_path best_ck_dir/ --pytorch_dump_folder_path ./
    
  • Here, best_ck_dir contains the finetuned XLM-R checkpoint named as model.pt, dict.txt and sentencepiece.bpe.model. Latter 2 files are the same for both the pre-trained and finetuned models, which can be accessed here. pytorch_dump_folder_path refers to the directory where the Transformers compatible PyTorch version needs to be saved.
  • Note that the Transformers library had some issues with the file convert_roberta_original_pytorch_checkpoint_to_pytorch.py, which we fixed and added to the utils directory. Replace this file and rebuild the library.
  • (Optional) We can use the HuggingFace guides directly to finetune the model without first using the Fairseq library. We found this approach extremely slow due to poor multi-GPU support provided by the HuggingFace. They implemented multithreading over multiprocessing which causes imbalanced GPU usage. Fairseq implemented their own module to handle this, which is discussed here.
  • After finetuning, just use the final PyTorch version to replace the original pre-trained models for training and evaluating the XLM-R-fused systems.

7. Script Conversion

  • We used some script conversion strategies, where we tried to exploit the lexical similarities between the related languages by using a common script. We used the Indic NLP library to convert the same.
  • As the XLM-R-fused system processes the same input sentences in the XLM-R, as well as, the NMT-encoder, we tried different combinations of the scripts for these modules. For example, for the Gujarati-Hindi pair, we passed Gujarati script sentences to the XLM-R module, but Gujarati in the Devanagari script to the NMT-encoder to maximize the lexical overlap with the target language.
  • The sentences in the different scripts have the same semantic meaning, so their attention based fusion was possible. Check the thesis for more details.
  • This functionality can be used with the XLM-R-fused system by changing the source files to be binarsied for the XLM-R. It can be done by using this script, which converts these files to the target script.
  • Similarly, the script can be used to convert the script of the source files to be passed to the XLM-R, as well as, the standard NMT-encoder.
  • Then, train the baseline and XLM-R-fused NMT systems as before using the initial training scripts.
  • Evaluate these systems as before using the initial evaluation scripts. If the target language is converted to the source language's script, then it needs to be converted back to its initial script as a postprocessing step. This can be done by using the evaluation scripts present in the script-converted directory inside the baseline and xlm-r-fused systems' scripts' directories.

8. Syntactic Analysis

Please get familiar with the work of [3], whose code is available here. Our work extends it to trace the transfer of the syntactic knowledge in the XLM-R-fused systems.

8.1 Preparing data

  • Processing the Universal Dependencies (UD) dataset
    • We used the Hindi UD dataset [5] [6] for the syntactic analysis.
    • Use this script to process the raw UD train and test files. It will extract the syntactic head and corresponding syntactic relations from the UD files.
    • Then, use this script to convert the above files to the JSON format using the instructions here.
    • Finally, extract the raw sentences from the above files using this script.
  • Processing source files for Fairseq inference
    • Use the above files with the raw sentences as the source test files. We evaluate our best baseline and XLM-R-fused system checkpoints with these files.
    • Preprocess these files as mentioned in Step 3 (Preprocessing) and prepare the binarised files for the Fairseq. As we do not have any target side data here, we use a modified preprocessing script to process only the source side files.

8.2 Extracting Attention Maps from Baseline and XLM-R-fused Systems

  • Use the above binarsied data to extract the attention maps from the XLM-R-fused system using the evaluation script. Similarly, use this script to extract the maps from the baseline system.
  • These scripts use two different systems built over the baseline NMT system and XLM-R-fused NMT system, which can be accessed here and here, respectively.
  • These systems extract the self-attention maps for all the attention heads present in all the Transformer encoder layers. Further, the system built over the XLM-R-fused also extracts the bert-attention maps resulting from the attention-based fusion of the XLM-R representations and the NMT-encoder representations.
  • Use the additional parameter --save_attn_maps to give the path to save the attention maps. Create the folders -- self, bert, and batch_sentences inside it to store the respective maps. batch_sentences stores the corresponding sentences in the order the attention maps are extracted. This file can be used to verify the order of the sentences processed.
  • These maps will be saved in the numpy arrays where a single file contains the number of sentences same as the batch size.
  • Use this script to further process the attention maps.
  • It creates the pickle objects using the attention maps and the JSON files.
  • Then, it converts the attention maps for the BPE level tokens to the word level. Check the thesis for more details.
  • For testing our code, you can use our pickle files for both the baseline and XLM-R-fused systems which are available here. Download and extract the compressed file at this location. These pickle files will work with the Hindi UD preprocessed data already present at the mentioned location.

8.3 Visualising Attention Maps and Attention based Probing Classifier

  • Run syntactic analysis notebook available here. Point train_path and dev_path to the above train and test pickle files. Here, our dev and test files are the same, as we do not use any hyperparameter.
  • The weights obtained from the baseline and XLM-R-fused systems were used to determine the correct syntactic head in different layers and attention heads.
  • It has some qualitative examples where a syntactic head was successfully predicted.
  • Finally, it gives a final UAS score by training and evaluating the attention based probing classifier. It takes a weighted combination of the self-attention weights given by all the layers and attention heads to give an overall measure of the syntactic knowledge.

9. Additional Info

  • Licenses: Please note that our work is licensed under the MIT License. But, we use some other works and datasets which have their own licenses. Specifically, all the systems which are based on the Fairseq library have their corresponding licenses present in their respective directories. Further, please check the licenses for the English-Hindi IIT Bombay parallel dataset and the Hindi Universal Dependencies dataset by using the given links in the Readme file. Similarly, check the license for the HuggingFace Transformers library, as we modified one of its files as mentioned in the Readme.
  • Raise an issue if you need any help. If you find this work useful, feel free to use it and please cite my thesis as well.

10. References

[1] Conneau, Alexis, et al. "Unsupervised Cross-Lingual Representation Learning At Scale." arXiv preprint arXiv:1911.02116 (2019)

[2] Zhu, Jinhua, et al. "Incorporating BERT into Neural Machine Translation." International Conference on Learning Representations. 2019

[3] Clark, K., Khandelwal, U., Levy, O., & Manning, C. D. (2019, August). What Does BERT Look at? An Analysis of BERT’s Attention. In Proceedings of the 2019 ACL Workshop BlackboxNLP: Analyzing and Interpreting Neural Networks for NLP (pp. 276-286).

[4] Anoop Kunchukuttan, Pratik Mehta, Pushpak Bhattacharyya. The IIT Bombay English-Hindi Parallel Corpus. Language Resources and Evaluation Conference. 2018.

[5]Riyaz Ahmad Bhat, Rajesh Bhatt, Annahita Farudi, Prescott Klassen, Bhuvana Narasimhan, Martha Palmer, Owen Rambow, Dipti Misra Sharma, Ashwini Vaidya, Sri Ramagurumurthy Vishnu, and Fei Xia. The Hindi/Urdu Treebank Project. In the Handbook of Linguistic Annotation (edited by Nancy Ide and James Pustejovsky), Springer Press. 2015.

[6]Martha Palmer, Rajesh Bhatt, Bhuvana Narasimhan, Owen Rambow, Dipti Misra Sharma, Fei Xia. Hindi Syntax: Annotating Dependency, Lexical Predicate-Argument Structure, and Phrase Structure. In the Proceedings of the 7th International Conference on Natural Language Processing, ICON-2009, Hyderabad, India, Dec 14-17, 2009.