예제 #1
0
def test_failures():
    with pytest.raises(rtd.RTDInputError):
        rtd.Convection(tau=-1, dt=DT, time_end=TIME_END)
    with pytest.raises(rtd.RTDInputError):
        rtd.Convection(tau=1, dt=-1, time_end=TIME_END)
    with pytest.raises(rtd.RTDInputError):
        rtd.Convection(tau=1, dt=DT, time_end=-1)
예제 #2
0
def test_convection(tau):
    """
    Test integral and MRT.

    Convection model requires a lot of precision for integral to converge.
    Convection model also requires a long time for mean to converge.
    """
    dt = tau/2000
    time_end = tau * 500
    a = rtd.Convection(tau=tau, dt=dt, time_end=time_end)
    assert(np.isclose(a.integral(), 1, rtol=rtol, atol=atol))
    assert(np.isclose(a.mrt(), analytical_mrt(tau), rtol=rtol, atol=atol))
예제 #3
0
def test_convection_points():
    """Manually test specific points for E, E*, and E**."""
    a = rtd.Convection(tau=1, dt=DT, time_end=TIME_END)

    times    =      [ 1/4,  1/2,    1,    2,     4]
    e_values =      [   0,    4,  1/2, 1/16, 1/128]     
    estar_values =  [   0,    2,  1/2,  1/8,  1/32]
    estar2_values = [   0,    1,  1/2,  1/4,   1/8]

    for t, e, estar, estar2 in zip(
            times, e_values, estar_values, estar2_values):
        assert np.isclose(np.interp(t, a.time, a.exitage), e)
        assert np.isclose(np.interp(t, a.time, a.exitage_star), estar)
        assert np.isclose(np.interp(t, a.time, a.exitage_star2), estar2)
예제 #4
0
import matplotlib.pyplot as plt
import rtdpy
a = rtdpy.Convection(tau=1, dt=.01, time_end=2)
plt.plot(a.time, a.exitage, label='E')
plt.plot(a.time, a.exitage_star, label='E*')
plt.plot(a.time, a.exitage_star2, label='E**')
plt.xlabel('Time')
plt.ylabel('Exit Age Function')
plt.legend()
plt.show()
예제 #5
0
def test_repr():
    a = rtd.Convection(tau=1, dt=DT, time_end=TIME_END)
    b = eval("rtd."+repr(a))
    assert np.isclose(a.integral(), b.integral(), rtol=rtol, atol=atol)
    assert np.isclose(a.mrt(), b.mrt(), rtol=rtol, atol=atol)
    assert np.isclose(a.sigma(), b.sigma(), rtol=rtol, atol=atol)
예제 #6
0
def test_negative_tau_error(tau):
    with pytest.raises(rtd.RTDInputError):
        rtd.Convection(tau=tau, dt=1, time_end=1)
예제 #7
0
def test_negative_dt_error(dt):
    with pytest.raises(rtd.RTDInputError):
        rtd.Convection(tau=1, dt=dt, time_end=1)