Skip to content

Commit

Permalink
[Doc] Fix typos (#2682)
Browse files Browse the repository at this point in the history
Co-authored-by: Vincent Moens <vincentmoens@gmail.com>
  • Loading branch information
codingWhale13 and vmoens authored Jan 9, 2025
1 parent d009835 commit f672c70
Show file tree
Hide file tree
Showing 6 changed files with 20 additions and 18 deletions.
19 changes: 11 additions & 8 deletions docs/source/reference/envs.rst
Original file line number Diff line number Diff line change
Expand Up @@ -218,7 +218,7 @@ The ``"_reset"`` key has two distinct functionalities:
modification will be lost. After this masking operation, the ``"_reset"``
entries will be erased from the :meth:`~.EnvBase.reset` outputs.

It must be pointed that ``"_reset"`` is a private key, and it should only be
It must be pointed out that ``"_reset"`` is a private key, and it should only be
used when coding specific environment features that are internal facing.
In other words, this should NOT be used outside of the library, and developers
will keep the right to modify the logic of partial resets through ``"_reset"``
Expand All @@ -243,7 +243,7 @@ designing reset functionalities:
``any`` or ``all`` logic depending on the task).
- When calling :meth:`env.reset(tensordict)` with a partial ``"_reset"`` entry
that will reset some but not all the done sub-environments, the input data
should contain the data of the sub-environemtns that are __not__ being reset.
should contain the data of the sub-environments that are __not__ being reset.
The reason for this constrain lies in the fact that the output of the
``env._reset(data)`` can only be predicted for the entries that are reset.
For the others, TorchRL cannot know in advance if they will be meaningful or
Expand All @@ -267,7 +267,7 @@ have on an environment returning zeros after reset:
>>> env.reset(data)
>>> print(data.get(("agent0", "val"))) # only the second value is 0
tensor([1, 0])
>>> print(data.get(("agent1", "val"))) # only the second value is 0
>>> print(data.get(("agent1", "val"))) # only the first value is 0
tensor([0, 2])
>>> # nested resets are overridden by a "_reset" at the root
>>> data = TensorDict({
Expand Down Expand Up @@ -573,7 +573,7 @@ Dynamic Specs
.. _dynamic_envs:

Running environments in parallel is usually done via the creation of memory buffers used to pass information from one
process to another. In some cases, it may be impossible to forecast whether and environment will or will not have
process to another. In some cases, it may be impossible to forecast whether an environment will or will not have
consistent inputs or outputs during a rollout, as their shape may be variable. We refer to this as dynamic specs.

TorchRL is capable of handling dynamic specs, but the batched environments and collectors will need to be made
Expand Down Expand Up @@ -670,9 +670,12 @@ Here is a working example:
is_shared=False,
stack_dim=0)

.. warning:: The absence of memory buffers in :class:`~torchrl.envs.ParallelEnv` and in data collectors can impact
performance of these classes dramatically. Any such usage should be carefully benchmarked against a plain execution on
a single process, as serializing and deserializing large numbers of tensors can be very expensive.
.. warning::
The absence of memory buffers in :class:`~torchrl.envs.ParallelEnv` and in
data collectors can impact performance of these classes dramatically. Any
such usage should be carefully benchmarked against a plain execution on a
single process, as serializing and deserializing large numbers of tensors
can be very expensive.

Currently, :func:`~torchrl.envs.utils.check_env_specs` will pass for dynamic specs where a shape varies along some
dimensions, but not when a key is present during a step and absent during others, or when the number of dimensions
Expand Down Expand Up @@ -941,7 +944,7 @@ formatted images (WHC or CWH).
>>> env.transform.dump() # Save the video and clear cache

Note that the cache of the transform will keep on growing until dump is called. It is the user responsibility to
take care of calling dumpy when needed to avoid OOM issues.
take care of calling `dump` when needed to avoid OOM issues.

In some cases, creating a testing environment where images can be collected is tedious or expensive, or simply impossible
(some libraries only allow one environment instance per workspace).
Expand Down
4 changes: 2 additions & 2 deletions torchrl/envs/transforms/transforms.py
Original file line number Diff line number Diff line change
Expand Up @@ -3533,7 +3533,7 @@ class DTypeCastTransform(Transform):
>>> print(td.get("not_transformed").dtype)
torch.float32
The same behavior is the rule when environments are constructedw without
The same behavior is the rule when environments are constructed without
specifying the transform keys:
Examples:
Expand Down Expand Up @@ -3903,7 +3903,7 @@ class DoubleToFloat(DTypeCastTransform):
>>> print(td.get("not_transformed").dtype)
torch.float32
The same behavior is the rule when environments are constructedw without
The same behavior is the rule when environments are constructed without
specifying the transform keys:
Examples:
Expand Down
4 changes: 2 additions & 2 deletions torchrl/modules/tensordict_module/probabilistic.py
Original file line number Diff line number Diff line change
Expand Up @@ -213,8 +213,8 @@ class SafeProbabilisticTensorDictSequential(
instances, terminating in ProbabilisticTensorDictModule, to be run
sequentially.
partial_tolerant (bool, optional): if ``True``, the input tensordict can miss some
of the input keys. If so, the only module that will be executed are those
who can be executed given the keys that are present. Also, if the input
of the input keys. If so, the only modules that will be executed are those
which can be executed given the keys that are present. Also, if the input
tensordict is a lazy stack of tensordicts AND if partial_tolerant is
``True`` AND if the stack does not have the required keys, then
TensorDictSequential will scan through the sub-tensordicts looking for those
Expand Down
2 changes: 1 addition & 1 deletion torchrl/modules/tensordict_module/sequence.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class SafeSequential(TensorDictSequential, SafeModule):
Args:
modules (iterable of TensorDictModules): ordered sequence of TensorDictModule instances to be run sequentially.
partial_tolerant (bool, optional): if ``True``, the input tensordict can miss some of the input keys.
If so, the only module that will be executed are those who can be executed given the keys that
If so, the only modules that will be executed are those which can be executed given the keys that
are present.
Also, if the input tensordict is a lazy stack of tensordicts AND if partial_tolerant is ``True`` AND if the
stack does not have the required keys, then SafeSequential will scan through the sub-tensordicts
Expand Down
2 changes: 1 addition & 1 deletion tutorials/sphinx-tutorials/getting-started-0.py
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@
print(reset_with_action["action"])

################################
# We now need to pass this action tp the environment.
# We now need to pass this action to the environment.
# We'll be passing the entire tensordict to the ``step`` method, since there
# might be more than one tensor to be read in more advanced cases like
# Multi-Agent RL or stateless environments:
Expand Down
7 changes: 3 additions & 4 deletions tutorials/sphinx-tutorials/multi_task.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,6 @@
# sphinx_gallery_start_ignore
import warnings

from tensordict import LazyStackedTensorDict

warnings.filterwarnings("ignore")

from torch import multiprocessing
Expand All @@ -32,6 +30,7 @@

# sphinx_gallery_end_ignore

from tensordict import LazyStackedTensorDict
from tensordict.nn import TensorDictModule, TensorDictSequential
from torch import nn

Expand Down Expand Up @@ -91,7 +90,7 @@
# ^^^^^^
#
# We will design a policy where a backbone reads the "observation" key.
# Then specific sub-components will ready the "observation_stand" and
# Then specific sub-components will read the "observation_stand" and
# "observation_walk" keys of the stacked tensordicts, if they are present,
# and pass them through the dedicated sub-network.

Expand Down Expand Up @@ -138,7 +137,7 @@
# Executing diverse tasks in parallel
# ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
#
# We can parallelize the operations if the common keys-value pairs share the
# We can parallelize the operations if the common key-value pairs share the
# same specs (in particular their shape and dtype must match: you can't do the
# following if the observation shapes are different but are pointed to by the
# same key).
Expand Down

1 comment on commit f672c70

@github-actions
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Performance Alert ⚠️

Possible performance regression was detected for benchmark 'CPU Benchmark Results'.
Benchmark result of this commit is worse than the previous benchmark result exceeding threshold 2.

Benchmark suite Current: f672c70 Previous: d009835 Ratio
benchmarks/test_replaybuffer_benchmark.py::test_rb_sample[TensorDictReplayBuffer-LazyMemmapStorage-RandomSampler-10000] 643.6479098900596 iter/sec (stddev: 0.03227955688678535) 1868.0755423919275 iter/sec (stddev: 0.00007699349336521317) 2.90
benchmarks/test_replaybuffer_benchmark.py::test_rb_populate[TensorDictPrioritizedReplayBuffer-LazyMemmapStorage-None-400] 35.82819193046635 iter/sec (stddev: 0.17966071463870026) 392.93898082119364 iter/sec (stddev: 0.0010673916474571651) 10.97

This comment was automatically generated by workflow using github-action-benchmark.

CC: @vmoens

Please sign in to comment.