Simulation of collision between moving particles with different masses inside a container, using the d3-force physics engine.
Uses two elastic collision forces, d3.forceBounce to handle elastic collisions between nodes, and d3.forceSurface for collisions with the container walls.
You can reduce the elasticity (coefficient of restitution) of the particles using the slider on the upper-left, causing kinetic energy to be lost at every collision. Elasticity of 1 indicates a pure elastic collision, while a value of 0 will cause particles to stick to each other along the collision axis.
xxxxxxxxxx
<head>
<script src="//cdnjs.cloudflare.com/ajax/libs/d3/4.8.0/d3.min.js"></script>
<script src="//unpkg.com/d3-force-bounce"></script>
<script src="//unpkg.com/d3-force-surface"></script>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div id="controls">
Particles:
<input id="density-control" class="slider-control" type="range" min="0" max="0.002" step="0.00001" oninput="onDensityChange(this.value)">
<span id="numparticles-val"></span>
<br>
Elasticity:
<input id="elasticity-control" class="slider-control" type="range" min="0" max="1" step="0.1" value="1" oninput="onElasticityChange(this.value)">
<span id="elasticity-val">1</span>
</div>
<svg id="canvas"></svg>
<script src="index.js"></script>
</body>
https://cdnjs.cloudflare.com/ajax/libs/d3/4.8.0/d3.min.js
https://unpkg.com/d3-force-bounce
https://unpkg.com/d3-force-surface