JavaScript Star System simulator.
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
external
.gitignore
LICENSE
README.md
isaac_core.js
isaac_graphics.js
isaac_math.js
isaac_obj.js
isaac_queue.js
isaac_simulation.js
isaac_worker.js
orbitPhys.html
thingy.js

README.md

The stable (master) release of ISAAC can be found here. The latest functional development branch version can be found here.

What is ISAAC?

ISAAC is a star system simulator, with full n-body gravity calculations between orbital bodies. Star systems are defined through a set of specifications given as JSON.

Users can adjust values such as the Gravitational Constant and the masses of each individual body to see how their orbits are affected.

What exactly does ISAAC do?

ISAAC takes in a JSON object specifying the star system to simulate, creates the orbital bodies laid out in that specification, and simulates the way in which they interact with one another. ISAAC also creates a graphical representation of the star system (powered by Three.js), and provides a UI through which objects can be manipulated (using dat.GUI).

How are star systems specified?

Full details can be found in isaac_simulation.

What can I do with ISAAC?

In order of increasing difficulty (and coding required):

  1. Simulate a star system from a basic set of information, specified in JSON.
  2. Create a new sandbox tool powered by ISAAC's simulation and graphics, with minor changes to the UI.
  3. Completely rip out the graphical layer (replacing it with another solution), while keeping the same underlying simulation systems and UI.
  4. Create an entirely new application altogether, with a custom UI and new graphics, using the same underlying simulation systems.