fancy_gym/alr_envs/utils/mps/alr_env.py

40 lines
1.1 KiB
Python
Raw Normal View History

from abc import abstractmethod, ABC
2021-05-12 09:52:25 +02:00
from typing import Union
import gym
import numpy as np
class AlrEnv(gym.Env, ABC):
2021-05-12 09:52:25 +02:00
@property
def active_obs(self):
2021-05-18 10:39:30 +02:00
"""Returns boolean mask for each observation entry
whether the observation is returned for the contextual case or not.
2021-05-12 09:52:25 +02:00
This effectively allows to filter unwanted or unnecessary observations from the full step-based case.
"""
2021-05-18 10:39:30 +02:00
return np.ones(self.observation_space.shape, dtype=bool)
2021-05-12 09:52:25 +02:00
@property
@abstractmethod
def start_pos(self) -> Union[float, int, np.ndarray]:
"""
2021-05-18 10:39:30 +02:00
Returns the starting position of the joints
2021-05-12 09:52:25 +02:00
"""
raise NotImplementedError()
@property
def goal_pos(self) -> Union[float, int, np.ndarray]:
"""
Returns the current final position of the joints for the MP.
By default this returns the starting position.
"""
return self.start_pos
@property
@abstractmethod
def dt(self) -> Union[float, int]:
"""
Returns the time between two simulated steps of the environment
"""
raise NotImplementedError()