Skip to main content

Net Radiation and Daily Upscaling Remote Sensing in Python

Project description

Net Radiation and Daily Upscaling Remote Sensing in Python

This Python package implements the net radiation and daily upscaling methods described in Verma et al 2016.

Gregory H. Halverson (they/them)
gregory.h.halverson@jpl.nasa.gov
Lead developer
NASA Jet Propulsion Laboratory 329G

Installation

This package is distributed using the pip package manager as verma-net-radiation with dashes.

pip install verma-net-radiation

Usage

Import this package as verma_net_radiation with underscores.

This module provides functions to calculate instantaneous net radiation and its components, integrate daily net radiation, and process radiation data from a DataFrame. Below is a detailed explanation of each function and how to use them.

verma_net_radiation

Description:
Calculates instantaneous net radiation and its components based on input parameters.

Parameters:

  • ST_C (Union[Raster, np.ndarray, float]): Surface temperature in Celsius.
  • emissivity (Union[Raster, np.ndarray, float]): Surface emissivity (unitless, constrained between 0 and 1).
  • albedo (Union[Raster, np.ndarray, float]): Surface albedo (unitless, constrained between 0 and 1).
  • SWin_Wm2 (Union[Raster, np.ndarray, float], optional): Incoming shortwave radiation (W/m²). If not provided, will be retrieved from GEOS-5 FP if geometry and time_UTC are given.
  • Ta_C (Union[Raster, np.ndarray, float], optional): Air temperature in Celsius. If not provided, will be retrieved from GEOS-5 FP if geometry and time_UTC are given.
  • RH (Union[Raster, np.ndarray, float], optional): Relative humidity (fractional, e.g., 0.5 for 50%). If not provided, will be retrieved from GEOS-5 FP if geometry and time_UTC are given.
  • geometry (RasterGeometry, optional): Spatial geometry for GEOS-5 FP retrievals.
  • time_UTC (datetime, optional): UTC time for GEOS-5 FP retrievals.
  • GEOS5FP_connection (GEOS5FP, optional): Existing GEOS5FP connection to use for data retrievals.
  • resampling (str, optional): Resampling method for GEOS-5 FP data retrievals.
  • cloud_mask (Union[Raster, np.ndarray, float], optional): Boolean mask indicating cloudy areas (True for cloudy).

Returns: A dictionary containing:

  • "SWout": Outgoing shortwave radiation (W/m²).
  • "LWin": Incoming longwave radiation (W/m²).
  • "LWout": Outgoing longwave radiation (W/m²).
  • "Rn": Instantaneous net radiation (W/m²).

Example:

results = verma_net_radiation(
  ST_C=surface_temp_array,
  emissivity=emissivity_array,
  albedo=albedo_array,
  SWin_Wm2=SWin_array,
  Ta_C=air_temp_array,
  RH=relative_humidity_array,
  cloud_mask=cloud_mask_array
)

daily_Rn_integration_verma

Description:
Integrates instantaneous net radiation (Rn) to daily average values using solar geometry parameters. Supports Raster, numpy array, or float inputs. If sunrise time or daylight hours are not provided, they are calculated from day of year and latitude.

Parameters:

  • Rn_Wm2 (Union[Raster, np.ndarray, float]): Instantaneous net radiation (W/m²).
  • hour_of_day (Union[Raster, np.ndarray, float]): Hour of the day (0-24) when Rn is measured.
  • day_of_year (Union[Raster, np.ndarray, float], optional): Day of the year (1-365).
  • lat (Union[Raster, np.ndarray, float], optional): Latitude in degrees.
  • sunrise_hour (Union[Raster, np.ndarray, float], optional): Hour of sunrise (local time).
  • daylight_hours (Union[Raster, np.ndarray, float], optional): Total daylight hours.

Returns:

  • Union[Raster, np.ndarray, float]: Daily average net radiation (W/m²).

Notes:

  • To obtain total daily energy (J/m²), multiply the result by (daylight_hours * 3600).
  • If sunrise_hour or daylight_hours are not provided, they are computed from day_of_year and lat using solar geometry.

