This is a research project, not an official NVIDIA product.
- Python 3.6
- Tensorflow r1.2 or r1.3 (with GPU support)
- NLTK v3.2.3+
Checkout the code and make sure the following test pass: You should see OK after each test
./create_toy_data.sh
python -m unittest test/data_layer_tests.py
python -m unittest test/model_tests.py
When you execute ./create_toy_data.sh
script, it will create the following toy data:
-
Source: random sequence of numbers
-
Target: reversed source sequence
The task is to learn to reverse sequences. You can test single or multi-gpu training.
Single GPU:
$ python run.py --config=example_configs/toy_data_config.json --mode=train --logdir=ModelAndLogFolder
- You can monitor training progress with Tensorboard:
tensorboard --logdir=ModelAndLogFolder
Multi-GPU:
We follow data parallel approach for training. Each GPU receives a full copy of the model and its own mini-batch.
To start multi-GPU training, set "num_gpus"
parameter in the model config accordingly.
The "batch_size"
parameter specifies batch size per GPU. Hence, global (or algorithmic) batch size will be equal "num_gpus"*"batch_size"
$ python run.py --config=example_configs/toy_data_config_2GPUs.json --mode=train --logdir=ModelAndLogFolder
Once you have trained the model and saved it in ModelAndLogFolder
, run:
$ python run.py --config=example_configs/toy_data_config_2GPUs.json --mode=infer --logdir=ModelAndLogFolder --inference_out=pred.txt
$ ./multi-bleu.perl test/toy_data/test/target.txt < pred.txt
If you just used provided configs, your BLUE score should be > 98 for both single and 2 gpu runs.
Download and execute this script
Edit the 'nmt.json' file and replace [WMT16_DATA_LOCATION] with correct data location.
Edit "num_gpus" section of nmt.json - set it to the number of GPUs you want to use.
python run.py --config_file=example_configs/nmt.json --logdir=nmt --checkpoint_frequency=2000 --summary_frequency=50 --eval_frequency=1000
- If you are getting OOM exceptions try decreasing batch_size parameter in
nmt.json
python run.py --config_file=example_configs/nmt.json --logdir=nmt --mode=infer --inference_out=wmt_pred.txt
Clean wmt_pred.txt
and newstest2015.tok.bpe.32000.en
from BPE segmentation
$ cat {file_with_BPE_segmentation} | sed -r 's/(@@ )|(@@ ?$)//g' > {cleaned_file}
Run multi-blue.perl
script on cleaned data.
$ ./multi-bleu.perl cleaned_newstest2015.tok.bpe.32000.en < cleaned_wmt_pred.txt
For this example config you should get BLEU score around 22.66.
On a single Quadro GP100 (16GB) it takes around 24 hours (4 epochs) to get this result.
Train longer (and/or using more GPUs) to get better results.
Oleksii Kuchaiev and Siddharth Bhatnagar (internship work at NVIDIA)
Contributions are welcome!