Esempio n. 1
0
    def test_clear_sky_solar_radiation(self):
        day = Station(-22.90, 0).day(135)
        solar_radiation = day.solar_radiation(7.1)
        self.assertEqual(solar_radiation, 14.4)

        clear_sky_radiation = day.R_so()
        self.assertEqual(clear_sky_radiation, 18.8)
Esempio n. 2
0
    def test_eto_hargreaves(self):
        day = Station(41.42, 109).day(295)
        day.temp_min = 19.5
        day.temp_max = 26.5

        eto = day.eto_hargreaves()
        self.assertEqual(eto, 4.97)
Esempio n. 3
0
    def test_daylight_hours(self):
        station = Station(41.42, 109)
        day = station.day(135)
        day.temp_min = 19.5
        day.temp_max = 28

        self.assertEqual(day.daylight_hours(), 14.3, "daylighth_hours")
Esempio n. 4
0
    def test_actual_vapour_pressure_dew(self):
        station = Station(41.42, 1200)
        station.climate = Climate()
        day = station.day(130)

        self.assertEqual(day.temp_dew, None, "Dew temp is not known")
        day.temp_dew = 17.0
        self.assertEqual(day.temp_dew, 17.0, "Dew temp is set")
        self.assertEqual(day.actual_vapour_pressure(), 1.938,
                         "Actual vapour pressure with no psychrometric data")
Esempio n. 5
0
 def test_actual_vapour_pressure_psychrometric(self):
     station = Station(41.42, 1200)
     station.climate = Climate()
     day = station.day(130)
     day.temp_wet = 19.5
     day.temp_dry = 25.6
     self.assertEqual(day.atmospheric_pressure(), 87.9, 87.9)
     self.assertEqual(day.saturation_vapour_pressure(19.5), 2.267)
     self.assertEqual(day.temp_dew, None, "No dew point temperature known")
     self.assertEqual(day.actual_vapour_pressure(), 1.91,
                      "Actual vapour pressure from psychrometric data")
Esempio n. 6
0
    def test_actual_vapour_pressure_humidity_max_temp_min(self):
        station = Station(41.42, 1200)

        day = station.day(130)
        day.temp_min = 18
        day.humidity_max = 82

        actual_vp = day.actual_vapour_pressure()
        self.assertEqual(
            actual_vp, 1.692,
            "Actual vapour pressure with only humidity_max and temp_min")
Esempio n. 7
0
    def test_vapour_pressure_deficit(self):
        station = Station(41.42, 1200)

        day = station.day(130)
        day.temp_min = 18
        day.temp_max = 25
        day.humidity_max = 82
        day.humidity_min = 54

        vp_deficit = day.vapour_pressure_deficit()
        self.assertEqual(vp_deficit, 0.914,
                         "Dtermining vapour pressure deficit")
Esempio n. 8
0
    def test_actual_vapour_pressure_humidity_mean(self):
        station = Station(41.42, 1200)

        day = station.day(130)
        day.temp_min = 18
        day.temp_max = 25
        day.humidity_mean = 68

        actual_vp = day.actual_vapour_pressure()
        self.assertEqual(
            actual_vp, 1.779,
            "Actual vapour pressure with only humidity_mean, temp_min and temp_max"
        )
Esempio n. 9
0
    def test_with_no_assumptions(self):

        station = Station(41.42, 109)
        station.climate = None

        day = station.get_day(228)  # august 16
        day.temp_min = 19.8
        day.temp_max = 29.9
        day.radiation_s = 264 * 0.0864
        day.humidity_min = 37
        day.humidity_max = 88
        day.wind_speed = 2

        self.assertEqual(day.eto(), 5.3)
Esempio n. 10
0
    def test_solar_radiation_in_island(self):
        day = Station(41.42, 10).day(105)
        day.station.climate.island()

        rs = day.solar_radiation()
        self.assertEqual(rs, 20.0)

        day.station.climate.coastal()

        rs = day.solar_radiation()
        self.assertEqual(rs, 25.7)

        day.station.climate.interior()

        rs = day.solar_radiation()
        self.assertEqual(rs, 25.7)
