Пример #1
0
def test_saturn_perihelion_aphelion():
    """Tests the perihelion_aphelion() method of Saturn class"""

    epoch = Epoch(2030, 1, 1.0)
    e = Saturn.perihelion_aphelion(epoch)
    y, m, d, h, mi, s = e.get_full_date()

    assert abs(y - 2032) < TOL, \
        "ERROR: 1st perihelion_aphelion() test doesn't match"

    assert abs(m - 11) < TOL, \
        "ERROR: 2nd perihelion_aphelion() test doesn't match"

    assert abs(d - 28) < TOL, \
        "ERROR: 3rd perihelion_aphelion() test doesn't match"

    epoch = Epoch(1925, 1, 1.0)
    e = Saturn.perihelion_aphelion(epoch, perihelion=False)
    y, m, d, h, mi, s = e.get_full_date()

    assert abs(y - 1929) < TOL, \
        "ERROR: 4th perihelion_aphelion() test doesn't match"

    assert abs(m - 11) < TOL, \
        "ERROR: 5th perihelion_aphelion() test doesn't match"

    assert abs(d - 11) < TOL, \
        "ERROR: 6th perihelion_aphelion() test doesn't match"
Пример #2
0
def test_ring_parameters():
    """Test the ring_parameters() method of Saturn class"""

    epoch = Epoch(1992, 12, 16.00068)
    B, Bprime, P, delta_U, a, b = Saturn.ring_parameters(epoch)
    B = round(B, 3)
    Bprime = round(Bprime, 3)
    P = round(P, 3)
    delta_U = round(delta_U, 3)
    a = round(a, 2)
    b = round(b, 2)

    assert abs(B - 16.442) < TOL, \
        "ERROR: 1st ring_parameters() test doesn't match"

    assert abs(Bprime - 14.679) < TOL, \
        "ERROR: 2nd ring_parameters() test doesn't match"

    assert abs(P - 6.741) < TOL, \
        "ERROR: 3rd ring_parameters() test doesn't match"

    assert abs(delta_U - 4.198) < TOL, \
        "ERROR: 4th ring_parameters() test doesn't match"

    assert abs(a - 35.87) < TOL, \
        "ERROR: 5th ring_parameters() test doesn't match"

    assert abs(b - 10.15) < TOL, \
        "ERROR: 6th ring_parameters() test doesn't match"
Пример #3
0
def test_ring_longitude_ascending_node():
    """Tests the ring_logitude_ascending_node() method of Saturn class"""

    epoch = Epoch(1992, 12, 16.00068)
    omega = Saturn.ring_logitude_ascending_node(epoch)
    omega = round(omega, 6)

    assert abs(omega - 169.410243) < TOL, \
        "ERROR: 1st ring_logitude_ascending_node() test doesn't match"
Пример #4
0
def test_ring_inclination():
    """Tests the ring_inclination() method of Saturn class"""

    epoch = Epoch(1992, 12, 16.00068)
    i = Saturn.ring_inclination(epoch)
    i = round(i, 6)

    assert abs(i - 28.076131) < TOL, \
        "ERROR: 1st ring_inclination() test doesn't match"
Пример #5
0
def test_magnitude():
    """Tests the magnitude() method of Saturn class"""

    sun_dist = 9.867882
    earth_dist = 10.464606
    delta_u = Angle(16.442)
    b = Angle(4.198)
    m = Saturn.magnitude(sun_dist, earth_dist, delta_u, b)

    assert abs(m - 1.9) < TOL, \
        "ERROR: 1st magnitude() test doesn't match"
Пример #6
0
def test_saturn_geocentric_position():
    """Tests the geocentric_position() method of Saturn class"""

    epoch = Epoch(1992, 12, 20.0)
    ra, dec, elon = Saturn.geocentric_position(epoch)

    assert ra.ra_str(n_dec=1) == "21h 11' 41.8''", \
        "ERROR: 1st geocentric_position() test doesn't match"

    assert dec.dms_str(n_dec=1) == "-17d 15' 40.8''", \
        "ERROR: 2nd geocentric_position() test doesn't match"

    assert elon.dms_str(n_dec=1) == "46d 51' 47.7''", \
        "ERROR: 3rd geocentric_position() test doesn't match"
Пример #7
0
def test_saturn_geometric_heliocentric_position():
    """Tests the geometric_heliocentric_position() method of Saturn class"""

    epoch = Epoch(2018, 10, 27.0)
    lon, lat, r = Saturn.geometric_heliocentric_position(epoch)

    assert abs(round(lon.to_positive(), 4) - 279.5108) < TOL, \
        "ERROR: 1st geometric_heliocentric_position() test doesn't match"

    assert abs(round(lat, 4) - 0.6141) < TOL, \
        "ERROR: 2nd geometric_heliocentric_position() test doesn't match"

    assert abs(round(r, 5) - 10.06266) < TOL, \
        "ERROR: 3rd geometric_heliocentric_position() test doesn't match"
