Now Reading
Hands-on to ReAgent: End-to-End Platform for Applied Reinforcement Learning

Hands-on to ReAgent: End-to-End Platform for Applied Reinforcement Learning


Facebook ReAgent, previously known as Horizon is an end-to-end platform for using applied Reinforcement Learning in order to solve industrial problems. The main purpose of this framework is to make the development & experimentation of deep reinforcement algorithms fast. ReAgent is built on Python. It uses PyTorch framework for data modelling 

And training and TorchScript for serving. ReAgent holds different algorithms for data preprocessing, feature engineering, model training & evaluation and lastly for optimized serving. ReAgent was first presented in the research paperHorizon: Facebook’s Open Source Applied Reinforcement Learning Platform by Jason Gauci, Edoardo Conti, Yitao Liang, Kittipat Virochsiri, Yuchen He, Zachary Kaden, Vivek Narayanan, Xiaohui Ye, Zhengxing Chen, Scott Fujimoto.

The key features of Facebook’s ReAgent are :

  • Capable of handling Large-dimension datasets.
  • Provides optimized algorithms for data preprocessing, training, etc.
  • Gives a highly efficient production environment for model serving.

Algorithms Supported by ReAgent

Workflow of ReAgent

The image below shows the overall workflow of ReAgent for decision making and reasoning. It starts its decision-making process by using predefined rules and then with the help of feedback, multi-armed bandits, those decisions are optimized and at last, contextual feedback trains the contextual bandits and reinforcement learning models. These trained models are then deployed via TorchScript library.

Dependencies of ReAgent Platform

Python >=3.7


ReAgent can be installed using the docker image and manually.  In this case, we are cloning the GitHub repository and installing all the required dependencies of ReAgent via pip.

 git clone
 %cd /content/ReAgent/ 

Then install the required python packages:

!pip install -r requirements.txt 

Additionally, install:

 !pip install pytorch_lightning
 !pip install --pre torch torchvision -f
 !pip install ".[gym]" 

You can check the detailed-installation process here and usage of ReAgent is discussed here.

To know more about ReAgent Serving Platform(RASP), you can check this documentation.

Demo – Reinforcement Learning on CartPole Problem

See Also
ResNet50 in PyTorch with TPU

This demo explains the usage of ReAgent on CartPole reinforcement learning. The code below uses the OpenAI Gym environment.

  1. Import all the required modules and packages.
 from reagent.gym.envs.gym import Gym
 import pandas as pd
 from matplotlib import pyplot as plt
 import seaborn as sns
 import numpy as np
 import torch
 import torch.nn.functional as F
 import tqdm.autonotebook as tqdm 
  1. Define the environment by passing CartPole to the Gym class.
 env = Gym('CartPole-v0')
 def reset_env(env, seed):
 reset_env(env, seed=0) 
  1. Next, is to create a policy which contains a simple scorer or Multilayer perceptron network and softmax sampler.
from reagent.net_builder.discrete_dqn.fully_connected import FullyConnected
 from reagent.gym.utils import build_normalizer
 norm = build_normalizer(env)
 net_builder = FullyConnected(sizes=[8], activations=["linear"])
 cartpole_scorer = net_builder.build_q_network(

The idea behind the policy is that agents will simply execute this cart pole environment.

 from reagent.gym.policies.policy import Policy
 from reagent.gym.policies.samplers.discrete_sampler import SoftmaxActionSampler
 from reagent.gym.agents.agent import Agent
 policy = Policy(scorer=cartpole_scorer, sampler=SoftmaxActionSampler())
 agent = Agent.create_for_env(env, policy) 
  1. Now, create a trainer that takes reinforcement learning algorithms to train. The following trainer can be created from the commands below:
 from import (
     Reinforce, ReinforceParams
 from reagent.optimizer.union import classes
 trainer = Reinforce(policy, ReinforceParams(
     optimizer=classes['Adam'](lr=5e-3, weight_decay=1e-3)
  1. After creating a Trainer, start the training of the model by creating a function that changes the observed transitions into a training batch and then evaluating the reward for all episodes via RL interaction loop. The code for it is shown below:
 import reagent.types as rlt
 def to_train_batch(trajectory):
     return rlt.PolicyGradientInput(
         action=F.one_hot(torch.from_numpy(np.stack(trajectory.action)), 2),

    Run agent on the environment and record the rewards.

 from reagent.gym.runners.gymrunner import evaluate_for_n_episodes
 eval_rewards = evaluate_for_n_episodes(100, env, agent, 500, num_processes=20)
 Start the loop
 num_episodes = 200
 reward_min = 20
 max_steps = 200
 reward_decay = 0.8
 train_rewards = []
 running_reward = reward_min
 from reagent.gym.runners.gymrunner import run_episode
 with tqdm.trange(num_episodes, unit=" epoch") as t:
     for i in t:
         trajectory = run_episode(env, agent, max_steps=max_steps, mdp_id=i)
         batch = to_train_batch(trajectory)
         ep_reward = trajectory.calculate_cumulative_reward(1.0)
         running_reward *= reward_decay
         running_reward += (1 - reward_decay) * ep_reward
  1. Finally, print all the rewards on each training episode in a form of the graph as shown below.


In this write-up, we have discussed ReAgent Platform aka Horizon and its demo with an example of CartPole Problem with reinforcement learning. 

Note : The codes mentioned above are not suitable for colab, due to some dependency issues. The following is the Jupyter Notebook file, to reproduce the above experiment.

Official Codes, Docs & Tutorials are available at:

Join Our Telegram Group. Be part of an engaging online community. Join Here.

Subscribe to our Newsletter

Get the latest updates and relevant offers by sharing your email.

Copyright Analytics India Magazine Pvt Ltd

Scroll To Top