This is a simple 2d wave equation simulator. When the user clicks on the window, energy will be introduced to the system which will bounce off the walls that were loaded in via a texture.
Since this program was created using WebGPU (which is still unstable), it is experimental and only works on the Chrome Canary browser with WebGPU enabled.
As stated above, this is a 2d wave equation simulator that allows for
- Arbitrary walls by importing textures
- Arbitrary energies in the form of user-submitted clicks
While there are still many limitations in the application, it can create various simulations for arbitrary background walls and clicks. To do this, it uses the WebGPU library to send relevant data to the GPU where the actual calculations are being performed. From here, a finite difference approximation of the wave equation is used to compute the next value for each point on a grid of finite differences (currently represented by pixels).
For boundary conditions, any point that is clicked has the energy increased, and any point that is a wall always has zero energy. And this repeats each cycle.
If you'd like to see a more visual explanation of the above, here is a presentation I gave toward the end of my batch at the Recurse Center! If you want an uncompressed version, you can also download that version here!
WavePresentation-compressed.mp4
(note: about 8:50 in, I erroneously say "j times the height." I should have just said "j" as the equation on the screen does)
If you would like more information about how I created this presentation, the code I used to create the interactive slides can be found here!
Using pnpm run dev, you can serve this simulation in your webbrowser at http://localhost:8080. That being said, there are a few other important details to keep in mind:
- Due to WebGPU still being unstable, this can currently only run in Chrome Canary with the WebGPU flags enabled
- Background images need to be added to /dist/img/ (these are not currently included in the repository)
- If you wish to change the image in use, you currently need to change the hard-coded file name in /src/renderer.ts
- If you wish to increase or decrease the amount of energy introduced by a click, you can do so in /src/energies.ts
The basic functionality of the app is there, but there are a lot of improvements that could be made:
- A vertex-based grid instead of a pixel-based one
- More configurations options
- The ability to upload a wall texture from the page
- Click and Hold for bigger wave
- Click and drag for moving source
- Configurable options such as canvas size and wave speed
- Different boundary conditions at edges