Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://toji.github.io/webgpu-clustered-shading/
Personal experimental project to implement clustered shading with WebGPU.
https://toji.github.io/webgpu-clustered-shading/
Last synced: 2 months ago
JSON representation
Personal experimental project to implement clustered shading with WebGPU.
- Host: GitHub
- URL: https://toji.github.io/webgpu-clustered-shading/
- Owner: toji
- Created: 2020-12-19T04:48:18.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2023-01-27T19:32:37.000Z (almost 2 years ago)
- Last Synced: 2024-10-31T19:05:17.864Z (2 months ago)
- Language: JavaScript
- Homepage: https://toji.github.io/webgpu-clustered-shading/
- Size: 148 MB
- Stars: 182
- Watchers: 7
- Forks: 18
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-webgpu - WebGPU Clustered Shading - By Brandon Jones - [Repository](https://github.com/toji/webgpu-clustered-shading) (Demos / Safari)
README
# WebGPU Clustered Forward Shading
Live page at [https://toji.github.io/webgpu-clustered-shading/](https://toji.github.io/webgpu-clustered-shading/).
This project implements a simple clustered forward shading renderer with WebGPU. My primary goals in developing it were to learn more about the technique and some of the related tech (like compute shaders), to implement something non-trivial with WebGPU/WGSL in order to identify bugs, and to demonstrate a interesting use case for WebGPU that wasn't practical with WebGL.
While the technique IS aimed at increasing performance, optimization was not my primary concern and thus this code could probably quite easily be improved on for real-world use cases. That said, it does rather nicely demonstrate the considerable performance benefits of clustered shading vs. a more naive lighting approach.
To test the WebGPU renderer use Chrome Canary on Windows or MacOS, navigate to about:flags, and turn on the "Unsafe WebGPU" flag.
A WebGL 2.0 renderer is included for comparison/debugging but it only implements the naive path.
## Known Issues
- Only the "naive" path works for WebGL 2.0. This is intentional, and I don't think I'm going to try fixing it any time soon.