Source code for alf.algorithms.on_policy_algorithm

# Copyright (c) 2019 Horizon Robotics. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#      http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Base class for on-policy RL algorithms."""

from alf.algorithms.off_policy_algorithm import OffPolicyAlgorithm


[docs]class OnPolicyAlgorithm(OffPolicyAlgorithm): """OnPolicyAlgorithm implements the basic on-policy training procedure. User needs to implement ``rollout_step()`` and ``calc_loss()``. ``rollout_step()`` is called to generate actions for every environment step. It also needs to generate necessary information for training. ``update_with_gradient()`` is called every ``unroll_length`` steps (specified in ``config.TrainerConfig``). All the training information collected by every ``rollout_step()`` are batched and provided as arguments for ``calc_loss()``. The following is the pseudo code to illustrate how ``OnPolicyAlgorithm`` can be used: .. code-block:: python for _ in range(unroll_length): policy_step = rollout_step(time_step, policy_step.state) collect information from time_step into experience collect information from policy_step.info into train_info time_step = env.step(policy_step.output) loss = calc_loss(experience, train_info) update_with_gradient(loss) """ @property def on_policy(self): return True # Implement train_step() to allow off-policy training for an # OnPolicyAlgorithm
[docs] def train_step(self, inputs, state, rollout_info): return self.rollout_step(inputs, state)