Пример #8
0
def test_saturn_station_longitude_2():
    """Tests the station_longitude_2() method of Saturn class"""

    epoch = Epoch(2018, 11, 1.0)
    sta2 = Saturn.station_longitude_2(epoch)
    y, m, d = sta2.get_date()

    assert abs(round(y, 0) - 2018) < TOL, \
        "ERROR: 1st station_longitude_2() test doesn't match"

    assert abs(round(m, 0) - 9) < TOL, \
        "ERROR: 2nd station_longitude_2() test doesn't match"

    assert abs(round(d, 4) - 6.4175) < TOL, \
        "ERROR: 3rd station_longitude_2() test doesn't match"
Пример #9
0
def test_saturn_opposition():
    """Tests the opposition() method of Saturn class"""

    epoch = Epoch(-6, 9, 1.0)
    oppo = Saturn.opposition(epoch)
    y, m, d = oppo.get_date()

    assert abs(round(y, 0) - (-6)) < TOL, \
        "ERROR: 1st opposition() test doesn't match"

    assert abs(round(m, 0) - 9) < TOL, \
        "ERROR: 2nd opposition() test doesn't match"

    assert abs(round(d, 4) - 14.3709) < TOL, \
        "ERROR: 3rd opposition() test doesn't match"
Пример #10
0
def test_saturn_conjunction():
    """Tests the conjunction() method of Saturn class"""

    epoch = Epoch(2125, 6, 1.0)
    conjunction = Saturn.conjunction(epoch)
    y, m, d = conjunction.get_date()

    assert abs(round(y, 0) - 2125) < TOL, \
        "ERROR: 1st conjunction() test doesn't match"

    assert abs(round(m, 0) - 8) < TOL, \
        "ERROR: 2nd conjunction() test doesn't match"

    assert abs(round(d, 4) - 26.4035) < TOL, \
        "ERROR: 3rd conjunction() test doesn't match"
Пример #11
0
def test_saturn_passage_nodes():
    """Tests the passage_nodes() method of Saturn class"""

    epoch = Epoch(2019, 1, 1)
    time, r = Saturn.passage_nodes(epoch)
    y, m, d = time.get_date()
    d = round(d, 1)
    r = round(r, 4)

    assert abs(y - 2034) < TOL, \
        "ERROR: 1st passage_nodes() test doesn't match"

    assert abs(m - 5) < TOL, \
        "ERROR: 2nd passage_nodes() test doesn't match"

    assert abs(d - 30.2) < TOL, \
        "ERROR: 3rd passage_nodes() test doesn't match"

    assert abs(r - 9.0546) < TOL, \
        "ERROR: 4th passage_nodes() test doesn't match"
Пример #12
0
def test_saturn_orbital_elements_j2000():
    """Tests the orbital_elements_j2000() method of Saturn class"""

    epoch = Epoch(2065, 6, 24.0)
    l, a, e, i, ome, arg = Saturn.orbital_elements_j2000(epoch)

    assert abs(round(l, 6) - 130.28188) < TOL, \
        "ERROR: 1st orbital_elements_j2000() test doesn't match"

    assert abs(round(a, 8) - 9.55490779) < TOL, \
        "ERROR: 2nd orbital_elements_j2000() test doesn't match"

    assert abs(round(e, 7) - 0.0553209) < TOL, \
        "ERROR: 3rd orbital_elements_j2000() test doesn't match"

    assert abs(round(i, 6) - 2.490529) < TOL, \
        "ERROR: 4th orbital_elements_j2000() test doesn't match"

    assert abs(round(ome, 5) - 113.49736) < TOL, \
        "ERROR: 5th orbital_elements_j2000() test doesn't match"

    assert abs(round(arg, 6) - (-20.068943)) < TOL, \
        "ERROR: 6th orbital_elements_j2000() test doesn't match"
Пример #13
0
def test_saturn_orbital_elements_mean_equinox():
    """Tests the orbital_elements_mean_equinox() method of Saturn class"""

    epoch = Epoch(2065, 6, 24.0)
    l, a, e, i, ome, arg = Saturn.orbital_elements_mean_equinox(epoch)

    assert abs(round(l, 6) - 131.196871) < TOL, \
        "ERROR: 1st orbital_elements_mean_equinox() test doesn't match"

    assert abs(round(a, 8) - 9.55490779) < TOL, \
        "ERROR: 2nd orbital_elements_mean_equinox() test doesn't match"

    assert abs(round(e, 7) - 0.0553209) < TOL, \
        "ERROR: 3rd orbital_elements_mean_equinox() test doesn't match"

    assert abs(round(i, 6) - 2.486426) < TOL, \
        "ERROR: 4th orbital_elements_mean_equinox() test doesn't match"

    assert abs(round(ome, 5) - 114.23974) < TOL, \
        "ERROR: 5th orbital_elements_mean_equinox() test doesn't match"

    assert abs(round(arg, 6) - (-19.896331)) < TOL, \
        "ERROR: 6th orbital_elements_mean_equinox() test doesn't match"