This is a minimal example for computing sentence embeddings for Arabic as described Kalimuthu et. al (2019): "Incremental Domain Adaptation for Neural Machine Translation in Low-Resource Settings".
This code is adapted from the original SIF implementation and is written in python. In addition, it requires gensim, numpy, scipy, pickle, and sklearn packages.
To install all the dependencies, virtualenv
or conda
environment is recommended. After activating an isolated environment, please install the requirements using pip:
$ pip install -r requirements.txt
At a high level, there are two main steps:
1) First, we need a GloVe pre-trained word embedding model. Since it would be a time-consuming exercise to train a word embedding model from scratch on huge amounts of data, we will leverage existing pretrained models. One such option for Arabic is AraVec, which is a pre-trained Word2Vec model that has been trained using 1.8M Arabic Wikipedia documents. So, we will download that first:
i) Go to aravec#n-grams-models-1
ii) Download the model with the following characteristics:
Model : Wikipedia-SkipGram
Docs No.: 1,800,000
Vocabularies No.: 662,109
Vec-Size: 300
Or simply click the URL: aravec_3_wiki/full_grams_sg_300_wiki.zip
However, this downloaded model is in Word2Vec format whereas we actually want a model in GloVe format. So, we will have to convert this Word2Vec model to a GloVe model since that's what SIF uses for computing sentence embeddings. To do so, one can use the following utility script: ./convert_word2vecmodel2glove_model.py
Once executed, this will generate a ~4.1GB file which is in GloVe format and will be written to the path ./models/glove_full_grams_sg_300_wiki.txt
. (***)
2) Second, we need a word weight file, which is simply a text file containing the frequency count of all the tokens in our (wiki) data.
For this, first we have to download & preprocess Arabic Wikipedia dump on which the Word2Vec model was trained on. To do so, one could simply follow the steps below:
(i)- Download the latest dump of Arabic Wikipedia from the URL: dumps.wikimedia.org/arwiki/latest/arwiki-latest-pages-articles.xml.bz2
(ii) cd
into wikiextractor
(iii) Run the following command
python WikiExtractor.py -o ../extracted_data -b 50M ../arwiki-latest-pages-articles.xml.bz2
Now, we need to do little bit of cleaning on the extracted Wikipedia dump. For this, please use the utility script: clean_extracted_data.py
Phew! finally, we can extract the much desired word frequencies. For this, we can use another utility script get_word_counts.py
. This will compute the counts and write them to a file in the location ./AraSIF_word_counts/arwiki_vocab_min200.txt
in a desired format which will be consumed by SIF. (***)
To get started, cd
into the directory examples/
and run demo.sh
NOTE: It is assumed that the Arabic Wikipedia dump is downloaded and preprocessed, pretrained Word2Vec model is downloaded and converted to GloVe format as described above, prior to executing demo.sh
. We cannot simply distribute these files due to memory restrictions of GitHub repositories.
The original source code for SIF consists of:
SIF_embedding.py
: which implements the SIF embedding. The SIF weighting scheme is very simple and is implemented in a few lines.data_io.py
: that provides the function for loading data.- utilities: includes
params.py
, andtree.py
. These provides utility data structure for the above.
The above code was written by @YingyuLiang.
The following scripts were written by @kmario23:
clean_extracted_data.py
- cleaning extracted Wikipedia dump,
convert_word2vecmodel2glove_model.py
- converting Word2Vec pretrained model to GloVe using gensim, get_word_counts.py
- computing frequency counts of tokens.
The wikiextractor
project is maintained by @attardi
For more details about how we leverage these sentence embeddings for incremental domain adaptation, please see our paper: Kalimuthu et. al (2019): "Incremental Domain Adaptation for Neural Machine Translation in Low-Resource Settings".
If you use find our work relevant and useful or if use this code, please consider citing our paper:
@inproceedings{kalimuthu-etal-2019-incremental,
title = "Incremental Domain Adaptation for Neural Machine Translation in Low-Resource Settings",
author = "Kalimuthu, Marimuthu and
Barz, Michael and
Sonntag, Daniel",
booktitle = "Proceedings of the Fourth Arabic Natural Language Processing Workshop",
month = aug,
year = "2019",
address = "Florence, Italy",
publisher = "Association for Computational Linguistics",
url = "https://www.aclweb.org/anthology/W19-4601",
pages = "1--10",
}