Skip to content

batonius/ray-ten

Repository files navigation

ray ten

Run in browser

Read the blog post

ray-ten.mp4

Reimagining of a 1986 ZX Spectrum game room ten made with ray tracing. Completely ignoring GPUs when rendering 3D graphics is extremely inefficient, but ray-ten is quite efficient at being inefficient, thanks to portable-simd, rayon and cutting all the corners. I use macroquad for displaying the render and window controls because its WASM integration just works.

So what do I do?

Use the arrow keys to move the paddle trying not to miss the ball.

I'm on a phone and I have no physical keyboard.

You can also click/touch borders to move the paddle.

Why ray tracing tho?

Because modern graphics pipelines are boring and reflections are nice, even in low-res.

Couldn't you just use fragment shaders to the same effect? That would be infinitely more efficient.

That's true, I believe I could, maybe I'll try it next.

What's 'rps'?

That's rays-per-second, a handy way to gauge ray tracing throughput. Works like ersatz CPU benchmark unless fps are capped.

So what's the results then?

Platform Native single core Native multicore Firefox WASM Chrome WASM
Ryzen 7 3700X (8 cores) 39M 300M 7M 17M
MediaTek Dimensity 1200 - - 10M 12M

All browser versions are the most recent as of August 07, 2022. WASM modules are compiled with +simd128, optimized with wasm-opt -O4 and run in single core mode. Yes, mobile Firefox is faster than the desktop version.

That multicore difference is huge, can't you use rayon in WASM somehow?

I can, but that would require GitHub Pages to set COOP/COEP headers, and they aren't there yet, see community/community#13309.

About

First-person 3D pong ray-traced on CPU in real time.

Topics

Resources

License

Stars

Watchers

Forks