Module moog.game_rules.re_center
Rules that re-center a sprite periodically.
Typically used in first-person games to keep the agent in the middle of the screen and move all non-agent sprites when the agent moves to preserve their position relative to the agent.
Classes
class KeepNearCenter (agent_layer, layers_to_center, grid_x, grid_y=None)
-
Expand source code
class KeepNearCenter(abstract_rule.AbstractRule): """Translates many sprites at once to re-center an agent. This is used in first-person games, where there is a background grid that does not extend to infinity so all the other sprites must periodically be snapped back near the center once the agent reaches the grid size away. """ def __init__(self, agent_layer, layers_to_center, grid_x, grid_y=None): """Constructor. Args: agent_layer: String. Must be a key in the environment state. The first sprite in state[agent_layer] will be kept near [0.5, 0.5]. layers_to_center: Iterable of strings. Elements must be keys in environment state. All sprites in these layers will be centered along with the agent. grid_x: Maximum x-distance from 0.5 allowed by the agent before centering. Recentering adjusts x-positions by exactly this amount. grid_x: Maximum y-distance from 0.5 allowed by the agent before centering. Recentering adjusts y-positions by exactly this amount. """ self._agent_layer = agent_layer if agent_layer not in set(layers_to_center): layers_to_center = list(layers_to_center) + [agent_layer] self._layers_to_center = layers_to_center if grid_y is None: grid_y = grid_x self._grid_cell = np.array([grid_x, grid_y]) def _move_sprites(self, state, delta_pos): for layer in self._layers_to_center: for sprite in state[layer]: sprite.position = sprite.position + delta_pos def step(self, state, meta_state): """Run the rule, centering layers if necessary.""" del meta_state agent = state[self._agent_layer][0] agent_pos = agent.position - np.array([0.5, 0.5]) delta_pos = ( -1. * self._grid_cell * (agent_pos > self._grid_cell) + self._grid_cell * (agent_pos < -1. * self._grid_cell) ) if any(delta_pos): self._move_sprites(state, delta_pos)
Translates many sprites at once to re-center an agent.
This is used in first-person games, where there is a background grid that does not extend to infinity so all the other sprites must periodically be snapped back near the center once the agent reaches the grid size away.
Constructor.
Args
agent_layer
- String. Must be a key in the environment state. The
- first sprite in state[agent_layer] will be kept near [0.5, 0.5].
layers_to_center
- Iterable of strings. Elements must be keys in environment state. All sprites in these layers will be centered along with the agent.
grid_x
- Maximum x-distance from 0.5 allowed by the agent before centering. Recentering adjusts x-positions by exactly this amount.
grid_x
- Maximum y-distance from 0.5 allowed by the agent before centering. Recentering adjusts y-positions by exactly this amount.
Ancestors
- AbstractRule
- abc.ABC
Methods
def step(self, state, meta_state)
-
Expand source code
def step(self, state, meta_state): """Run the rule, centering layers if necessary.""" del meta_state agent = state[self._agent_layer][0] agent_pos = agent.position - np.array([0.5, 0.5]) delta_pos = ( -1. * self._grid_cell * (agent_pos > self._grid_cell) + self._grid_cell * (agent_pos < -1. * self._grid_cell) ) if any(delta_pos): self._move_sprites(state, delta_pos)
Run the rule, centering layers if necessary.
Inherited members