Attention-based sequence to sequence learning
- TensorFlow for Python 3
- YAML and Matplotlib modules for Python 3:
sudo apt-get install python3-yaml python3-matplotlib
Train a model (CONFIG is a YAML configuration file, such as config/default.yaml
):
python3 -m translate CONFIG --train -v
Translate text using an existing model:
python3 -m translate CONFIG --decode FILE_TO_TRANSLATE --output OUTPUT_FILE
or for interactive decoding:
python3 -m translate CONFIG --decode
Example model:
experiments/WMT14/download.sh # download WMT14 data into data/raw
experiments/WMT14/prepare.sh # preprocess the data, and copy the files to experiments/WMT14/data
python3 -m translate experiments/WMT14/baseline.yaml --train -v # train a baseline model on this data
- YAML configuration files
- Beam-search decoder
- External language model
- Ensemble decoding
- Multiple encoders
- Hierarchical encoder
- Bidirectional encoder
- Local attention model
- Convolutional attention model
- Detailed logging
- Periodic BLEU evaluation
- Periodic checkpoints
- Multi-task training: train on several tasks at once (e.g. French->English and German->English MT)
- Subwords training and decoding
- Input binary features instead of text
- Pre-processing script: we provide a fully-featured Python script for data pre-processing (vocabulary creation, lowercasing, tokenizing, splitting, etc.)
- Dynamic RNNs: we use symbolic loops instead of statically unrolled RNNs. This means faster model creation, and that we don't need buckets
- This project is based on TensorFlow's reference implementation
- We include some of the pre-processing scripts from Moses
- The scripts for subword units come from github.com/rsennrich/subword-nmt
- For an obscure reason, when running seq2seq with Python 3.4, TensorFlow's
rnn._dynamic_rnn_loop
throws an exception. Works fine with Python 3.5.