Esempio n. 11
0
    def test_actual_vapour_pressure_humidity(self):

        station = Station(41.42, 1200)
        station.climate = Climate()

        day = station.day(130)
        day.temp_min = 18
        day.temp_max = 25
        day.humidity_max = 82
        day.humidity_min = 54

        sat_vap_pres_min = day.saturation_vapour_pressure(day.temp_min)
        self.assertEqual(sat_vap_pres_min, 2.064)

        sat_vap_pres_max = day.saturation_vapour_pressure(day.temp_max)
        self.assertEqual(sat_vap_pres_max, 3.168)

        actual_vp = day.actual_vapour_pressure()
        self.assertEqual(actual_vp, 1.702)
Esempio n. 12
0
    def test_et0(self):
        station = Station(41.42, 109)

        data = {
            228: [19.8, 29.9, 4.49],
            229: [15.1, 29.9, 5.13],
            230: [13.4, 29.6, 5.24],
            231: [12.7, 31.1, 5.62],
            232: [16.2, 32.8, 5.66],
            233: [16.9, 33.6, 5.72],
            234: [16.0, 35.5, 6.27]
        }

        for day_number, wdata in data.items():
            day = station.get_day(day_number)
            day.temp_min = wdata[0]
            day.temp_max = wdata[1]
            day.wind_speed = 2
            self.assertEqual(
                day.eto(), wdata[2],
                f"day {day_number}: Tmin={wdata[0]}, Tmax={wdata[1]}, ETo={wdata[2]}"
            )
Esempio n. 13
0
    def test_solar_radiation_from_temp(self):
        day = Station(45.72, 200).day(196)
        day.temp_max = 26.6
        day.temp_min = 14.8

        ra = day.R_a()
        self.assertEqual(ra, 40.6)

        solar_radiation = day.solar_radiation()
        self.assertEqual(solar_radiation, 22.3)
        self.assertEqual(day.solar_radiation_in_mm(), 9.1)
Esempio n. 14
0
    def test_net_radiation(self):
        day = Station(-22.90, 1200).day(135)
        day.temp_max = 25.1
        day.temp_min = 19.1
        day.vapour_pressure = 2.1

        net_radiation = day.net_radiation(7.1)
        self.assertEqual(net_radiation, 7.6)
Esempio n. 15
0
    def test_net_longwave_radiation(self):
        day = Station(-22.90, 1200).day(135)

        day.temp_max = 25.1
        day.temp_min = 19.1
        day.vapour_pressure = 2.1

        vp = day.actual_vapour_pressure()
        self.assertEqual(vp, 2.1)

        r_nl = day.R_nl(7.1)
        self.assertEqual(r_nl, 3.5)
Esempio n. 16
0
    def test_wind_speed2m(self):
        day = Station(-22.90, 1200).day(135)
        day.wind_speed = 5

        self.assertEqual(day.wind_speed_2m(), 5)

        day.station.anemometer_height = 10
        day.wind_speed = 3.2
        self.assertEqual(day.wind_speed_2m(), 2.4)
Esempio n. 17
0
    def test_net_radiation_without_radiation_data(self):
        day = Station(13.73, 2).day(105)

        climate = day.station.climate
        climate.coastal()

        day.temp_min = 25.6
        day.temp_max = 34.8

        self.assertEqual(Station(13.73, 2).latitude_rad, 0.24)

        ra = day.R_a()
        self.assertEqual(ra, 38.0)
        net_radiation = day.net_radiation()

        self.assertEqual(net_radiation, 14.0)
Esempio n. 18
0
    def test_latitude_rad(self):
        station_bangkok = Station(13.73, 1200)
        self.assertEqual(station_bangkok.latitude_rad, 0.240)

        station_rio = Station(22.90, 1200)
        self.assertEqual(station_rio.latitude_rad, 0.400)
Esempio n. 19
0
 def test_sunset_hour_angle(self):
     station = Station(-20.0, 1200)
     sunset_angle = station.day(246).sunset_hour_angle()
     self.assertEqual(sunset_angle, 1.527)
