Vibe Coding Home

3D Gas Simulator

This software was largely created by AI Vibe Coding
Created by YouMinds
The 3D gas simulation shows particles in a 3-dimensional space that meet and repel each other depending on the temperature. The energy distribution is shown as a diagram.
0
0
  Speedcolor Mode: 
Use the mouse to drag and turn the cube. Use the scroll wheel to zoom in and out.
How was it built
This software was created using Vibe Coding by a Large Language Model LLM / chatbot and reworked in look & feel.
Some features had to be implemented manually and corrections and improvements had to be made.
The following Vibe Coding prompts were used on Copilot:
"Create a Simulation of a 3D gas relaxing towards a Maxwell–Boltzmann speed distribution with 300 ball like particles and 3d look. using a single html page with embedded javascript that uses webgl with three.js. Use an import map for the three.js libraries. Use an orbit control. Use chart.js but do not put it into the import map."
"draw the 12 edges of the ball cube in white. center the cube in the lower page and fit the chart and 3d scene into the page. initially let the balls have the same speed. update the chart on each frame and show the distribution of the actual ball speeds. disable the fly in animation of the chart"
"place the chart in the left side of the page and the 3d scene on the right side of the page. React to window resize and keep the cube centered. Make shure the balls do not leave the cube by checking the position upon wall collision because the balls might already have left the wall due to hight speed. Introduce lighting for 3d look of the balls."
"make shure the bars are updated on each frame by recomputing the ball speeds. slow down the initial speed of the balls by a factor of 6"
"let the balls bounce off at each other. Make shure to compute real physics and mind impulse."
"add a slide to change the ball radius from 0.1 to 0.5. Add a slider to change the temperature e.g. the speed of all balls. Also let the barchart always show 10 bars and compute the speed ranges on each frame due to the available speeds."
"change the layout. Put the 3d scene on the right side the chart on the left side and the sliders below the chart."
"below the sliders add a field that counts the number of ball collisions"
"let the speed slider start at a zero speed. add a field below the sliders that shows the number of collisions per second."
"the speed slider does not appy the speed it is always a stand still"
"let the speed start at 0.01"
"also let the speed slider hava a minimum of 0.01"
"add a slider that allows to resize the cube from its current size up to 3 times bigger. Adjust the physics computation of the balls accordingly."