Reinforcement learning framework built in modern Python for experimentation, ease-of-use, modularity, and extensibility.
Decuen (dee-kew-en) is a reinforcement learning framework built in modern Python for experimentation, ease-of-use, modularity, and extensibility. Containing building blocks for modern reinforcement learning systems and modular implementations of common reinforcement learning algorithms, Decuen provides a platform for rapid iterative experimentation of new reinforcement learning systems.
Decuen has a robust Python API with type annotations (see the Python typing module) which provides developers and users with a clear view of API contracts that can accelerate debugging on both the developer and user side.
Decuen development and design is lead by Ziyad Edher .
The development of Decuen follows a small but effective set of guiding principles that attempts to span and encapsulate our vision of what Decuen is to be:
- Ease of use. Decuen provides an API that follows existing standards, terminology, and intuitions popularized in modern reinforcement learning literature. Following these standards allows the usage of Decuen to come as second-nature to developers or researchers already familiar with reinforcement learning. Development of Decuen follows this standard to reduce the barrier-of-entry to using the framework.
- Extensibility. Decuen is intended for quick, iterative development and experimentation of reinforcement learning systems, and as such the ability to easily extend Decuen source code is of utmost importance. Decuen achieves this by providing well-documented and typed source code with thoughtfully designed interfaces and abstractions.
- Modularity. Decuen strives to be a tool for developers and researchers alike to be able to create reinforcement learning mechanisms without reinventing the wheel. Decuen implements all algorithms in a modular "building blocks" fashion to allow the plug-and-play of different modules in the larger system. This allows the independent design and development of new components to be tested as replacements for modules in current reinforcement learning systems.
- Transparency. Decuen strives to be as transparent as possible in its interfaces and abstractions to facilitate as many dimensions of change as possible. Abstractions, interfaces, and implementations are not closed-off and tend to provide as much information about internal processes as possible while abiding by our standard of modularity and extensibility.
Package is not yet released on PyPI for basic release installation.
decuen from source is very simple given the framework is entirely written in modern Python:
0. Be in the environment you would like to install
- Clone the repository:
git clone https://github.com/ziyadedher/decuen.
decueninto your environment:
cd decuen && pip install ..
decuen, the framework is completely ready to be used. Detailed usage instructions, tutorials, examples, and more can be found in the Decuen Wiki.
decuen from source in your environment, there is a step to perform before the project is ready to be developed on:
decuenin editable mode with linting and testing libraries:
pip install -e '.[lint, test]'.
Now the project is ready to be developed. Note that in order to make sure that the CI/CD pipeline passes on your merge request, verify that our linter
prospector does not produce any errors or warnings. You can also use
tox to run the linter.
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size decuen-0.0.3-py2.py3-none-any.whl (4.2 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View hashes|
|Filename, size decuen-0.0.3.tar.gz (4.5 kB)||File type Source||Python version None||Upload date||Hashes View hashes|
Hashes for decuen-0.0.3-py2.py3-none-any.whl