Esempio n. 20
0
class Test(unittest.TestCase):

    station = Station(41.42, 109)
    station.climate = Climate()
    day_130 = station.day(130)

    def test_station_class(self):
        """Testing Station instance attributes"""
        self.assertIsInstance(self.station, Station,
                              "station is instance of Station")
        self.assertEqual(self.station.latitude, 41.42, "station.latitude")
        self.assertEqual(self.station.altitude, 109, "station.altitude")
        self.assertEqual(self.station.anemometer_height, 2,
                         "station.anemometer_height")
        self.assertIsInstance(self.station.climate, Climate, "station.climate")

    def test_station_day(self):
        """Testing station's 'day()' method"""
        day = self.station.day(130)
        self.assertEqual(day.day_number, 130, "Station.day.day_number")
        self.assertIsInstance(day, StationDay,
                              "staion.day is instance of StationDay")

    def test_atmospheric_pressure(self):
        station = Station(41.42, 1800)
        station.climate = Climate()
        day = station.day(130)
        self.assertEqual(day.atmospheric_pressure(), 81.8,
                         "Atmosphertic pressure")

    def test_psychrometric_constant(self):
        station = Station(41.42, 1800)
        station.climate = Climate()
        day = station.day(130)
        self.assertEqual(day.psychrometric_constant(), 0.054397,
                         "psychrometric constant")

    def test_specific_heat(self):
        day = self.station.day(130)
        self.assertEqual(day.specific_heat(), 1.013 * 10**(-3))

    def test_latent_heat_of_vaporization(self):
        day = self.station.day(130)
        self.assertEqual(day.latent_heat_of_vaporization(), 2.45)

    def test_mean_saturation_vp(self):
        day_130 = self.day_130
        day_130.temp_max = 24.5
        day_130.temp_min = 15
        self.assertEqual(day_130.mean_saturation_vapour_pressure(), 2.39,
                         "mean_saturation_vapour_pressure()")

    def test_RH(self):
        day = self.station.day(130)
        day.temp_dew = 19.5
        self.assertEqual(
            day.RH(35), 40.32,
            "We can calculate relative humidity for a given T if dew point is known"
        )

    def test_mean_saturation_vp2(self):
        day = self.station.day(130)
        day.temp_mean = 19.75
        self.assertEqual(day.mean_saturation_vapour_pressure(), 2.302,
                         "mean_saturation_vapour_pressure using just Tmean")

    def test_slope_of_saturation_vp(self):
        day = self.station.day(130)
        slope = day.slope_of_saturation_vapour_pressure(24.5)
        self.assertEqual(slope, 0.183837, "slope of vapour pressure curve")

    def test_actual_vapour_pressure_psychrometric(self):
        station = Station(41.42, 1200)
        station.climate = Climate()
        day = station.day(130)
        day.temp_wet = 19.5
        day.temp_dry = 25.6
        self.assertEqual(day.atmospheric_pressure(), 87.9, 87.9)
        self.assertEqual(day.saturation_vapour_pressure(19.5), 2.267)
        self.assertEqual(day.temp_dew, None, "No dew point temperature known")
        self.assertEqual(day.actual_vapour_pressure(), 1.91,
                         "Actual vapour pressure from psychrometric data")

    def test_actual_vapour_pressure_dew(self):
        station = Station(41.42, 1200)
        station.climate = Climate()
        day = station.day(130)

        self.assertEqual(day.temp_dew, None, "Dew temp is not known")
        day.temp_dew = 17.0
        self.assertEqual(day.temp_dew, 17.0, "Dew temp is set")
        self.assertEqual(day.actual_vapour_pressure(), 1.938,
                         "Actual vapour pressure with no psychrometric data")

    def test_actual_vapour_pressure_humidity(self):

        station = Station(41.42, 1200)
        station.climate = Climate()

        day = station.day(130)
        day.temp_min = 18
        day.temp_max = 25
        day.humidity_max = 82
        day.humidity_min = 54

        sat_vap_pres_min = day.saturation_vapour_pressure(day.temp_min)
        self.assertEqual(sat_vap_pres_min, 2.064)

        sat_vap_pres_max = day.saturation_vapour_pressure(day.temp_max)
        self.assertEqual(sat_vap_pres_max, 3.168)

        actual_vp = day.actual_vapour_pressure()
        self.assertEqual(actual_vp, 1.702)

    def test_actual_vapour_pressure_humidity_max_temp_min(self):
        station = Station(41.42, 1200)

        day = station.day(130)
        day.temp_min = 18
        day.humidity_max = 82

        actual_vp = day.actual_vapour_pressure()
        self.assertEqual(
            actual_vp, 1.692,
            "Actual vapour pressure with only humidity_max and temp_min")

    def test_actual_vapour_pressure_humidity_mean(self):
        station = Station(41.42, 1200)

        day = station.day(130)
        day.temp_min = 18
        day.temp_max = 25
        day.humidity_mean = 68

        actual_vp = day.actual_vapour_pressure()
        self.assertEqual(
            actual_vp, 1.779,
            "Actual vapour pressure with only humidity_mean, temp_min and temp_max"
        )

    def test_vapour_pressure_deficit(self):
        station = Station(41.42, 1200)

        day = station.day(130)
        day.temp_min = 18
        day.temp_max = 25
        day.humidity_max = 82
        day.humidity_min = 54

        vp_deficit = day.vapour_pressure_deficit()
        self.assertEqual(vp_deficit, 0.914,
                         "Dtermining vapour pressure deficit")

    def test_latitude_rad(self):
        station_bangkok = Station(13.73, 1200)
        self.assertEqual(station_bangkok.latitude_rad, 0.240)

        station_rio = Station(22.90, 1200)
        self.assertEqual(station_rio.latitude_rad, 0.400)

    def test_relative_sun_distance(self):
        dr = self.station.day(246).relative_sun_distance()
        self.assertEqual(dr, 0.985)

    def test_solar_declination(self):
        declination = self.station.day(246).solar_declination()
        self.assertEqual(declination, 0.120)

    def test_sunset_hour_angle(self):
        station = Station(-20.0, 1200)
        sunset_angle = station.day(246).sunset_hour_angle()
        self.assertEqual(sunset_angle, 1.527)

    def test_r_a(self):
        r_a = Station(-20.0, 1200).day(246).R_a()
        self.assertEqual(r_a, 32.2)

    def test_r_a_in_mm(self):
        r_a = Station(-20.0, 1200).day(246).R_a_in_mm()
        self.assertEqual(r_a, 13.10)

    def test_daylight_hours(self):
        hours = Station(-20.0, 1200).day(246).daylight_hours()
        self.assertEqual(hours, 11.7)

    def test_solar_radiation(self):
        radiation = Station(-22.90, 1200).day(135).solar_radiation(7.10)
        self.assertEqual(radiation, 14.4)

    def test_clear_sky_solar_radiation(self):
        day = Station(-22.90, 0).day(135)
        solar_radiation = day.solar_radiation(7.1)
        self.assertEqual(solar_radiation, 14.4)

        clear_sky_radiation = day.R_so()
        self.assertEqual(clear_sky_radiation, 18.8)

    def test_net_shortwave_radiation(self):
        day = Station(-22.90, 1200).day(135)
        r_ns = day.R_ns(7.1)
        self.assertEqual(r_ns, 11.1)

    def test_net_longwave_radiation(self):
        day = Station(-22.90, 1200).day(135)

        day.temp_max = 25.1
        day.temp_min = 19.1
        day.vapour_pressure = 2.1

        vp = day.actual_vapour_pressure()
        self.assertEqual(vp, 2.1)

        r_nl = day.R_nl(7.1)
        self.assertEqual(r_nl, 3.5)

    def test_net_radiation(self):
        day = Station(-22.90, 1200).day(135)
        day.temp_max = 25.1
        day.temp_min = 19.1
        day.vapour_pressure = 2.1

        net_radiation = day.net_radiation(7.1)
        self.assertEqual(net_radiation, 7.6)

    def test_wind_speed2m(self):
        day = Station(-22.90, 1200).day(135)
        day.wind_speed = 5

        self.assertEqual(day.wind_speed_2m(), 5)

        day.station.anemometer_height = 10
        day.wind_speed = 3.2
        self.assertEqual(day.wind_speed_2m(), 2.4)

    def test_solar_radiation_from_temp(self):
        day = Station(45.72, 200).day(196)
        day.temp_max = 26.6
        day.temp_min = 14.8

        ra = day.R_a()
        self.assertEqual(ra, 40.6)

        solar_radiation = day.solar_radiation()
        self.assertEqual(solar_radiation, 22.3)
        self.assertEqual(day.solar_radiation_in_mm(), 9.1)

    def test_net_radiation_without_radiation_data(self):
        day = Station(13.73, 2).day(105)

        climate = day.station.climate
        climate.coastal()

        day.temp_min = 25.6
        day.temp_max = 34.8

        self.assertEqual(Station(13.73, 2).latitude_rad, 0.24)

        ra = day.R_a()
        self.assertEqual(ra, 38.0)
        net_radiation = day.net_radiation()

        self.assertEqual(net_radiation, 14.0)

    def test_solar_radiation_in_island(self):
        day = Station(41.42, 10).day(105)
        day.station.climate.island()

        rs = day.solar_radiation()
        self.assertEqual(rs, 20.0)

        day.station.climate.coastal()

        rs = day.solar_radiation()
        self.assertEqual(rs, 25.7)

        day.station.climate.interior()

        rs = day.solar_radiation()
        self.assertEqual(rs, 25.7)

    def test_eto_hargreaves(self):
        day = Station(41.42, 109).day(295)
        day.temp_min = 19.5
        day.temp_max = 26.5

        eto = day.eto_hargreaves()
        self.assertEqual(eto, 4.97)

    def test_eto(self):
        day = Station(41.42, 109).day(150)
        day.temp_min = 19.5
        day.temp_max = 36.5
        day.wind_speed = 2
        #day.humidity_mean = 60

        self.assertEqual(day.slope_of_saturation_vapour_pressure(23), 0.169921)
        self.assertEqual(day.net_radiation(), 16.1)
        self.assertEqual(day.soil_heat_flux(), 0)
        self.assertEqual(day.psychrometric_constant(), 0.0665)
        self.assertEqual(day.wind_speed_2m(), 2)
        self.assertEqual(day.vapour_pressure_deficit(), 2.186)

        eto = day.eto()

        self.assertEqual(eto, 6.98)
