Skip to main content

A library for Reinforcement Learning

Project description

# anyrl-py

This is a Python remake (and makeover) of [anyrl](https://github.com/unixpickle/anyrl). It is a general-purpose library for Reinforcement Learning which aims to be as modular as possible.

# Installation

You can install anyrl with pip:

```
pip install anyrl
```

# APIs

There are several different sub-modules in anyrl:

* `models`: abstractions and concrete implementations of RL models. This includes actor-critic RNNs, MLPs, CNNs, etc. Takes care of sequence padding, BPTT, etc.
* `envs`: APIs for dealing with environments, including wrappers and asynchronous environments.
* `rollouts`: APIs for gathering and manipulating batches of episodes or partial episodes. Many RL algorithms include a "gather trajectories" step, and this sub-module fulfills that role.
* `algos`: well-known learning algorithms like policy gradients or PPO. Also includes mini-algorithms like Generalized Advantage Estimation.
* `spaces`: tools for using action and observation spaces. Includes parameterized probability distributions for implementing stochastic policies.

# Motivation

Currently, most RL code out there is very restricted and not properly decoupled. In contrast, anyrl aims to be extremely modular and flexible. The goal is to decouple agents, learning algorithms, trajectories, and things like GAE.

For example, anyrl decouples rollouts from the learning algorithm (when possible). This way, you can gather rollouts in several different ways and still feed the results into one learning algorithm. Further, and more obviously, you don't have to rewrite rollout code for every new RL algorithm you implement. However, algorithms like A3C and Evolution Strategies may have specific ways of performing rollouts that can't rely on the rollout API.

# Use of TensorFlow

This project relies on TensorFlow for models and training algorithms. However, anyrl APIs are framework-agnostic when possible. For example, the rollout API can be used with any policy, whether it's a TensorFlow neural network or a native-Python decision forest.

# Style

I use `autopep8` and `pylint`. Here is the command you can use to run autopep8:

```
autopep8 --recursive --in-place --max-line-length 100 .
```

I recommend the following lines in your pylintrc:

```
ignored-modules=numpy,mpi4py

disable=C,R
```

# TODO

Here is the current TODO list, organized by sub-module:

* `models`
* Unify CNN and MLP models with a single base class.
* Unshared actor-critics for TRPO and the like.
* `rollouts`
* Optimize for sub-batches in `BatchedPlayer`.
* `algos`
* TRPO
* PPO: allow clipping for value function
* `spaces`
* Dict
* `tests`
* Benchmarks for rollouts
* Benchmarks for training


Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

anyrl-0.11.25.tar.gz (56.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

anyrl-0.11.25-py3-none-any.whl (78.4 kB view details)

Uploaded Python 3

File details

Details for the file anyrl-0.11.25.tar.gz.

File metadata

  • Download URL: anyrl-0.11.25.tar.gz
  • Upload date:
  • Size: 56.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for anyrl-0.11.25.tar.gz
Algorithm Hash digest
SHA256 ba3c1c89a212cee47d06ad56bfd55e62a1aebd0fbd6a4fdd5f4b1ac8eaec16f2
MD5 446099c856a8237b850913aca10c3927
BLAKE2b-256 73c81afccee96dcf4dd6791443f6a42259e1668670d1e959f5fa067356e97c90

See more details on using hashes here.

File details

Details for the file anyrl-0.11.25-py3-none-any.whl.

File metadata

File hashes

Hashes for anyrl-0.11.25-py3-none-any.whl
Algorithm Hash digest
SHA256 b49cd75e1b9d5b265f502243c0d8cc3e24df04eb47afcc63c496f7c207707d27
MD5 c075c991da672417c88d96fa68561b91
BLAKE2b-256 00a72a7cf60c9473353d4708e49dfa7c004977969259a3ed081dbcd611072a97

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page