Skip to content

Latest commit

 

History

History
82 lines (50 loc) · 3.61 KB

README.md

File metadata and controls

82 lines (50 loc) · 3.61 KB

Orbit Visualizer

Original idea by elplanetaerrante.

Original

Implementation

Prototype 1

First prototype

Prototype 2

Seccond prototype

Prototype 3

Current version

Prototype here

Details to add

  • Change the color of the barycenter to better differentiate it from the stars.
  • Add mention to elplanetaerrante
  • Add tool tips with explanation on what is each variable.
  • Add a bit of space on top.
  • Make sliders bigger for mobile.
  • Change github link to repo link.
  • Fix orbital period

Simulation

The process of simulating the two-body problem in real time with the mass ratio, eccentricity, and semi-major axis as parameters was not an easy task. Fortunately, I was able to come up with a solution that works well enough to give an accurate representation of the orbits in real time.

The orbit of the first planet is created based on it’s eccentricity and semi-major axis. It’s right focus is centered in the canvas. This focus will become the barycenter later.

While the orbit itself is easy to create, ensuring that the planet moves at the correct speed at each point in time is not. For this, we need the function $r(t)$ (position based on time). The Law of Areas becomes important now.

A line that connects a planet to the sun sweeps out equal areas in equal times.

Adapting it to a two-body problem where the center is not the sun but the barycenter. With this, we know that $t(A)$ is linear (time based on area swept) so it’s enough to get an $r(A)$ (position based on the area) to get a proper scale of time for our position.

Since we know the position based on an angle:

$$ r(\theta) = \frac{a\cdot(1-e^2)}{1 + e \cdot \cos(\theta)} $$

❓ this is the position in polar coordinates centered in the focus with $e$ the eccentricity and $a$ the semi-major axis

If we can get the angle based on an area ($\theta(A)$) then we’ll have $r(A)$

To calculate this we first can get $A(\theta)$ by integrating the radious over $\Delta\theta$

$$ A(\theta) = \int \frac{r(\theta)^2}{2}d\theta $$

$$ A(\theta) = \frac{a^2(e^3 - e) \sin(\theta)}{2e\cos(\theta) + 2} + a^2\sqrt{1 - e}\sqrt{e + 1} \cdot\arctan((\frac{\sqrt{1-e}}{\sqrt{e + 1}} \tan(\theta/2)) $$

Since getting the inverse of $A(\theta)$ is really complicated, I decided to use an empirical approach. In this approach we subdivide the orbit in $n$ segments of equal angle, then calculate the area of each angle with $A(\theta)$, and then use that to interpolate the angle for a given area. Let’s call this aproximation: $\theta_{A(\theta)}(A)$.

With $\theta_{A(\theta)}(A)$ we can have an $r_{A(\theta)}(A)$ using $r(\theta_{A(\theta)}(A))$.

With this we can calculate the position of the first planet for any given area swept. Now we just animate the area going from 0% of the ellipse to 100% in a linear manner, and we get the corresponding movement of the planet.

With the position of the first planet, we can get the position of the second planet by simply using the fact that the center of mass of both will stay at the barycenter.

$$ pos_{second} = barycenter - r_{A(\theta)}(A)\frac{m_{first}}{m_{second}} $$

Thanks to this, we can know the position of the two planets at any time based on the semi-major axis and the eccentricity. The mass ratio between the planets comes into play because it dictates the semi-major axis of the orbit used to calculate the orbital period.