data:image/s3,"s3://crabby-images/b4329/b4329f363670983c6a4f75da906bd1447fe71a13" alt=""
The algorithm consists of 3 parts, a function and 2 scripts and was split for convenience in writing and troubleshooting. The generator works by creating a matrix of 0's, picking a location at random and turning the 0 into a 1, then creating branches of 1's outwards in random directions until no further branches can be made.
data:image/s3,"s3://crabby-images/ef1cc/ef1cc06d888c95e8b54a4f6bb08f3fe69ba1e8d6" alt=""
This script is the first one called in the function and is simply used to move the active coordinate 2 units in a random direction. By moving 2 units, a grid of coordinates is rendered incapable of turning into 1's. These coordinates become the maze walls.
data:image/s3,"s3://crabby-images/87941/87941124a0a6b3d0d4a9b8853a087fb341ec33bc" alt=""
This is the second script called in the function. It detects if the new active coordinate has already been activated (if it is a 1), and if so moves back along the path the active coordinate followed until an unactivated coordinate is available. When this condition is met, it activates the coordinate (changes a 0 to a 1) as well as the coordinate in between both the current and the last active coordinates.
data:image/s3,"s3://crabby-images/13e46/13e460d99f7a428b0151b1c27a425c9dd6afbf2c" alt=""
The is the command window of MATLAB. From here, the function is called using an x and y dimension for the maze. This dimension is the size of the maze without walls. The matrix it generates is (2x-1) in size. The 10x10 maze generated here uses a 19x19 matrix.
data:image/s3,"s3://crabby-images/d9045/d90450e3f19055b5c4ce9a0cd153added2d7966f" alt=""
When the maze can grow no farther, the generator stops. The matrix can then be copy pasted into excel.
data:image/s3,"s3://crabby-images/045a3/045a3869a27291a90b370f39e1678478ec935476" alt=""
Using an Excel macro I wrote, each cell is filled with either black for 0 or white for 1.
data:image/s3,"s3://crabby-images/4cb12/4cb1231ab73171b27c684232d8614a57792323fb" alt=""
This is the matrix after being filled. The matrix is then given a border, the text removed, and the maze printed.
data:image/s3,"s3://crabby-images/0bb03/0bb03fc52cff37cffc8da1f955f8acfbd88ecf53" alt=""
The maze at the time of printing. (Note the maze has been rotated 90deg clockwise)
data:image/s3,"s3://crabby-images/c83f3/c83f33902693c01824a1301397267c238095d45b" alt=""
A second finished maze.
data:image/s3,"s3://crabby-images/a32ef/a32ef626ba9a5d155cdf563ffd5028c24423e9b9" alt=""
A third finished maze.
gLike