layout | title | order |
---|---|---|
page |
Frequently asked questions |
4 |
- TOC {:toc}
OpenNMT has been successfully used in many research and industry applications. It is now a robust and complete ecosystem for machine translation and related tasks.
Here are some reasons to use OpenNMT:
- The 2 supported implementations, OpenNMT-py and OpenNMT-tf, give the choice between PyTorch and TensorFlow which are 2 of the most popular deep learning toolkits.
- The implementations are packed with many configurable models and features including for other generation tasks: summarization, speech to text, image to text, etc.
- The OpenNMT ecosystem includes tools and projects to cover the full NMT workflow:
- CTranslate2, a fast inference engine for OpenNMT models which explores model quantization and inference acceleration on CPU and GPU
- Tokenizer, a fast and customizable text tokenization library
- The NMT systems are able to reach high translation quality and speed, on par with the best online translation offerings.
- You get reactive and free support on the community forum.
OpenNMT is currently supported by the companies SYSTRAN and Ubiqus. The main maintainers are:
- Guillaume Klein (SYSTRAN)
- François Hernandez (UBIQUS)
- Vincent Nguyen (Independant researcher)
The project was initiated in December 2016 by the Harvard NLP group and SYSTRAN.
OpenNMT has 2 main implementations: OpenNMT-py and OpenNMT-tf.
You first need to decide between PyTorch and TensorFlow. Both frameworks have strengths and weaknesses, see which one is more suited and easier for you to integrate.
Then, each OpenNMT implementation has its own design and set of unique features. For example OpenNMT-py has better support for other tasks (summarization, speech, image) and is generally faster while OpenNMT-tf supports modular architectures and language modeling. See their respective GitHub repository for more details.
If you are using the project for academic work, please cite the initial system demonstration paper for ACL 2017:
@inproceedings{klein-etal-2017-opennmt,
title = "{O}pen{NMT}: Open-Source Toolkit for Neural Machine Translation",
author = "Klein, Guillaume and
Kim, Yoon and
Deng, Yuntian and
Senellart, Jean and
Rush, Alexander",
booktitle = "Proceedings of {ACL} 2017, System Demonstrations",
month = jul,
year = "2017",
address = "Vancouver, Canada",
publisher = "Association for Computational Linguistics",
url = "https://www.aclweb.org/anthology/P17-4012",
pages = "67--72",
}
The OpenNMT forum is the place to go for asking general questions or requesting support. You can usually expect a reply within 1 or 2 work days.
For bugs, please report them on the GitHub repositories directly.
We recommend starting with the ACL'16 NMT produced by researchers at Stanford and NYU. The tutorial also includes a detailed bibliography describing work in the field.
You just need two files: a source file and a target file, each with one sentence per line with words that are space separated. These files can come from standard free translation corpora such as WMT, or it can be any other sources you want to train from.
While in theory you can train on any machine, in practice for all but trivally small data sets you will need a GPU if you want the training to finish in a reasonable amount of time.
We recommend using a NVIDIA GPU with at least 8GB of memory.
We published a baseline training script to train a robust German-English translation model using OpenNMT-tf. If you are using OpenNMT-py, you can apply the same preprocessing and train a Transformer model with the recommended options.
There are several pretrained models available for OpenNMT-py and OpenNMT-tf.
Try the OPUS project, an open-source collection of parallel corpora. After stripping XML tags, you should be able to use the raw files directly in OpenNMT.
I am interested in other seq2seq-like problems such as summarization, dialogue, tree-generation. Can OpenNMT work for these?
Yes. OpenNMT is a general-purpose attention-based sequence to sequence system. There is very little code that is translation specific, and so it should be effective for many of these applications.
For the case of summarization, OpenNMT has been shown to be more effective than neural systems like NAMAS, and will be supported going forward. See the OpenNMT-py models page for a pretrained summarization system on the Gigaword dataset.