Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rwth-i6/returnn

The RWTH extensible training framework for universal recurrent neural networks
https://github.com/rwth-i6/returnn

deep-learning gpu recurrent-neural-networks tensorflow theano

Last synced: 5 days ago
JSON representation

The RWTH extensible training framework for universal recurrent neural networks

Awesome Lists containing this project

README

        

==================
Welcome to RETURNN
==================

`GitHub repository `__.
`RETURNN paper 2016 `_,
`RETURNN paper 2018 `_.

RETURNN - RWTH extensible training framework for universal recurrent neural networks,
is a Theano/TensorFlow-based implementation of modern recurrent neural network architectures.
It is optimized for fast and reliable training of recurrent neural networks in a multi-GPU environment.

The high-level features and goals of RETURNN are:

* **Simplicity**

* Writing config / code is simple & straight-forward (setting up experiment, defining model)
* Debugging in case of problems is simple
* Reading config / code is simple (defined model, training, decoding all becomes clear)

* **Flexibility**

* Allow for many different kinds of experiments / models

* **Efficiency**

* Training speed
* Decoding speed

All items are important for research, decoding speed is esp. important for production.

See our `Interspeech 2020 tutorial "Efficient and Flexible Implementation of Machine Learning for ASR and MT" video `__
(`slides `__)
with an introduction of the core concepts.

More specific features include:

- Mini-batch training of feed-forward neural networks
- Sequence-chunking based batch training for recurrent neural networks
- Long short-term memory recurrent neural networks
including our own fast CUDA kernel
- Multidimensional LSTM (GPU only, there is no CPU version)
- Memory management for large data sets
- Work distribution across multiple devices
- Flexible and fast architecture which allows all kinds of encoder-attention-decoder models

See `documentation `__.
See `basic usage `__
and `technological overview `__.

`Here is the video recording of a RETURNN overview talk `_
(`slides `__,
`exercise sheet `__;
hosted by eBay).

There are `many example demos `_
which work on artificially generated data,
i.e. they should work as-is.

There are `some real-world examples `_
such as setups for speech recognition on the Switchboard or LibriSpeech corpus.

Some benchmark setups against other frameworks
can be found `here `_.
The results are in the `RETURNN paper 2016 `_.
Performance benchmarks of our LSTM kernel vs CuDNN and other TensorFlow kernels
are in `TensorFlow LSTM benchmark `__.

There is also `a wiki `_.
Questions can also be asked on
`StackOverflow using the RETURNN tag `_.

.. image:: https://github.com/rwth-i6/returnn/workflows/CI/badge.svg
:target: https://github.com/rwth-i6/returnn/actions

Dependencies
============

pip dependencies are listed in ``requirements.txt`` and ``requirements-dev``,
although some parts of the code may require additional dependencies (e.g. ``librosa``, ``resampy``) on-demand.

RETURNN supports Python >= 3.8. Bumps to the minimum Python version are listed in `CHANGELOG.md `__.

TensorFlow-based setups require TensorFlow >= 2.2.

PyTorch-based setups require Torch >= 1.0.