Home

Awesome

Maze TUI

demo

For a complete breakdown of all maze generation algorithms, pseudocode, and many other important details please read the wiki This is just the quick start guide to refer to for usage instructions.

Requirements

Quick Start Guide

This project is a terminal user interface application powered by crossterm, ratatui.rs, and tui-textarea that can be run with various combinations of commands. The goal of the program is to explore various maze building, solving, and measurement algorithms while visualizing them in interesting ways. The basic principle behind the program is that you can ask for any combination of settings, include any settings, exclude any settings, and the program will just work. There are sensible defaults for every flag so experiment with different combinations and tweaks until you get what you are looking for. In addition, you can learn about each maze algorithm you observe with informational popups (they are a work in progress right now!).

If you just want to get started follow these steps.

$ git clone https://github.com/agl-alexglopez/maze-tui.git
$ cd maze-tui/maze_tui
$ cargo run --release --bin run_tui

You will be greeted by the home page. Read the directions or if you just want to see some cool maze animations right away press [ENTER]. Check out the pausing, arrow commands, and stepping capabilities for how to control the animation you are watching. See the introduction below.

Run TUI Program

Here are the instructions that greet you upon running the application.

███╗   ███╗ █████╗ ███████╗███████╗    ████████╗██╗   ██╗██╗
████╗ ████║██╔══██╗╚══███╔╝██╔════╝    ╚══██╔══╝██║   ██║██║
██╔████╔██║███████║  ███╔╝ █████╗         ██║   ██║   ██║██║
██║╚██╔╝██║██╔══██║ ███╔╝  ██╔══╝         ██║   ██║   ██║██║
██║ ╚═╝ ██║██║  ██║███████╗███████╗       ██║   ╚██████╔╝██║
╚═╝     ╚═╝╚═╝  ╚═╝╚══════╝╚══════╝       ╚═╝    ╚═════╝ ╚═╝

Use flags, followed by arguments, in any order.
Press [ENTER] to confirm your flag choices.

(scroll with [↓/↑], exit with [ESCAPE])

BUILDER FLAG[-b] Set maze building algorithm.
    [rdfs] - Randomized depth first search.
    [hunt-kill] - Randomized walks and scans.
    [kruskal] - Randomized Kruskal's algorithm.
    [prim] - Randomized Prim's algorithm.
    [eller] - Randomized Eller's algorithm.
    [wilson] - Loop-erased random path carver.
    [wilson-walls] - Loop-erased random wall adder.
    [fractal] - Randomized recursive subdivision.
    [grid] - A random grid pattern.
    [arena] - Open floor with no walls.

MODIFICATION FLAG[-m] Add shortcuts to the maze.
    [cross]- Add crossroads through the center.
    [x]- Add an x of crossing paths through center.

SOLVER FLAG[-s] Set maze solving algorithm.
    [dfs-hunt] - Depth First Search
    [dfs-gather] - Depth First Search
    [dfs-corner] - Depth First Search
    [floodfs-hunt] - Depth First Search
    [floodfs-gather] - Depth First Search
    [floodfs-corner] - Depth First Search
    [rdfs-hunt] - Randomized Depth First Search
    [rdfs-gather] - Randomized Depth First Search
    [rdfs-corner] - Randomized Depth First Search
    [bfs-hunt] - Breadth First Search
    [bfs-gather] - Breadth First Search
    [bfs-corner] - Breadth First Search
    [distance] - Path Distances from Center
    [runs] - Path Run Lengths

WALL FLAG[-w] Set the wall style for the maze.
    [mini] - Half size walls and paths.
    [sharp] - The default straight lines.
    [round] - Rounded corners.
    [doubles] - Sharp double lines.
    [bold] - Thicker straight lines.
    [contrast] - Full block width and height walls.
    [half] - Half wall height and full size paths.
    [spikes] - Connected lines with spikes.

Animations can play forward or reversed.
Cancel any animation by pressing [ESCAPE].
Pause/Play an animation with [SPACE]
Slower or faster [</>]. Try it and watch the background!
Step next/previous or change the play direction with [←/→]
Zoom out/in with [CTRL-[-]]/[CTRL-[+]]
If any flags are omitted, defaults are used.
An empty command line will create a random maze.

EXAMPLES:

-b rdfs -s bfs-hunt
-s bfs-gather -b prim
-s bfs-corner -w mini -b fractal

ASCII lettering for this title and algorithm
descriptions are templates I used from
patorjk.com and modified to use box-drawing
characters.

Enjoy!

Details

The underlying principles for this program are as follows.

  1. Build a maze by representing paths and walls in a u32 integer.
  2. Use logical and visually pleasing unicode characters to represent the walls and features of the maze.
  3. Solve the maze with various algorithms, both single and multi-threaded, so that we can observe important features of the mazes.

I included as many interesting maze building algorithms as I could. The solving algorithms are multi-threaded in many cases. This is not particularly practical or special on its own. However, multithreading allows for more fun and interesting visualizations and can speed up what can sometimes be a slow solving process to watch for a single thread.

While I have not yet put together a testing suite for performance testing of building and solving the mazes, I will be interested to see the performance implications of the solvers. The wiki is likely where you will find documentation of new features or other testing.

Wiki

Please read the wiki for more detailed explanation of settings, write-ups for each maze generation algorithm, and much more. Thank you!

Tips