Skip to content
/ futracer Public

Race through breathtaking 3-D graphics with Futhark! 🐌

License

Notifications You must be signed in to change notification settings

nqpz/futracer

Repository files navigation

futracer

Race through breathtaking 3-D graphics with Futhark through OpenCL (not OpenGL)!

Run make to build the library, and then run ./futcubes.py, ./futfly.py, or ./futdoom.py to run the example programs. Use the --help argument to see which settings exist.

There are three rendering approaches: segmented (the default) chunked, and scatter_bbox. The segmented approach is a rasterizer, while chunked and scatter_bbox are raycasters.

Click on the image to see a 1-minute video of futcubes.py in action. Video of futcubes

Click on the image to see a 1-minute video of futfly.py in action. Video of futfly

Click on the image to see a 30-second video of futdoom.py in action. Video of futdoom

Dependencies

futracer depends on the programming language Futhark; see http://futhark-lang.org/ and https://github.com/HIPERFIT/futhark.

futracer also depends on PyGame, PyPNG (only futcubes.py and futdoom.py), and NumPy.

Keyboard controls

Use the arrow keys for now. Use Page Down and Page Up to decrease and increase the view distance for rendering (fun!). Use 1 and 2 to decrease and increase the draw distance.

Use R to switch rendering approaches.

For the chunked rendering approach, use A and D to decrease and increase the number of draw rectangles on the X axis, and W and S on the Y axis. Sometime in the future this should be chosen automatically. Warning: This might slow down the program to a crawl for some reason.

Scripts

futdoom.py supports custom maps. For an example of a (poorly) randomly generated map, run:

./futdoomlib/scripts/generate_random_map.py | ./futdoom.py --auto-fps --level -

About

Race through breathtaking 3-D graphics with Futhark! 🐌

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages