Skip to content

Latest commit

 

History

History
123 lines (88 loc) · 5.75 KB

README.md

File metadata and controls

123 lines (88 loc) · 5.75 KB

barra2-dl

Build Status codecov Python Version wemake-python-styleguide

A tool for downloading BARRA version 2 (BARRA2) atmospheric reanalysis data.

Background

barra2-dl is a Python package to bulk download data from BARRA2 reanalysis data for a specific latitude and longitude. It is for use in wind resource and energy assessments, but can be used to download other data from BARRA2.

BARRA2 provides the Bureau's higher resolution regional atmospheric reanalysis over Australia and surrounding regions, spanning 1979-present day time period. When completed, it replaces the first version of BARRA (Su et al., doi: 10.5194/gmd-14-4357-2021; 10.5194/gmd-12-2049-2019).

It is produced using the Bureau's data assimilation system for numerical weather prediction - 4D variational scheme, and ACCESS as a limited-area dynamical coupled atmosphere-land model - Unified Model (UM) and JULES.

The data set includes sub-daily, daily and monthly data for temperature, moisture, wind and flux variables at sub-surface, surface, and pressure levels, and heights above surface. The vertical levels include many pressure levels and several heights above surface.

Data Provider: Bureau of Meteorology

NCI Data Catalogue: https://dx.doi.org/10.25914/1x6g-2v48 NCI THREDDS Data Server: https://dx.doi.org/10.25914/1x6g-2v48 License: https://creativecommons.org/licenses/by/4.0/ Extended Documentation: https://opus.nci.org.au/x/DgDADw

Source: https://thredds.nci.org.au/thredds/fileServer/ob53/BARRA2/README.txt

Data from BARRA2 can be downloaded in netCDF or CSV format from the NCI THREDDS server.

However, BARRA2 is structured with data for each variable saved in separate folders with separate files for each month. Therefore, for the purpose of downloading a subset of variables for a specific location, a recursive web request is required using the NetcdfSubset Data Access to get subsetted data.

This package and example scripts provides examples to recursively download data in csv (for point data) relevant to wind farm resource analysis for specific locations and time periods.

The following links provide an example of the urls:

Example URL for NetCDF grid files for ua50m wind speed: https://thredds.nci.org.au/thredds/ncss/grid/ob53/output/reanalysis/AUS-11/BOM/ERA5/historical/hres/BARRA-R2/v1/1hr/ua50m/latest/ua50m_AUS-11_ERA5_historical_hres_BOM_BARRA-R2_v1_1hr_197901-197901.nc?var=ua50m&north=-36&west=140&east=141&south=-37&horizStride=1&time_start=1979-01-01T00:00:00Z&time_end=1979-01-31T23:00:00Z&&&accept=netcdf3

Or as grid points to get CSV files for ua50m wind speed: https://thredds.nci.org.au/thredds/ncss/grid/ob53/output/reanalysis/AUS-11/BOM/ERA5/historical/hres/BARRA-R2/v1/1hr/ua50m/latest/ua50m_AUS-11_ERA5_historical_hres_BOM_BARRA-R2_v1_1hr_197901-197901.nc?var=ua50m&latitude=-36&longitude=140&time_start=1979-01-01T00%3A00%3A00Z&time_end=1979-01-31T23%3A00%3A00Z&timeStride=&vertCoord=&accept=csv

Reference for downloading from thredds is provided here: https://opus.nci.org.au/display/DAE/examples-thredds

For a full list of BARRA2 variables refer to the BARRA2 FAQ: https://opus.nci.org.au/pages/viewpage.action?pageId=264241306

Refer to BARRA2 documentation for further details: https://opus.nci.org.au/pages/viewpage.action?pageId=264241166

Features

  • Point data download to closest node from BARRA2 AUS-11 Reanalysis data
  • Fully typed with annotations and checked with mypy, PEP561 compatible

Installation

# Clone or download repo

Example

from datetime import datetime
from pathlib import Path

import barra2_dl

from barra2_dl.globals import barra2_var_wind_50m, barra2_var_wind_default, BARRA2_AUS11_INDEX

barra2_dl.download.get_point_data(
    barra2_vars = barra2_var_wind_default,
    latitude = -23.5527472,
    longitude = 133.3961111,
    start_datetime= datetime.strptime("2023-01-01T00:00:00Z", "%Y-%m-%dT%H:%M:%SZ"),
    end_datetime = datetime.strptime("2023-03-31T23:00:00Z", "%Y-%m-%dT%H:%M:%SZ"),
    fileout_prefix = "Demo",
    fileout_folder= r"cache_dir",
)

Also refer to the example Jupyter Notebook and script

License

CC-BY-4.0

Roadmap

  1. Currently, AUS-11 1hr is implemented. Add option for AUS-22 and AUST-04
  2. Implement bulk download for netCDF (for gridded data)
  3. Add download progress bar
  4. Multi-location download
  5. CLI interface

Contributing

Refer to Contributing.md

Or if you are so inclined or use this for commercial work you can "Buy Me A Coffee"

Authors and acknowledgment

akarich73

This project was generated with wemake-python-package. Current template version is: 326622187bdef4596c6fe0901e481bc6e7ebc93a. See what is updated since then.