Esempio n. 21
0
 def test_r_a(self):
     r_a = Station(-20.0, 1200).day(246).R_a()
     self.assertEqual(r_a, 32.2)
Esempio n. 22
0
 def test_psychrometric_constant(self):
     station = Station(41.42, 1800)
     station.climate = Climate()
     day = station.day(130)
     self.assertEqual(day.psychrometric_constant(), 0.054397,
                      "psychrometric constant")
Esempio n. 23
0
 def test_atmospheric_pressure(self):
     station = Station(41.42, 1800)
     station.climate = Climate()
     day = station.day(130)
     self.assertEqual(day.atmospheric_pressure(), 81.8,
                      "Atmosphertic pressure")
Esempio n. 24
0
    def test_eto(self):
        day = Station(41.42, 109).day(150)
        day.temp_min = 19.5
        day.temp_max = 36.5
        day.wind_speed = 2
        #day.humidity_mean = 60

        self.assertEqual(day.slope_of_saturation_vapour_pressure(23), 0.169921)
        self.assertEqual(day.net_radiation(), 16.1)
        self.assertEqual(day.soil_heat_flux(), 0)
        self.assertEqual(day.psychrometric_constant(), 0.0665)
        self.assertEqual(day.wind_speed_2m(), 2)
        self.assertEqual(day.vapour_pressure_deficit(), 2.186)

        eto = day.eto()

        self.assertEqual(eto, 6.98)
Esempio n. 25
0
 def test_r_a_in_mm(self):
     r_a = Station(-20.0, 1200).day(246).R_a_in_mm()
     self.assertEqual(r_a, 13.10)
Esempio n. 26
0
 def test_daylight_hours(self):
     hours = Station(-20.0, 1200).day(246).daylight_hours()
     self.assertEqual(hours, 11.7)
Esempio n. 27
0
 def test_solar_radiation(self):
     radiation = Station(-22.90, 1200).day(135).solar_radiation(7.10)
     self.assertEqual(radiation, 14.4)
Esempio n. 28
0
 def test_net_shortwave_radiation(self):
     day = Station(-22.90, 1200).day(135)
     r_ns = day.R_ns(7.1)
     self.assertEqual(r_ns, 11.1)