data:image/s3,"s3://crabby-images/6d578/6d578509b0531bc2c2def449feda31bfcf19000a" alt="" |
data:image/s3,"s3://crabby-images/7374f/7374fab35b339464a0b677e213c0ad3aee711b05" alt=""
Submitted by , posted on 22 March 2005
|
data:image/s3,"s3://crabby-images/11398/113985dec29b62c0186ef005faa92224c1014187" alt="" |
Image Description, by
data:image/s3,"s3://crabby-images/9cb2a/9cb2a1de1588cd30ad52466911d1d92dcb58c44d" alt=""
Following a post on the comp.lang.functional newsgroup asking for a 2D maze
generator written in a functional style, I wrote this little 131-line OCaml
program to generate and render simple 2D mazes using OpenGL and also export
the result as PostScript.
The program stores the set of visited grid cells as a mapping from (x, y)
coordinates (of type "int * int") to booleans, implemented as a balanced
binary tree by the OCaml library. The grid is then traversed recursively from
the bottom left-hand cell (0, 0) by moving randomly to unvisited, on-board
neighbours left, right, up or down.
The maze is rendered while it is generated, as OpenGL points and lines. The
result is memoized in a display list for fast redisplay.
The complete source code, along with the compilation command, is available
on-line here:
http://www.ffconsultancy.com/free/maze/
Cheers,
Jon.
|
|