test_wfc_adjacency.py 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. """Convert input data to adjacency information"""
  2. from __future__ import annotations
  3. import numpy as np
  4. from minigrid.envs.wfc.wfclogic import adjacency as wfc_adjacency
  5. from minigrid.envs.wfc.wfclogic import patterns as wfc_patterns
  6. from minigrid.envs.wfc.wfclogic import tiles as wfc_tiles
  7. def test_adjacency_extraction(img_redmaze: np.ndarray) -> None:
  8. # TODO: generalize this to more than the four cardinal directions
  9. direction_offsets = list(enumerate([(0, -1), (1, 0), (0, 1), (-1, 0)]))
  10. img = img_redmaze
  11. tile_size = 1
  12. pattern_width = 2
  13. periodic = False
  14. _tile_catalog, tile_grid, _code_list, _unique_tiles = wfc_tiles.make_tile_catalog(
  15. img, tile_size
  16. )
  17. (
  18. pattern_catalog,
  19. _pattern_weights,
  20. _pattern_list,
  21. pattern_grid,
  22. ) = wfc_patterns.make_pattern_catalog(tile_grid, pattern_width, periodic)
  23. adjacency_relations = wfc_adjacency.adjacency_extraction(
  24. pattern_grid, pattern_catalog, direction_offsets
  25. )
  26. assert ((0, -1), -6150964001204120324, -4042134092912931260) in adjacency_relations
  27. assert ((-1, 0), -4042134092912931260, 3069048847358774683) in adjacency_relations
  28. assert ((1, 0), -3950451988873469076, -3950451988873469076) in adjacency_relations
  29. assert ((-1, 0), -3950451988873469076, -3950451988873469076) in adjacency_relations
  30. assert ((0, 1), -3950451988873469076, 3336256675067683735) in adjacency_relations
  31. assert (
  32. not ((0, -1), -3950451988873469076, -3950451988873469076) in adjacency_relations
  33. )
  34. assert (
  35. not ((0, 1), -3950451988873469076, -3950451988873469076) in adjacency_relations
  36. )