Skip to main content

GPU-accelerated SOLWEIG model for urban thermal comfort simulation

Project description

SOLWEIG-GPU: GPU-Accelerated Thermal Comfort Modeling Framework

SOLWEIG-GPU Logo

Project Status: Active PyPI version License: MIT PyPI Downloads

SOLWEIG-GPU is a Python package and command-line interface for running standalone SOLWEIG (Solar and LongWave Environmental Irradiance Geometry) model on CPU or GPU (if available). It enables high-resolution urban microclimate modeling by computing key variables such as Sky View Factor (SVF), Mean Radiant Temperature (Tmrt), and the Universal Thermal Climate Index (UTCI).

SOLWEIG was originally developed by Dr. Fredrik Lindberg's group. Journal reference: Lindberg, F., Holmer, B. & Thorsson, S. SOLWEIG 1.0 – Modelling spatial variations of 3D radiant fluxes and mean radiant temperature in complex urban settings. Int J Biometeorol 52, 697–713 (2008). https://doi.org/10.1007/s00484-008-0162-7

SOLWEIG GPU code is an extension of the original SOLWEIG Python model that is part of the Urban Multi-scale Environmental Predictor (UMEP) (GitHub code reference: https://github.com/UMEP-dev/UMEP). UMEP journal reference: Lindberg, F., Grimmond, C.S.B., Gabey, A., Huang, B., Kent, C.W., Sun, T., Theeuwes, N.E., Järvi, L., Ward, H.C., Capel-Timms, I. and Chang, Y., 2018. Urban Multi-scale Environmental Predictor (UMEP): An integrated tool for city-based climate services. Environmental modelling & software, 99, pp.70-87. https://doi.org/10.1016/j.envsoft.2017.09.020


Features

  • CPU and GPU support (automatically uses GPU if available)
  • Divides larger areas into tiles based on the selected tile size
  • CPU-based computations of wall height and aspect are parallelized across multiple CPUs
  • GPU-based computation of SVF, shortwave/longwave radiation, shadows, Tmrt, and UTCI
  • Compatible with meteorological data from UMEP, ERA5, and WRF (wrfout)

SOLWEIG-GPU workflow Flowchart of the SOLWEIG-GPU modeling framework


Required Input Data

  • Building DSM: Includes both buildings and terrain elevation (e.g., Building_DSM.tif)
  • DEM: Digital Elevation Model excluding buildings (e.g., DEM.tif)
  • Tree DSM: Vegetation height data only (e.g., Trees.tif)
  • Meteorological forcing:
    • Custom .txt file (from UMEP)
    • ERA5 (both instantaneous and accumulated)
    • WRF output NetCDF (wrfout)

Please refer to the sample dataset to familiarize yourself with the expected inputs. Sample data can be found at https://utexas.box.com/s/8fctqicidr5cup8kj3tk53jd444pow6z

ERA5 Variables Required

  • 2-meter air temperature
  • 2-meter dew point temperature
  • Surface pressure
  • 10-meter U and V wind components
  • Downwelling shortwave radiation (accumulated)
  • Downwelling longwave radiation (accumulated)

Output Details

  • Output directory: Outputs/
  • Structure: One folder per tile (e.g., tile_0_0/, tile_0_600/)
  • SVF: Single-band raster
  • Other outputs: Multi-band raster (e.g., 24 bands for hourly results)

UTCI for New Delhi UTCI for New Delhi, India, generated using SOLWEIG-GPU and visualized with ArcGIS Online.


Installation

conda create -n solweig python=3.10
conda activate solweig
conda install -c conda-forge gdal pytorch
pip install solweig-gpu
#Or from source 
git clone https://github.com/nvnsudharsan/solweig-gpu.git
cd solweig-gpu
pip install .

Python Usage

from solweig_gpu import thermal_comfort

thermal_comfort(
    base_path='/path/to/input',
    selected_date_str='2020-08-13',
    building_dsm_filename='Building_DSM.tif',
    dem_filename='DEM.tif',
    trees_filename='Trees.tif',
    landcover_filename = None,
    tile_size =3600,
    overlap = 100,
    use_own_met=True,
    own_met_file='/path/to/met.txt',
    start_time='2020-08-13 00:00:00',
    end_time='2020-08-13 23:00:00',
    data_source_type='ERA5',  # or 'WRFOUT'
    data_folder='/path/to/era5_or_wrfout',
    save_tmrt=False, #True if you want to save TMRT, likewise below
    save_svf=False,
    save_kup=False,
    save_kdown=False,
    save_lup=False,
    save_ldown=False,
    save_shadow=False
)

Command-Line Interface (CLI)

conda activate solweig
thermal_comfort --base_path /path/to/input \
                --selected_date_str 2020-08-13 \
                --building_dsm_filename Building_DSM.tif \
                --dem_filename DEM.tif \
                --trees_filename Trees.tif \
                --landcover_filename None \
                --tile_size 3600 \
                --use_own_met True \
                --own_met_file /path/to/met.txt \
                --start_time "2020-08-13 00:00:00" \
                --end_time "2020-08-13 23:00:00" \
                --data_source_type ERA5 \
                --data_folder /path/to/era5_or_wrfout \
                --save_tmrt True \
                --save_svf False

Tip: Use --help to list all CLI options.


GUI Usage

To launch the GUI:

conda activate solweig
solweig_gpu_gui

GUI

GUI Workflow

  1. Select the base path containing input datasets.
  2. Choose the Building DSM, DEM, Tree DSM, and Land cover (optional) raster files.
  3. Set the tile size (e.g., 600 or 1200 pixels).
  4. Select a meteorological source (metfile, ERA5, or wrfout):
    • If metfile: Provide a .txt file.
    • If ERA5: Provide a folder with both instantaneous and accumulated files.
    • If wrfout: Provide a folder with WRF output NetCDF files.
  5. Set the start and end times in UTC (YYYY-MM-DD HH:MM:SS).
  6. Choose which outputs to generate (e.g., Tmrt, UTCI, radiation fluxes).
  7. Output will be saved in Outputs/, with subfolders for each tile.

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a Pull Request

Please keep your pull requests small and focused. This will make it easier to review and merge.

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

solweig_gpu-1.2.11.tar.gz (4.7 MB view details)

Uploaded Source

Built Distribution

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

solweig_gpu-1.2.11-py3-none-any.whl (62.1 kB view details)

Uploaded Python 3

File details

Details for the file solweig_gpu-1.2.11.tar.gz.

File metadata

  • Download URL: solweig_gpu-1.2.11.tar.gz
  • Upload date:
  • Size: 4.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for solweig_gpu-1.2.11.tar.gz
Algorithm Hash digest
SHA256 c772832c741f204c5b88bcf9220444505799a4434f1adf29115d4d45f00ace0f
MD5 18ffa194458a908f354b38aab9d576c5
BLAKE2b-256 f27a771254305b0f800542253028a1631c5f93ec3af89c45f625cd5c0152c3dd

See more details on using hashes here.

Provenance

The following attestation bundles were made for solweig_gpu-1.2.11.tar.gz:

Publisher: publish.yml on nvnsudharsan/SOLWEIG-GPU

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file solweig_gpu-1.2.11-py3-none-any.whl.

File metadata

  • Download URL: solweig_gpu-1.2.11-py3-none-any.whl
  • Upload date:
  • Size: 62.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for solweig_gpu-1.2.11-py3-none-any.whl
Algorithm Hash digest
SHA256 08c6d1faae191fbaf0f3b6db83b7aad240063a4a183614d0d09fc3b11790b76b
MD5 044b344a923ba21a62376fb13fcb9abd
BLAKE2b-256 bc3fc4a05a450cf695e13c25a05d8cf14722b48f83989c5bf21e66d99b653314

See more details on using hashes here.

Provenance

The following attestation bundles were made for solweig_gpu-1.2.11-py3-none-any.whl:

Publisher: publish.yml on nvnsudharsan/SOLWEIG-GPU

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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