rollout module¶
Methods to collect, analyze and manipulate transition and trajectory rollouts. Code adopted from https://github.com/HumanCompatibleAI/imitation.git
- class rollout.TrajectoryAccumulator¶
Bases:
object
Accumulates trajectories step-by-step.
Useful for collecting completed trajectories while ignoring partially-completed trajectories (e.g. when rolling out a VecEnv to collect a set number of transitions). Each in-progress trajectory is identified by a ‘key’, which enables several independent trajectories to be collected at once. They key can also be left at its default value of None if you only wish to collect one trajectory.
- add_step(step_dict: Mapping[str, numpy.ndarray], key: collections.abc.Hashable = None) None ¶
Add a single step to the partial trajectory identified by key.
Generally a single step could correspond to, e.g., one environment managed by a VecEnv.
- Args:
- step_dict: dictionary containing information for the current step. Its
keys could include any (or all) attributes of a TrajectoryWithRew (e.g. “obs”, “acts”, etc.).
- key: key to uniquely identify the trajectory to append to, if working
with multiple partial trajectories.
- add_steps_and_auto_finish(acts: numpy.ndarray, obs: numpy.ndarray, rews: numpy.ndarray, dones: numpy.ndarray, infos: List[dict], manual: False) List[types_unique.TrajectoryWithRew] ¶
Calls add_step repeatedly using acts and the returns from venv.step.
Also automatically calls finish_trajectory() for each done == True. Before calling this method, each environment index key needs to be initialized with the initial observation (usually from venv.reset()).
See the body of util.rollout.generate_trajectory for an example.
- Args:
acts: Actions passed into VecEnv.step(). obs: Return value from VecEnv.step(acts). rews: Return value from VecEnv.step(acts). dones: Return value from VecEnv.step(acts). infos: Return value from VecEnv.step(acts).
- Returns:
A list of completed trajectories. There should be one trajectory for each True in the dones argument.
- finish_trajectory(key: collections.abc.Hashable, terminal: bool) types_unique.TrajectoryWithRew ¶
Complete the trajectory labelled with key.
- Args:
key: key uniquely identifying which in-progress trajectory to remove. terminal: trajectory has naturally finished (i.e. includes terminal state).
- Returns:
- traj: list of completed trajectories popped from
self.partial_trajectories.
- rollout.discounted_sum(arr: numpy.ndarray, gamma: float) Union[numpy.ndarray, float] ¶
Calculate the discounted sum of arr.
If arr is an array of rewards, then this computes the return; however, it can also be used to e.g. compute discounted state occupancy measures.
- Args:
- arr: 1 or 2-dimensional array to compute discounted sum over.
Last axis is timestep, from current time step (first) to last timestep (last). First axis (if present) is batch dimension.
gamma: the discount factor used.
- Returns:
The discounted sum over the timestep axis. The first timestep is undiscounted, i.e. we start at gamma^0.
- rollout.flatten_trajectories(trajectories: Sequence[types_unique.Trajectory]) types_unique.Transitions ¶
Flatten a series of trajectory dictionaries into arrays.
- Args:
trajectories: list of trajectories.
- Returns:
The trajectories flattened into a single batch of Transitions.
- rollout.flatten_trajectories_with_rew(trajectories: Sequence[types_unique.TrajectoryWithRew]) types_unique.TransitionsWithRew ¶
- rollout.generate_trajectories(policy: typing.Optional[typing.Union[stable_baselines3.common.base_class.BaseAlgorithm, stable_baselines3.common.policies.BasePolicy, typing.Callable[numpy.ndarray, numpy.ndarray]]], venv: stable_baselines3.common.vec_env.base_vec_env.VecEnv, sample_until: typing.Callable[typing.Sequence[types_unique.TrajectoryWithRew], bool], *, deterministic_policy: bool = False, rng: numpy.random.mtrand.RandomState = <module 'numpy.random' from 'C:\\Users\\asahu\\.conda\\envs\\generic_gym_env\\lib\\site-packages\\numpy\\random\\__init__.py'>) Sequence[types_unique.TrajectoryWithRew] ¶
Generate trajectory dictionaries from a policy and an environment.
- Args:
- policy: Can be any of the following:
A stable_baselines3 policy or algorithm trained on the gym environment.
2) A Callable that takes an ndarray of observations and returns an ndarray of corresponding actions. 3) None, in which case actions will be sampled randomly.
venv: The vectorized environments to interact with. sample_until: A function determining the termination condition.
It takes a sequence of trajectories, and returns a bool. Most users will want to use one of min_episodes or min_timesteps.
- deterministic_policy: If True, asks policy to deterministically return
action. Note the trajectories might still be non-deterministic if the environment has non-determinism!
rng: used for shuffling trajectories.
- Returns:
Sequence of trajectories, satisfying sample_until. Additional trajectories may be collected to avoid biasing process towards short episodes; the user should truncate if required.
- rollout.generate_transitions(policy: Optional[Union[stable_baselines3.common.base_class.BaseAlgorithm, stable_baselines3.common.policies.BasePolicy, Callable[numpy.ndarray, numpy.ndarray]]], venv: stable_baselines3.common.vec_env.base_vec_env.VecEnv, n_timesteps: int, *, truncate: bool = True, **kwargs) types_unique.TransitionsWithRew ¶
Generate obs-action-next_obs-reward tuples.
- Args:
- policy: Can be any of the following:
A stable_baselines3 policy or algorithm trained on the gym environment
A Callable that takes an ndarray of observations and returns an ndarray
of corresponding actions - None, in which case actions will be sampled randomly
venv: The vectorized environments to interact with. n_timesteps: The minimum number of timesteps to sample. truncate: If True, then drop any additional samples to ensure that exactly
n_timesteps samples are returned.
**kwargs: Passed-through to generate_trajectories.
- Returns:
A batch of Transitions. The length of the constituent arrays is guaranteed to be at least n_timesteps (if specified), but may be greater unless truncate is provided as we collect data until the end of each episode.
- rollout.make_min_episodes(n: int) Callable[Sequence[types_unique.TrajectoryWithRew], bool] ¶
Terminate after collecting n episodes of data.
- Args:
- n: Minimum number of episodes of data to collect.
May overshoot if two episodes complete simultaneously (unlikely).
- Returns:
A function implementing this termination condition.
- rollout.make_min_timesteps(n: int) Callable[Sequence[types_unique.TrajectoryWithRew], bool] ¶
Terminate at the first episode after collecting n timesteps of data.
- Args:
- n: Minimum number of timesteps of data to collect.
May overshoot to nearest episode boundary.
- Returns:
A function implementing this termination condition.
- rollout.make_sample_until(min_timesteps: Optional[int], min_episodes: Optional[int]) Callable[Sequence[types_unique.TrajectoryWithRew], bool] ¶
Returns a termination condition sampling for a number of timesteps and episodes.
- Args:
- min_timesteps: Sampling will not stop until there are at least this many
timesteps.
- min_episodes: Sampling will not stop until there are at least this many
episodes.
- Returns:
A termination condition.
- Raises:
- ValueError: Neither of n_timesteps and n_episodes are set, or either are
non-positive.
- rollout.rollout(policy: Optional[Union[stable_baselines3.common.base_class.BaseAlgorithm, stable_baselines3.common.policies.BasePolicy, Callable[numpy.ndarray, numpy.ndarray]]], venv: stable_baselines3.common.vec_env.base_vec_env.VecEnv, sample_until: Callable[Sequence[types_unique.TrajectoryWithRew], bool], *, unwrap: bool = True, exclude_infos: bool = True, verbose: bool = True, **kwargs) Sequence[types_unique.TrajectoryWithRew] ¶
Generate policy rollouts.
The .infos field of each Trajectory is set to None to save space.
- Args:
- policy: Can be any of the following:
A stable_baselines3 policy or algorithm trained on the gym environment.
2) A Callable that takes an ndarray of observations and returns an ndarray of corresponding actions. 3) None, in which case actions will be sampled randomly.
venv: The vectorized environments. sample_until: End condition for rollout sampling. unwrap: If True, then save original observations and rewards (instead of
potentially wrapped observations and rewards) by calling unwrap_traj().
- exclude_infos: If True, then exclude infos from pickle by setting
this field to None. Excluding infos can save a lot of space during pickles.
verbose: If True, then print out rollout stats before saving. **kwargs: Passed through to generate_trajectories.
- Returns:
Sequence of trajectories, satisfying sample_until. Additional trajectories may be collected to avoid biasing process towards short episodes; the user should truncate if required.
- rollout.rollout_stats(trajectories: Sequence[types_unique.TrajectoryWithRew]) Mapping[str, float] ¶
Calculates various stats for a sequence of trajectories.
- Args:
trajectories: Sequence of trajectories.
- Returns:
Dictionary containing n_traj collected (int), along with episode return statistics (keys: {monitor_,}return_{min,mean,std,max}, float values) and trajectory length statistics (keys: len_{min,mean,std,max}, float values).
return_* values are calculated from environment rewards. monitor_* values are calculated from Monitor-captured rewards, and are only included if the trajectories contain Monitor infos.
- rollout.unwrap_traj(traj: types_unique.TrajectoryWithRew) types_unique.TrajectoryWithRew ¶
Uses RolloutInfoWrapper-captured obs and rews to replace fields.
This can be useful for bypassing other wrappers to retrieve the original obs and rews.
Fails if infos is None or if the trajectory was generated from an environment without imitation.util.rollout.RolloutInfoWrapper
- Args:
traj: A trajectory generated from RolloutInfoWrapper-wrapped Environments.
- Returns:
A copy of traj with replaced obs and rews fields.