data:image/s3,"s3://crabby-images/906b1/906b10c8e8460bee6a4b1ab113859a1ee6c00a58" alt="" |
data:image/s3,"s3://crabby-images/b3256/b325620d1202b3d2463a5e78b42420710e055145" alt=""
Submitted by , posted on 22 March 2005
|
data:image/s3,"s3://crabby-images/d1451/d14515f195ef99c05308ad64ac4cdc0ad29bb195" alt="" |
Image Description, by
data:image/s3,"s3://crabby-images/69965/69965670d518d2aa7fd31d9ef6b86f987323433f" 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.
|
|