Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add VectorizeMode for make_vec #765

Closed
Changes from 1 commit
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
97ac1eb
Remove deprecated features (#609)
pseudo-rnd-thoughts Jul 15, 2023
d4aa544
Merge experimental functional api into root (#610)
pseudo-rnd-thoughts Jul 16, 2023
68a6a25
Merge experimental vector into root (#613)
pseudo-rnd-thoughts Jul 17, 2023
e49cdc8
Merge experimental wrappers to root (#614)
pseudo-rnd-thoughts Jul 18, 2023
0d78c98
[WIP] Merge stateful observation tests to main tests suite (#623)
jjshoots Jul 22, 2023
d932fe9
Update vector docs (#624)
pseudo-rnd-thoughts Jul 24, 2023
b754b5d
Update all of the docs to v1.0.0 (#637)
pseudo-rnd-thoughts Jul 31, 2023
93f6448
ENH: Add NormalizeReward & NormalizeObservation vector wrappers (#632)
younik Aug 2, 2023
f159ab4
Remove `VectorWrapper.__getattr__` (#645)
pseudo-rnd-thoughts Aug 3, 2023
04a8548
Update docs 2 (#649)
pseudo-rnd-thoughts Aug 4, 2023
700ffd0
Automatically generate the list of wrappers using their first line in…
pseudo-rnd-thoughts Aug 5, 2023
a220735
Merge experimental wrappers tests into wrappers tests (#656)
pseudo-rnd-thoughts Aug 7, 2023
02b7d6d
Improve the normalize vector wrapper tests (#659)
pseudo-rnd-thoughts Aug 10, 2023
e98bbad
Reduce the number of CI warnings (#663)
pseudo-rnd-thoughts Aug 10, 2023
937177d
Update version to v1.0.0a1
pseudo-rnd-thoughts Aug 10, 2023
f686481
Add more examples to docs for wrappers (#657)
jjshoots Aug 21, 2023
24cc085
Rename `AsyncVectorEnv` or `SyncVectorEnv` attributes (#678)
pseudo-rnd-thoughts Aug 21, 2023
e3ec4b8
Remove wrapper version numbers (#665)
pseudo-rnd-thoughts Aug 21, 2023
0bc7f1e
Support `gym.make_vec(envs.spec)` (#679)
pseudo-rnd-thoughts Aug 21, 2023
dcd9ab9
Add `VectorEnv.render` function (#666)
pseudo-rnd-thoughts Aug 21, 2023
36a446b
Remove old testing code (#680)
pseudo-rnd-thoughts Aug 22, 2023
ff1128f
Add `Wrapper.set_wrapper_attr` and fix issue 357 (#681)
pseudo-rnd-thoughts Aug 22, 2023
d2efa7c
Change to release candidate from alpha
pseudo-rnd-thoughts Aug 22, 2023
76e8871
Improve the documentation (#688)
pseudo-rnd-thoughts Aug 26, 2023
c48cbd7
Fixed `VectorizeTransformAction` and `VectorizeTransformObservation` …
jjshoots Aug 26, 2023
65c62eb
Remove `Autoreset.spec`, add type hints to `TimeLimit`, correct type …
pseudo-rnd-thoughts Aug 28, 2023
80ef108
Add change logs to wrapper documentation (#696)
pseudo-rnd-thoughts Aug 29, 2023
f7f0363
Add dtype check to `Box.__eq__` and `MultiDiscrete.__eq__` (#707)
pseudo-rnd-thoughts Sep 5, 2023
0313eac
add examples for vector wrappers (#673)
jjshoots Sep 5, 2023
2af443f
Add `make(max_episode_steps=0)` to not apply a `TimeLimit` wrapper (#…
pseudo-rnd-thoughts Sep 8, 2023
ce01fd9
Update `make_vec(vectorization_mode)` to default to `None` and use `v…
pseudo-rnd-thoughts Sep 8, 2023
adcc405
Update `make_vec` to use `make` for `async` and `sync` (#711)
pseudo-rnd-thoughts Sep 8, 2023
16f3a4e
Option to save frames to disk in video recorder (#715)
rk1a Sep 20, 2023
6d492ea
Fix CI problems of #715 (#719)
rk1a Sep 20, 2023
00a62a0
Add VectorizeMode for `make_vec`
pseudo-rnd-thoughts Nov 7, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Support gym.make_vec(envs.spec) (#679)
  • Loading branch information
pseudo-rnd-thoughts authored Aug 21, 2023
commit 0bc7f1e6dbca73929a1fd8dd81ad82278fa61e00
17 changes: 15 additions & 2 deletions gymnasium/envs/registration.py
Original file line number Diff line number Diff line change
@@ -833,16 +833,21 @@ def make_vec(
"""
if vector_kwargs is None:
vector_kwargs = {}

if wrappers is None:
wrappers = []

if isinstance(id, EnvSpec):
spec_ = id

_kwargs = spec_.kwargs.copy()
num_envs = _kwargs.pop("num_envs", num_envs)
vectorization_mode = _kwargs.pop("vectorization_mode", vectorization_mode)
vector_kwargs = _kwargs.pop("vector_kwargs", vector_kwargs)
wrappers = _kwargs.pop("wrappers", wrappers)
else:
spec_ = _find_spec(id)
_kwargs = spec_.kwargs.copy()

_kwargs = spec_.kwargs.copy()
_kwargs.update(kwargs)

# Check if we have the necessary entry point
@@ -913,6 +918,14 @@ def _create_env() -> Env:
# Copies the environment creation specification and kwargs to add to the environment specification details
spec_ = copy.deepcopy(spec_)
spec_.kwargs = _kwargs
if num_envs != 1:
spec_.kwargs["num_envs"] = num_envs
if vectorization_mode != "async":
spec_.kwargs["vectorization_mode"] = vectorization_mode
if vector_kwargs is not None:
spec_.kwargs["vector_kwargs"] = vector_kwargs
if wrappers is not None:
spec_.kwargs["wrappers"] = wrappers
env.unwrapped.spec = spec_

return env
5 changes: 5 additions & 0 deletions gymnasium/vector/async_vector_env.py
Original file line number Diff line number Diff line change
@@ -53,10 +53,15 @@ class AsyncVectorEnv(VectorEnv):

Example:
>>> import gymnasium as gym
>>> envs = gym.make_vec("Pendulum-v1", num_envs=2, vectorization_mode="async")
>>> envs
AsyncVectorEnv(Pendulum-v1, num_envs=2)
>>> envs = gym.vector.AsyncVectorEnv([
... lambda: gym.make("Pendulum-v1", g=9.81),
... lambda: gym.make("Pendulum-v1", g=1.62)
... ])
>>> envs
AsyncVectorEnv(num_envs=2)
>>> observations, infos = envs.reset(seed=42)
>>> observations
array([[-0.14995256, 0.9886932 , -0.12224312],
6 changes: 4 additions & 2 deletions gymnasium/vector/sync_vector_env.py
Original file line number Diff line number Diff line change
@@ -20,12 +20,15 @@ class SyncVectorEnv(VectorEnv):

Example:
>>> import gymnasium as gym
>>> envs = gym.make_vec("Pendulum-v1", num_envs=2, vectorization_mode="sync")
>>> envs
SyncVectorEnv(Pendulum-v1, num_envs=2)
>>> envs = gym.vector.SyncVectorEnv([
... lambda: gym.make("Pendulum-v1", g=9.81),
... lambda: gym.make("Pendulum-v1", g=1.62)
... ])
>>> envs
SyncVectorEnv(Pendulum-v1, num_envs=2)
SyncVectorEnv(num_envs=2)
>>> obs, infos = envs.reset(seed=42)
>>> obs
array([[-0.14995256, 0.9886932 , -0.12224312],
@@ -73,7 +76,6 @@ def __init__(
# Define core attributes using the sub-environments
self.num_envs = len(self.envs)
self.metadata = self.envs[0].metadata
self.spec = self.envs[0].spec

# Initialises the single spaces from the sub-environments
self.single_observation_space = self.envs[0].observation_space
41 changes: 41 additions & 0 deletions tests/envs/registration/test_make_vec.py
Original file line number Diff line number Diff line change
@@ -3,6 +3,7 @@
import pytest

import gymnasium as gym
from gymnasium.envs.classic_control import CartPoleEnv
from gymnasium.vector import AsyncVectorEnv, SyncVectorEnv
from gymnasium.wrappers import TimeLimit, TransformObservation
from tests.wrappers.utils import has_wrapper
@@ -67,3 +68,43 @@ def test_make_vec_wrappers():
assert all(has_wrapper(sub_env, TransformObservation) for sub_env in env.envs)

env.close()


@pytest.mark.parametrize(
"env_id, kwargs",
(
("CartPole-v1", {}),
("CartPole-v1", {"num_envs": 3}),
("CartPole-v1", {"vectorization_mode": "sync"}),
("CartPole-v1", {"vectorization_mode": "custom"}),
("CartPole-v1", {"vector_kwargs": {"copy": False}}),
("CartPole-v1", {"wrappers": (gym.wrappers.TimeAwareObservation,)}),
("CartPole-v1", {"render_mode": "rgb_array"}),
),
)
def test_make_vec_with_spec(env_id: str, kwargs: dict):
envs = gym.make_vec(env_id, **kwargs)
assert envs.spec is not None
recreated_envs = gym.make_vec(envs.spec)

# Assert equivalence
assert envs.spec == recreated_envs.spec
assert envs.num_envs == recreated_envs.num_envs

assert envs.observation_space == recreated_envs.observation_space
assert envs.single_observation_space == recreated_envs.single_observation_space
assert envs.action_space == recreated_envs.action_space
assert envs.single_action_space == recreated_envs.single_action_space

assert type(envs) == type(recreated_envs)

envs.close()
recreated_envs.close()


def test_async_with_dynamically_registered_env():
gym.register("TestEnv-v0", CartPoleEnv)

gym.make_vec("TestEnv-v0", vectorization_mode="async")

del gym.registry["TestEnv-v0"]