After learning about the BSicons that Wikipedia uses to build route maps for transport systems, I wanted to see if I could use BSicons in randomly generated maps.
data:image/s3,"s3://crabby-images/6868d/6868d83d9d7e0e8d1bdb2dbbdf6935afa61d80d0" alt="A diagram of the circular line 4 that shows the route of the metro alongside station names and connecting rail services"
Automatic matching
I wanted to include as many different BSicons as possible in my generated maps. I made a copy of all the BSicons from Wikipedia and created a script to analyse them. By examining the pixels in the icon the script would categorize each edge. I used this later to decide if two icons could ‘fit’ together. The strategy for map generation was to:
- Place a random icon in the centre of the grid
- For each empty tile in a spiral from the centre, find a tile where the edges of the tile matched with the edges of all adjacent placed tiles
This was a good start and made some interesting maps. However, the way I was determining if icons could fit together wasn’t very reliable. It meant that many icons were never be placed because they had no matches. While icons with curves wouldn’t visually match to the icons they were placed next to.
data:image/s3,"s3://crabby-images/dd0cf/dd0cfe01b005d596f74bcfc80947a408965b0e65" alt="A partially filled grid of icons showing a road and some rail lines"
data:image/s3,"s3://crabby-images/fb772/fb772922a748b645b02f47b0dd61a08824671dbd" alt="A filled grid of icons showing train lines going under and over each other in a diagonal lattice."
10 PRINT
.Less is more
By reducing the number of BSicons I was working with, it became feasible for me to manually categorise what tiles could fit together. I changed to using the wavefunction collapse algorithm to place the tiles. The wavefunction collapse algorithm prioritizes placing tiles in the spaces with the greatest restriction on them. This reduces situations where the algorithm can’t place anything and gets stuck.
data:image/s3,"s3://crabby-images/13d72/13d7245723c1aeee6b4c00690321b102b4fb0da2" alt="Icons placed in a grid showing two overlapping train lines"
data:image/s3,"s3://crabby-images/c0ddd/c0ddd4e52a17d3bfd5d415b7fc217f6359a39984" alt="Icons placed in a grid showing two overlapping train lines with tunnels and roads."
data:image/s3,"s3://crabby-images/fc7f5/fc7f5855f7ce0e360668d3911e2e8037c11ab38a" alt="Icons placed in a grid showing rail lines and roads that go past the edge of the image"
I really like the interconnected and overlapping routes the generator can make. You can use it to generate your own maps.