Example:

daily_Rn = daily_Rn_integration_verma(
  Rn_Wm2=Rn_array,
  hour_of_day=hour_of_day_array,
  day_of_year=day_of_year_array,
  lat=latitude_array,
  sunrise_hour=sunrise_hour_array,
  daylight_hours=daylight_hours_array
)

verma_net_radiation_table

Description:
Processes a DataFrame containing inputs for Verma net radiation calculations and appends the results as new columns.

Parameters:

  • verma_net_radiation_inputs_df (DataFrame): A DataFrame containing the following columns:
    • Rg: Incoming shortwave radiation (W/m²).
    • albedo: Surface albedo (unitless, constrained between 0 and 1).
    • ST_C: Surface temperature in Celsius.
    • EmisWB or emissivity: Surface emissivity (unitless, constrained between 0 and 1).
    • Ta_C: Air temperature in Celsius.
    • RH: Relative humidity (fractional, e.g., 0.5 for 50%).

Returns:

  • DataFrame: A copy of the input DataFrame with additional columns for the calculated radiation components:
    • SWout: Outgoing shortwave radiation (W/m²).
    • LWin: Incoming longwave radiation (W/m²).
    • LWout: Outgoing longwave radiation (W/m²).
    • Rn: Instantaneous net radiation (W/m²).

Example:

output_df = verma_net_radiation_table(input_df)

References

Brutsaert, W. (1975). On a Derivable Formula for Long‐Wave Radiation from Clear Skies. Water Resources Research, 11(5), 742–744. https://doi.org/10.1029/WR011i005p00742
Empirical model for clear-sky atmospheric emissivity, used in the calculation of incoming longwave radiation.

Liou, K. N. (2002). An Introduction to Atmospheric Radiation (2nd ed.). Academic Press. (See Eq. 2.3.1)
Textbook reference for the Stefan-Boltzmann Law and radiative transfer theory, used for outgoing longwave radiation calculations.

Stefan, J. (1879). Über die Beziehung zwischen der Wärmestrahlung und der Temperatur. Sitzungsberichte der mathematisch-naturwissenschaftlichen Classe der kaiserlichen Akademie der Wissenschaften, 79, 391–428.
Original publication of the Stefan-Boltzmann Law, fundamental to blackbody radiation calculations.

Verma, M., Fisher, J. B., Mallick, K., Ryu, Y., Kobayashi, H., Guillaume, A., Moore, G., Ramakrishnan, L., Hendrix, V. C., Wolf, S., Sikka, M., Kiely, G., Wohlfahrt, G., Gielen, B., Roupsard, O., Toscano, P., Arain, A., & Cescatti, A. (2016). Global surface net-radiation at 5 km from MODIS Terra. Remote Sensing, 8, 739. Link
Primary methodology for net radiation and daily upscaling as implemented in this package.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

verma_net_radiation-1.6.0.tar.gz (792.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

verma_net_radiation-1.6.0-py3-none-any.whl (797.5 kB view details)

Uploaded Python 3

File details

Details for the file verma_net_radiation-1.6.0.tar.gz.

File metadata

  • Download URL: verma_net_radiation-1.6.0.tar.gz
  • Upload date:
  • Size: 792.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for verma_net_radiation-1.6.0.tar.gz
Algorithm Hash digest
SHA256 e8e3185f0ccd95be7a3334ae01ff50e1115cf3181a6ae08ab1e4dd8cc97653de
MD5 0032b340621892656bf64ee239a1afb5
BLAKE2b-256 f82d457ef2fca588b9b6c12f748f655d6c95bf6b7337f4f27dd36a493fba4bb3

See more details on using hashes here.

File details

Details for the file verma_net_radiation-1.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for verma_net_radiation-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 71dd6e6a5543f11995616d2deda059d3e1b8f1c5cb67f21a029dc138409c1ded
MD5 e260b3826aaef3d0510d907c2b82a9d9
BLAKE2b-256 2ee8780e97bea0cad3cfdb2b393567d8ddef736dc2b83cb9f095729777bdfcfd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page