1

我正在制作一个程序来模拟从地球上可见的火星的逆行运动。所以这是地球和火星绕太阳运行的平面图 还有一条从地球到火星的线。但是,我需要它与火星相交并继续前进,直到它与线 x = 15 相交

另一个用户向我发送了此代码

我之前的代码

import math
import matplotlib.pyplot as plt
import matplotlib.animation as animation
def _update_plot(i, fig, scat, l):
    scat.set_offsets(([math.cos(math.radians(i))*5, math.sin(math.radians(i))*5], [math.cos(math.radians(i/2))*10, math.sin(math.radians(i/2))*10], [0, 0]))
        l.set_data(([math.cos(math.radians(i))*5,math.cos(math.radians(i/2))*10],[math.sin(math.radians(i))*5,math.sin(math.radians(i/2))*10]))
    return [scat,l]

fig = plt.figure()

x = [0]
y = [0]

ax = fig.add_subplot(111)
ax.set_aspect('equal')
ax.grid(True, linestyle = '-', color = '0.10')
ax.set_xlim([-11, 11])
ax.set_ylim([-11, 11])

l, = plt.plot([],[], 'r--', zorder=1)
scat = plt.scatter(x, y, c = x, zorder=2)
scat.set_alpha(0.8)

anim = animation.FuncAnimation(fig, _update_plot, fargs = (fig, scat, l),
                           frames = 720, interval = 10)

plt.show()

另一个用户代码

def _update_plot(i, fig, scat, l):
    angle = math.radians(i)
    sun_pos = np.array([0., 0.])
    earth_pos = np.array([math.cos(angle)*5, math.sin(angle)*5])
    mars_pos = np.array([math.cos(angle / 2.) * 10, math.sin(angle / 2.) * 10])

    # compute the unit vector that points from Earth to Mars
    direction = mars_pos - earth_pos
    direction /= np.sqrt(np.dot(direction, direction))

    # find out where the line would intersect the x = 15 axis
    start_from = earth_pos
    alpha = (15 - start_from[0]) / direction[0]
    # if alpha comes out to be negative we picked the "wrong" planet
    if alpha < 0:
            start_from = mars_pos
            direction = -direction
            alpha = (15 - start_from[0]) / direction[0]
    y_line = start_from[1] + alpha * direction[1]

    # draw the planets
    scat.set_offsets((earth_pos, mars_pos, sun_pos))
    # draw the line
    l.set_data(([start_from[0], 15], [start_from[1], y_line]))
    return [scat,l]

所以目标是有一条线从“地球”(最里面的移动物体)到线 x=15 以及中间的另一个移动物体。

我还认为这条线应该只在这条线到达 x=15 时出现,所以只在轨道周期的第一个和最后一个季度

4

0 回答 0