Skip to main content

TensorTrade-NG: A reinforcement learning library for training, evaluating, and deploying robust trading agents.

Project description

Apache License Python 3.12



ℹ️ TensorTrade-NG was forked from the TensorTrade-Project, mainly because the code needed a lot refactoring, was outdated and it looked not really maintained anymore. Therefor we did a lot of breaking changes, removed old unused stuff and cleaned up. We tried to preserve the APIs but if you want to switch from TensorTrade to TensorTrade-NG be aware that it may take a little bit of effort. Apart from that we thank all the former developers and community for their awesome work and are happy to welcome them here.

TensorTrade-NG is still in Beta, meaning it should be used very cautiously if used in production, as it may contain bugs.

TensorTrade-NG is an open source Python framework for building, training, evaluating, and deploying robust trading algorithms using reinforcement learning. The framework focuses on being highly composable and extensible, to allow the system to scale from simple trading strategies on a single CPU, to complex investment strategies run on a distribution of HPC machines.

Under the hood, the framework uses many of the APIs from existing machine learning libraries to maintain high quality data pipelines and learning models. One of the main goals of TensorTrade is to enable fast experimentation with algorithmic trading strategies, by leveraging the existing tools and pipelines provided by numpy, pandas and gymnasium. The idea behind Tensorflow-NG is not to implement all the machine learning stuff itself. But to provide a solid framework that makes it possible to quickly provide a working environment for other tools such as Stable-Baselines3.

Every piece of the framework is split up into re-usable components, allowing you to take advantage of the general use components built by the community, while keeping your proprietary features private. The aim is to simplify the process of testing and deploying robust trading agents using deep reinforcement learning, to allow you and I to focus on creating profitable strategies.

The goal of this framework is to enable fast experimentation, while maintaining production-quality data pipelines.

Read the documentation.

Guiding principles

Inspired by Keras' guiding principles.

  • User friendliness. TensorTrade is an API designed for human beings, not machines. It puts user experience front and center. TensorTrade follows best practices for reducing cognitive load: it offers consistent & simple APIs, it minimizes the number of user actions required for common use cases, and it provides clear and actionable feedback upon user error.

  • Modularity. A trading environment is a conglomeration of fully configurable modules that can be plugged together with as few restrictions as possible. In particular, exchanges, feature pipelines, action schemes, reward schemes, trading agents, and performance reports are all standalone modules that you can combine to create new trading environments.

  • Easy extensibility. New modules are simple to add (as new classes and functions), and existing modules provide ample examples. To be able to easily create new modules allows for total expressiveness, making TensorTrade suitable for advanced research and production use.

Getting Started

You can get started testing on Google Colab or your local machine, by viewing our many examples.

Recommended beginning points:

Installation

TensorTrade-NG requires Python >= 3.12.0 for all functionality to work as expected.

As package

You can install TensorTrade-NG both as a pre-packaged solution by running the default setup command.

pip install tensortrade-ng

Via git

You can also alternatively install TensorTrade-NG directly from the master code repository, pulling directly from the latest commits. This will give you the latest features/fixes, but it is highly untested code, so proceed at your own risk.

pip install git+https://github.com/erhardtconsulting/tensortrade-ng.git

Cloning the repository

⚠️ Warning: This repository uses git-lfs for storing the Jupyter Notebooks and other big files. Make sure to install the git-lfs Extension before cloning the repository.

You can clone/download the repository in your local environment and manually install the requirements, either the "base" ones, or the ones that also include requirements to run the examples in the documentation.

# install only base requirements
pip install -e .

# install all requirements
pip install -e ".[dev]"

Build Documentation

You can either build the documentation once or serve it locally.

Prerequisites: You need to have pandoc installed locally for converting jupyter notebooks. Otherwise it won't work. The pip-version won't work, because it's just a wrapper. You need to use your package manager, like brew or apt.

Run documentation as local webserver

hatch run docs:serve

Build documentation

hatch run docs:build

Run Test Suite

To run the test suite, execute the following command.

hatch test

Support

You can also post bug reports and feature requests in GitHub issues. Make sure to read our guidelines first.

If you have questions or anything else that needs to be discussed. Please use GitHub Discussions rather than opening an issue.

Contributors

Contributions are encouraged and welcomed. This project is meant to grow as the community around it grows. Let us know on GitHub Discussions if there is anything that you would like to see in the future, or if there is anything you feel is missing.

Working on your first Pull Request? You can learn how from this free series How to Contribute to an Open Source Project on GitHub.

https://github.com/erhardtconsulting/tensortrade-ng/graphs/contributors

Project details


Download files

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

Source Distribution

tensortrade_ng-2.0.0a1.tar.gz (70.7 kB view details)

Uploaded Source

Built Distribution

tensortrade_ng-2.0.0a1-py3-none-any.whl (124.2 kB view details)

Uploaded Python 3

File details

Details for the file tensortrade_ng-2.0.0a1.tar.gz.

File metadata

  • Download URL: tensortrade_ng-2.0.0a1.tar.gz
  • Upload date:
  • Size: 70.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for tensortrade_ng-2.0.0a1.tar.gz
Algorithm Hash digest
SHA256 53328e2f7601248081359306de5a18473b25101fc9d3dffa4c99e849befdd204
MD5 59b7a020fa916d959ac45640f4e54660
BLAKE2b-256 17fcc7cf19e27c04a7747e29a42667057b8d1ea78e8940989a03205bf6073b3e

See more details on using hashes here.

File details

Details for the file tensortrade_ng-2.0.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for tensortrade_ng-2.0.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 ee1321866f07a472059be7c77133e7b8b7c5d98315c59b31b62d498bd4b51db8
MD5 470b0f21c57bbacfb6161a224a82175c
BLAKE2b-256 e83461cfc204123363b05c0a71a6586b2840cc41e14d63f6e283376b65c9e2c2

See more details on using hashes here.

Supported by

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