You are seeing poliastro blog. If you want to see documentation, the latest version can be found in

To Infinity and Beyond!

By Meuge

Hey folks! It's been a while, but here I am to keep you posted about what we've been up to these last days.


What have we been up to?

We began the coding period with a video call with the mentors, as you might already know, JuanLu and Jorge. We got to know each other a little better, and we started to design what was ahead of our path.


But, before dropping any line of code, we first had to think about what would be the best way to integrate the new features to Poliastro community in order to capture the desired requirements from an end-user perspective. After some deliberation, we came up with the idea of adding two new objects.


By now, I hope to have your attention as well as Spock's. So we created EarthSatellite and Spacecraft. Both of them would be vital to develop what's coming next for Poliastro. Did someone say TLE?.


Still, you might want to check out EarthSatellite propagation considering J2's perturbation and the atmospheric drag. Sounds superb, right? In order to use it you might want to try:

from import COESA76
from poliastro.bodies import Earth
from import EarthSatellite
from astropy import units as u
from poliastro.twobody.orbit import Orbit
from import EarthGravity
from poliastro.spacecraft import Spacecraft

tof = 1.0 * u.min 
ss0 = Orbit.from_classical( Earth, 1000 *, 0.75 *,  63.4 * u.deg, 0 *u.deg, 270 * u.deg, 80 * u.deg)
C_D = 2.2 *  # dimentionless drag coefficient
A = ((np.pi / 4.0) * (u.m ** 2)).to( ** 2)
m = 100 * 
spacecraft = Spacecraft(A, C_D, m) #we create the spacecraft
earth_satellite = EarthSatellite(ss0, spacecraft)
orbit_with_atmosphere_and_J2 = earth_satellite.propagate(tof=tof, gravity=EarthGravity.J2, atmosphere=COESA76())

Nevertheless, this API is subject to changes, so before diving in, verify the documentation :)

See you in the next post, and stay safe :)