Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/hav4ik/Hydra

Multi-Task Learning Framework on PyTorch. State-of-the-art methods are implemented to effectively train models on multiple tasks.
https://github.com/hav4ik/Hydra

deep-learning multi-objective-optimization multi-task-learning neural-architecture-search pytorch

Last synced: 3 months ago
JSON representation

Multi-Task Learning Framework on PyTorch. State-of-the-art methods are implemented to effectively train models on multiple tasks.

Awesome Lists containing this project

README

        

# Hydra — a Multi-Task Learning Framework

[![Python 3.6](https://img.shields.io/badge/python-3.6-blue.svg)](https://www.python.org/downloads/release/python-360/)
[![Using PyTorch](https://img.shields.io/badge/PyTorch-red.svg?labelColor=f3f4f7&logo=)](https://pytorch.org/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://github.com/hav4ik/Hydra/blob/master/LICENSE)
[![Contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat)](https://github.com/hav4ik/Hydra/issues)

[Hydra][hydra] is a flexible multi-task learning framework written in [PyTorch 1.0][pytorch]. The following multi-objective optimization algorithms are implemented:

* **Naive** — a separate optimizer for each task
* **Gradients averaging** — average out the gradients to the network's body
* **MGDA** — described in the paper [Multi-Task Learning as Multi-Objective Optimization (NIPS 2018)][mgda]

A comprehensive survey on these algorithms (and more) can be found in [this blog article][blog-post].

# Installation

* The code was written on `Python 3.6`. Clone this repository:

git clone https://github.com/hav4ik/Hydra

* It is recommended to use [anaconda][conda] for installation of core packages (since `conda` packages comes with low-level libraries that can optimize the runtime):

conda install pytorch torchvision cudatoolkit=10.0 -c pytorch
conda install numpy pandas scikit-learn

* Some of the packages are not available from anaconda, so you can install them using `pip`:

pip install -r requirements.txt

# Getting started

* Examples of configuration files can be found [here][configs-dir]. A minimal example is available in [starter.sh][starter]. Execute it as follows (will train with configurations in [configs/toy_experiments/naive.yaml][naive-yaml]):

./starter.sh naive 50

# Coming soon...

* Proper framework documentation and examples.

[hydra]: https://github.com/hav4ik/Hydra
[conda]: https://docs.conda.io/en/latest/miniconda.html
[pytorch]: https://pytorch.org/
[mgda]: https://papers.nips.cc/paper/7334-multi-task-learning-as-multi-objective-optimization.pdf
[gradnorm]: https://arxiv.org/abs/1711.02257
[starter]: https://github.com/hav4ik/Hydra/blob/master/starter.sh
[configs-dir]: https://github.com/hav4ik/Hydra/tree/master/configs
[naive-yaml]: https://github.com/hav4ik/Hydra/blob/master/configs/toy_experiments/naive.yaml
[blog-post]: https://hav4ik.github.io/articles/mtl-a-practical-survey