from IPython.html.widgets import interact, interactive, fixed from IPython.display import display, HTML import requests from mpl_toolkits.mplot3d import Axes3D import datetime import numpy as np planets = ['mars','earth','venus','mercury','sun'] planets = ','.join(planets) now = datetime.datetime.now() year,month,day = now.year, now.month, now.day def get_eph(year,month,day): url = "http://www.astro-phys.com/api/de406/states?date=%s-%s-%s&bodies=%s" % (year,month,day, planets) data = requests.get(url).json() data = data['results'] return data def distances(data): dists = {} for planet in data: dists[planet] = int(np.linalg.norm(np.array(data["earth"]) - np.array(data[planet]), 2)) return dists def system(year, month, day): fig = plt.figure() ax = fig.add_subplot(111, projection='3d') thisdate = str(datetime.date(year, month, day)) ax.set_title(thisdate) data = get_eph(year, month, day) table = '
{0} | {1} km |