net.simplace.sim.components.util.helper.EquationsFAO56

Helper EquationsFAO56 for computing values due to equations from (FAO 56)

Equation numbers refers to the paper cited below.

References

(FAO 56): Allen, Crop evapotranspiration - Guidelines for computing crop water requirements - FAO Irrigation and drainage paper 56, 1998




public class EquationsFAO56 {
// Public Constructors
public EquationsFAO56();

// Constants
public static final double a_s_Default;
public static final double b_s_Default;
public static final double albedo;
public static final double lambda;

// Class Methods
public static double ReferenceEvapotranspiration(double T, double R_n,
double u_2, double e_s, double e_a, double z);

Calculates the daily crop evapotranspiration with the FAO-Penman-Montheith method Eq. (6) FAO Penman-Monteith equation determines the evapotranspiration from the hypothetical grass reference surface and provides a standard to which evapotranspiration in different periods of the year or in other regions can be compared and to which the evapotranspiration from other crops can be related. [FAO 56, p.65f]
returns crop reference evapotranspiration ET0 [mm day-1]
public static double AtmosphericPressure(double z);

Calculates the atmospheric Pressure P Eq. (7)
returns atmospheric pressure P [kPa]
public static double PsychrometricConstant(double P);

Calculates the psychrometric constant gamma as function of atmospheric pressure P Eq. (8) The factor is calculated from parameters for average atmospheric conditions and is rounded to 3 decimals to be consistent with the reference.
returns psychrometric constant gamma [kPa °C-1]
public static double SaturationVapourPressureAtTemperature(double T);

Saturation vapour pressure at air temperature T Eq. (11)
returns vapour pressure e_0_T [kPa]
public static double MeanSaturatedVapourPressure(double T_max, double T_min);

Mean vapour pressure of a period Eq. (12)
returns mean vapour pressure e_s [kPa]
public static double SlopeOfSaturationVapPressureCurve(double T);

Calculates the slope of saturation vapour pressure curve Delta as function of temperature T Eq (13)
returns slope of saturation vapour pressure Delta [kPa °C-1]
public static double VapourPressureFromDewpoint(double T_dew);

Actual vapour pressure at dewpoint Eq. (14)
returns actual vapour pressure e_a [kPa]
public static double VapourPressureFromPsychrometricData(double T_dry,
double T_wet, double a_psy, double z);

Actual vapour pressure derived from psychrometric data Eq. (15)
returns actual vapour pressure e_a [kPa]
public static double VapourPressureFromRelHumidityMaxMin(double RH_max,
double RH_min, double T_max, double T_min);

Actual vapour pressure from maximum and minimum relative humidity Eq. (17)
returns actual vapour pressure e_a [kPa]
public static double VapourPressureFromRelHumidityMax(double RH_max, double
T_min);

Actual vapour pressure from maximum relative humidity Eq. (18)
returns actual vapour pressure e_a [kPa]
public static double VapourPressureFromRelHumidityMean(double RH_mean,
double T_max, double T_min);

Actual vapour pressure from mean relative humidity Eq. (19)
returns actual vapour pressure e_a [kPa]
public static double EvaporationEquivalentToRadiation(double Radiation);

Converts radiation [energy/surface] to equivalent evaporation [depth of water] Eq. (20)
returns equivalent evaporation [mm day-1]
public static double ExtraterrestrialRadiation(double d_r, double omega_s,
double phi, double delta);

Calculates extraterrestrial radiation Eq. (21)
returns extraterrestrial radiation per day [MJ m-2 day-1]
public static double DecimalDegreesToRadians(double degree);

Convert decimal degrees to radians Eq. (22)
returns radians [rad]
public static double InverseRelativeDistanceEarthSun(int J);

Inverse relative distance Earth-Sun Eq. (23)
returns inverse relative distance d_r []
public static double SolarDeclination(int J);

Solar declination Eq. (24)
returns solar declination delta [rad]
public static double SunsetHourAngle(double phi, double delta);

Sunset hour angle Eq. (25)
returns sunset hour angle omega_s [rad]
public static double ExtraterrestrialRadiationDiurnal(double d_r, double
delta, double phi, double omega_1, double omega_2);

Diurnal extraterrestrial radiation Eq. (29(
returns
public static double SolarTimeAngleBeginning(double t_l, double omega);

Solar time angle at beginning of period Eq. (29)
returns solar time angle at beginning omega_1 [rad]
public static double SolarTimeAngleEnd(double t_l, double omega);

Solar time angle at end of period Eq. (30)
returns solar time angle at end omega_2 [rad]
public static double SolarTimeAngleMidpoint(double t, double L_z, double L_m,
double S_c);

Solar time angel at midpoint of period Eq. (31)
returns
public static double SeasonalCorrectionSolarTime(int J);

Seasonal correction for solar time Eq. (32) and (33) *
returns seasonal correction S_c [hour]
public static double DaylightHours(double omega_s);

Dayligth hours Eq. (34)
returns daylight hours N
public static double SolarRadiation(double R_a, double n, double N, double
a_s, double b_s);

Calculates Solar Radiation from sunshine hours Eq. (35)
returns solar or shortwave radiation R_s [MJ m-2 day-1]
public static double ClearSkyRadiationWithAngstromVariables(double R_a,
double a_s, double b_s);

Calculates the clear-sky solar radiation when values for a_s and b_s are available Eq. (36)
returns Clear-sky solar radiation R_so when N=n [MJ m-2 day-1]
public static double ClearSkyRadiation(double R_a, double z);

Calculates the clear-sky solar radiation when values for a_s and b_s are not available Eq. (37)
returns Clear-sky solar radiation R_so when N=n [MJ m-2 day-1]
public static double NetShortwaveRadiation(double R_s, double alpha);

Net solar or net shortwave radiation Eq. (38) Calculates the amount of solar radiation that is not reflected.
returns net shortwave radiation R_ns [MJ m-2 day-1]
public static double NetSolarRadiation(double R_s);

Net shortvawe radiation resulting from balance of incoming and reflected solar radiation Eq. (38) Calculates the amount of solar radiation that is not reflected. Albedo coefficient alpha is 0.23 for the hypothetical grass reference crop.
returns net solar or net shortwave radiation R_ns [MJ m-2 day-1]
public static double NetLongwaveRadiation(double R_s, double R_so, double
e_a, double T_max, double T_min);

Net longwave radiation Eq. (39)
returns net longwave radiation R_nl [MJ m-2 day-1]
public static double NetLongwaveRadiationHourly(double R_s, double R_so,
double e_a, double T);

Net longwave radiation Eq. (39) hourly
returns net longwave radiation R_nl [MJ m-2 hour-1]
public static double NetRadiation(double R_ns, double R_nl);

Net radiation (difference between incoming shortwave and outgoing longwave radiation) Eq. (40) Remark: equation works also for hourly values. When R_ns and R_nl are in [MJ m-2 hour-1], the resulting net radiation R_n is also in [MJ m-2 hour-1]
returns net radiation R_n [MJ m-2 day-1]
public static double SoilHeatFluxHourlyDaylight(double R_n);

Soil heat flux for hourly periods during daylight periods Eq. (45)
returns hourly soil heat flux G_hr [MJ m-2 hour-1]
public static double SoilHeatFluxHourlyNighttime(double R_n);

Soil heat flux for hourly periods during nighttime periods Eq. (46)
returns hourly soil heat flux G_hr [MJ m-2 hour-1]
public static double SolarRadiationFromExtraterrestrialRadiationAndTemp(
double R_a, double T_max, double T_min, double k_Rs);

Estimates solar radiation by extraterrestrial radiation and temperature Eq. (50)
returns solar radiation R_s [MJ m-2 day-1]
public static double ReferenceEvapoTranspirationByExtraterrestrialRadiation(
double R_a, double T_max, double T_min);

Estimates the reference evapo transpiration by extraterrestrial radiation and temperature Eq. (52)
returns ET0 crop reference evapotranspiration ET0 [mm day-1]
public static double ReferenceEvapoTranspirationFromSolarRadiation(double
R_s, double T_max, double T_min);

Estimates the reference evapotranspiration by solar radiation and temperature Eq. (52) & Eq. (50) with k_Rs=0.17 see: Hargreaves, Allen, 2003, History and Evaluation of Hargreaves Evapotranspiration Equation: Eq. (3)
returns ET0 crop reference evapotranspiration ET0 [mm day-1]
public static double ReferenceEvapoTranspirationHourly(double R_n, double G,
double T_hr, double Delta, double gamma, double e_0, double e_a, double
u2);

Calculates hourly reference evapotranspiration Eq. (53)
returns reference evapotranspiration ET_0 [mm h-1]
public static double ActualVapourPressureFromRelativeHumidityHourly(double
e_0, double RH_hr);

Estimates hourly actual vapour pressure from hourly relative humidity Eq. (54)
returns
public static double AdjustedKCoefficientToWindAndHumidity(double K_c,
double u2, double RH_min, double h);

Adjustment of coefficient in climates where RH_min differs from 45% or where u2 is larger or smaller than 2 m/s Eq. (62) Same formula is used to adjust K_cmid [Eq. (62)], K_cend [Eq. (65)], K_cb [Eq. (70)], K_cmax [Eq. (72)], K_cbfull [Eq. (99)]
returns K_c adjusted coefficient
public static double UpperLimitKCoefficient(double K_cb, double u2, double
RH_min, double h);

Upper limit on the evaporation and transpiration from any cropped surface Eq. (72)
returns K_cmax upper limit
public static double ExposedAndWettedSoilFraction(double f_c, double f_w);

Exposed and wetted soil fraction Eq. (75)
returns f_ew exposed and wetted soil fraction
public static double VegetationCoveredSoilFraction(double K_cb, double
K_cmin, double K_cmax, double h);

Effective fraction of soil covered by vegetation Eq. (76)
returns f_c effective fraction of soil covered by vegetation
public static double KCoefficientByLAI(double K_cmin, double K_cbfull,
double LAI);

Estimated basal K_cb during the mid-season when plant density is lower than full cover Eq. (97)
returns Estimated basal K_cb during the mid-season when plant densitiy is lower than full cover
public static double p(double nominalDepletion, double ETC);

Calculates the ETC-adjusted depletion fraction/factor p. Table 22, Footnote 2, and last paragraph of p. 162. Limited to 0.1 <= p <= 0.8
returns Adjusted p [-]


}