### Reinforcement Learning for Practitioners (v1.4.1, 20Q1)
![Travis_Status](https://travis-ci.com/christianhidber/easyagents.svg?branch=master)
[![Coverage Status](https://coveralls.io/repos/github/christianhidber/easyagents/badge.svg?branch=master)](https://coveralls.io/github/christianhidber/easyagents?branch=master)
![License](https://img.shields.io/github/license/christianhidber/easyagents)
[![Downloads](https://pepy.tech/badge/easyagents)](https://pepy.tech/project/easyagents)
[![Docs](https://img.shields.io/badge/api-docs-blue)](https://christianhidber.github.io/easyagents/)
Status:
under active development, breaking changes may occur.
[Release notes](documentation/Markdown/Release_Notes.md).
![EasyAgents logo](images/EazyAgentsIcon.png)
EasyAgents is a high level reinforcement learning api focusing on ease of use and simplicity.
Written in Python and running on top of established reinforcement learning libraries like
[tf-Agents](https://github.com/tensorflow/agents),
[tensorforce](https://github.com/tensorforce/tensorforce) or
[keras-rl](https://github.com/keras-rl/keras-rl).
Environments are implemented in [OpenAI gym](https://github.com/openai/gym).
For an example of an industrial application of reinforcement learning see [here](#Industrial-Application).
In collaboration with [Oliver Zeigermann](http://zeigermann.eu/).
### Features
---
* provides the **same, simple api across all libraries**. Thus you can easily switch between different implementations
and you don't have to learn for each of them a new api.
* to create and run any algorithm you only need **2 lines of code**, all the parameters are named
consistently across all algorithms.
* supports a broad set of different algorithms
* runs inside **jupyter notebooks** as well as stand-alone, easy to install requiring only a single
'pip install easyagents'.
* easy to understand, **ready-made plots** and logs to investigate the algorithms and environments behaviour
Note: keras-rl backend is suspended until support for tensorflow 2.0 is available.
### Examples
---
````
from easyagents.agents import PpoAgent
from easyagents.callbacks import plot
ppoAgent = PpoAgent('CartPole-v0')
ppoAgent.train([plot.State(), plot.Loss(), plot.Rewards()])
````
![Scenario_Simple](images/Scenario_simple.png)
#### More Detailed
````
from easyagents.agents import PpoAgent
from easyagents.callbacks import plot
ppoAgent = PpoAgent( 'Orso-v1',fc_layers=(500,500,500))
ppoAgent.train([plot.State(), plot.Loss(), plot.Rewards(), plot.Actions(),
plot.StepRewards(), plot.Steps(), plot.ToMovie()],
learning_rate = 0.0001, num_iterations = 500, max_steps_per_episode=50 )
````
![Scenario_Detailed](images/Scenario_detailed.gif)
### Tutorials
---
* [1. Introduction (CartPole on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_cartpole.ipynb):
training, plotting, switching algorithms & backends. Based on the classic reinforcement learning example
balancing a stick on a cart.
* [2. Next steps & backend switching (Orso on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_orso.ipynb):
custom training, creating a movie & switching backends. gym environment based on a routing problem.
* [3. Controlling training & evaluation (on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_train_args.ipynb):
or 'what do all these agent.train(...) args mean ?'
* [4. Creating your own environment (LineWorld on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_line.ipynb):
implement a gym environment from scratch, workshop example.
* [5. Saving & loading (on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_persistence.ipynb):
Once a policy is trained, save it and reload it in a production environment.
You may also save intermediate policies as the training proceeds.
* [6. Switching backends (on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_switching_backends.ipynb):
See how you can switch between backend implementations.
* [7. Api logging, seeding & plot clearing (on colab)](https://colab.research.google.com/github/christianhidber/easyagents/blob/master/jupyter_notebooks/intro_logging.ipynb):
Investigate how easyagent interacts with the backend api and the gym environment;
how to set seeds; controlling jupyter output cell clearing
### Available Algorithms and Backends
---
|algorithm | [tf-Agents](https://github.com/tensorflow/agents) | [tensorforce](https://github.com/tensorforce/tensorforce) | [keras-rl (suspended)](https://github.com/keras-rl/keras-rl) | easyagents class name |
|----------|:---------:|:-----------:|:--------:| :---: |
|[CEM](https://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.81.6579&rep=rep1&type=pdf) |`not available` |`not available` |`yes` | CemAgent |
|[Dqn](https://arxiv.org/abs/1312.5602) |`yes` |`yes` |`yes` | DqnAgent |
|[Double Dqn](https://arxiv.org/abs/1509.06461) |`open` |`not available` |`yes` | DoubleDqnAgent|
|[Dueling Dqn](https://arxiv.org/abs/1511.06581) |`not available` |`yes` |`yes` | DuelingDqnAgent|
|[Ppo](https://arxiv.org/abs/1707.06347) |`yes` |`yes` |`not available` | PpoAgent |
|Random |`yes` |`yes` |`not available` | RandomAgent |
|[REINFORCE](http://www-anw.cs.umass.edu/~barto/courses/cs687/williams92simple.pdf) |`yes` |`yes` |`not available`| ReinforceAgent |
|[SAC](https://arxiv.org/abs/1801.01290) |`preview` |`not available` |`not available`|SacAgent|
[191001]
* if you are interested in other algorithms, backends or hyperparameters let us know by
[creating an issue](https://github.com/christianhidber/easyagents/issues/new/choose).
We'll try our best to support you.
* for a documentation of the agents api see [here](https://christianhidber.github.io/easyagents/).
* starting with easyagents 1.3 (191102) the backend for keras-rl is suspended
until support for tensorflow 2.0 is available.
### Industrial Application
---
[Geberit](https://www.geberit.com/en/) - a sanitary technology company with > 12'000 employees -
produces in particular pipes and other parts to get rain-water of flat roofs - so called
[syphonic roof drainage systems](https://www.international.geberit.com/products/piping-systems-drainage/geberit-pluvia-roof-drainage/).
They warrant that large buildings like stadiums, airports or shopping malls do not collapse during
heavy rainfalls.
However it is surprisingly difficult to find the right dimensions for the pipes.
It is actually so difficult, that as of today **no feasable, deterministic algorithm** is known.
Thus traditional heuristics and classic machine learning were used to support the users
in finding a suitable solution.
Using reinforcement learning the failrate of the previous solution was reduced by 70%, resulting
in an end-to-end success-rate of > 98%.
<p align="center">
<img src="https://raw.githubusercontent.com/christianhidber/easyagents/master/images/Pluvia_small.png">
</p>
For more details take a look at this [talk](https://www.youtube.com/watch?v=3RjSanoNIlk).
### Installation
---
Install from pypi using pip:
```python
pip install easyagents
```
### More
---
#### Documentation
for [release notes & class diagram](documentation/Markdown/Release_Notes.md),
for [agents & api](https://christianhidber.github.io/easyagents/).
#### Guiding Principles
* easily train, evaluate & debug policies for (you own) gym environment over "designing new algorithms"
* simple & consistent over "flexible & powerful"
* inspired by keras:
* same api across all algorithms
* support different implementations of the same algorithm
* extensible (pluggable backends, plots & training schemes)
#### EasyAgents may not be ideal if
* you would like to leverage implementation specific advantages of an algorithm
* you want to do distributed or in parallel reinforcement learning
#### Note
* If you have any difficulties in installing or using easyagents please let us know by
[creating an issue](https://github.com/christianhidber/easyagents/issues/new/choose).
We'll try our best to help you.
* Any ideas, help, suggestions, comments etc in python / open source development / reinforcement learning / whatever
are more than welcome.