mirror of
https://github.com/Farama-Foundation/Gymnasium.git
synced 2025-08-02 06:16:32 +00:00
* Ditch most of the seeding.py and replace np_random with the numpy default_rng. Let's see if tests pass * Updated a bunch of RNG calls from the RandomState API to Generator API * black; didn't expect that, did ya? * Undo a typo * blaaack * More typo fixes * Fixed setting/getting state in multidiscrete spaces * Fix typo, fix a test to work with the new sampling * Correctly (?) pass the randomly generated seed if np_random is called with None as seed * Convert the Discrete sample to a python int (as opposed to np.int64) * Remove some redundant imports * First version of the compatibility layer for old-style RNG. Mainly to trigger tests. * Removed redundant f-strings * Style fixes, removing unused imports * Try to make tests pass by removing atari from the dockerfile * Try to make tests pass by removing atari from the setup * Try to make tests pass by removing atari from the setup * Try to make tests pass by removing atari from the setup * First attempt at deprecating `env.seed` and supporting `env.reset(seed=seed)` instead. Tests should hopefully pass but throw up a million warnings. * black; didn't expect that, didya? * Rename the reset parameter in VecEnvs back to `seed` * Updated tests to use the new seeding method * Removed a bunch of old `seed` calls. Fixed a bug in AsyncVectorEnv * Stop Discrete envs from doing part of the setup (and using the randomness) in init (as opposed to reset) * Add explicit seed to wrappers reset * Remove an accidental return * Re-add some legacy functions with a warning. * Use deprecation instead of regular warnings for the newly deprecated methods/functions
58 lines
1.4 KiB
Python
58 lines
1.4 KiB
Python
import numpy as np
|
|
from .space import Space
|
|
|
|
|
|
class MultiBinary(Space):
|
|
"""
|
|
An n-shape binary space.
|
|
|
|
The argument to MultiBinary defines n, which could be a number or a `list` of numbers.
|
|
|
|
Example Usage:
|
|
|
|
>> self.observation_space = spaces.MultiBinary(5)
|
|
|
|
>> self.observation_space.sample()
|
|
|
|
array([0,1,0,1,0], dtype =int8)
|
|
|
|
>> self.observation_space = spaces.MultiBinary([3,2])
|
|
|
|
>> self.observation_space.sample()
|
|
|
|
array([[0, 0],
|
|
[0, 1],
|
|
[1, 1]], dtype=int8)
|
|
|
|
"""
|
|
|
|
def __init__(self, n, seed=None):
|
|
self.n = n
|
|
if type(n) in [tuple, list, np.ndarray]:
|
|
input_n = n
|
|
else:
|
|
input_n = (n,)
|
|
super().__init__(input_n, np.int8, seed)
|
|
|
|
def sample(self):
|
|
return self.np_random.integers(low=0, high=2, size=self.n, dtype=self.dtype)
|
|
|
|
def contains(self, x):
|
|
if isinstance(x, list) or isinstance(x, tuple):
|
|
x = np.array(x) # Promote list to array for contains check
|
|
if self.shape != x.shape:
|
|
return False
|
|
return ((x == 0) | (x == 1)).all()
|
|
|
|
def to_jsonable(self, sample_n):
|
|
return np.array(sample_n).tolist()
|
|
|
|
def from_jsonable(self, sample_n):
|
|
return [np.asarray(sample) for sample in sample_n]
|
|
|
|
def __repr__(self):
|
|
return f"MultiBinary({self.n})"
|
|
|
|
def __eq__(self, other):
|
|
return isinstance(other, MultiBinary) and self.n == other.n
|