Source code for ray.rllib.utils.schedules.constant_schedule
from typing import Optional
from ray.rllib.utils.annotations import OldAPIStack, override
from ray.rllib.utils.framework import try_import_tf
from ray.rllib.utils.schedules.schedule import Schedule
from ray.rllib.utils.typing import TensorType
tf1, tf, tfv = try_import_tf()
[docs]
@OldAPIStack
class ConstantSchedule(Schedule):
"""A Schedule where the value remains constant over time."""
[docs]
def __init__(self, value: float, framework: Optional[str] = None):
"""Initializes a ConstantSchedule instance.
Args:
value: The constant value to return, independently of time.
framework: The framework descriptor string, e.g. "tf",
"torch", or None.
"""
super().__init__(framework=framework)
self._v = value
@override(Schedule)
def _value(self, t: TensorType) -> TensorType:
return self._v
@override(Schedule)
def _tf_value_op(self, t: TensorType) -> TensorType:
return tf.constant(self._v)