This project implements Verlet integration to simulate particle physics in C, using GLFW for real-time visualization. You can directly run the verlet_simulator
or other scripts (e.g., simulate_impulse
, simulate_potential
) inside /bin
. The goal is to provide simple and visual simulations of particle physics. Currently implemented examples include gravity simulation, collision response, impulse dynamics, gas in a box, and particles in a potential field. Work on 3D simulations is in progress! 😄
Verlet integration is a numerical method used to simulate the motion of particles with great stability and minimal computational cost, even when forces become complex. This project leverages the Verlet algorithm to simulate realistic particle physics, including collision detection and response, in a 2D space. GLFW provides real-time rendering, enabling visual feedback and parameter adjustments like gravity, particle interaction, and potential fields.
- Stable Verlet Integration: Accurately simulates particle movement with position-based integration.
- GLFW Visualization: Real-time rendering of particles in a 2D environment.
- Collision Handling: Particle-to-particle and boundary collision detection with response.
- Interactive Simulations: Modify parameters or spawn particles dynamically using keyboard inputs.
- Potential Field Dynamics: Visualize and simulate particles in attractive or repulsive fields.
- Performance Efficient: Handles a large number of particles smoothly.
To build and run the project, ensure the following are installed:
- C compiler (e.g., GCC or Clang)
- GLFW library for OpenGL rendering
- GLAD for OpenGL function loading (included with GLFW)
- Make for building the project
sudo apt-get update
sudo apt-get install libglfw3-dev libglfw3 xorg-dev build-essential make
Install MSYS2 and use its package manager:
pacman -S mingw-w64-x86_64-glfw mingw-w64-x86_64-gcc
Verlet-Particles/
├── bin/ # Compiled binaries
├── include/ # Header files
├── build/ # Build files
├── libs/ # Dependencies (e.g. GLFW, GLUT, Unity)
├── scripts/ # Example scripts (e.g., simulate_impulse.c, simulate_potential.c)
├── src/ # Core simulation logic
├── tests/ # Unit tests
├── assets/ # Assets for visualization (e.g., GIFs, images)
├── Makefile # Build rules
└── README.md # Documentation
- Clone this repository:
git clone https://github.com/davidomanovic/particle-simulator.git
cd particle-simulator
- Clean the current build and build the project again:
make clean
make
- Run the binaries from /bin (executable files) after building, or use prebuilt project
./bin/simulate_impulse
./bin/gas_simulation
- Spacebar: Spawn particles dynamically
Contributions are welcome! Fork this repository, make your changes, and submit a pull request.
This project is licensed under the MIT License.