MPAS | WRF | Extract subset of GFS GRIB files
GFS subset download
NOMADS Data at NCEP
- https://nomads.ncep.noaa.gov/
- https://nomads.ncep.noaa.gov/gribfilter.php?ds=gfs_0p25_1hr
- Example:
1
https://nomads.ncep.noaa.gov/cgi-bin/filter_gfs_0p25_1hr.pl?dir=%2Fgfs.20250228%2F00%2Fatmos&file=gfs.t00z.pgrb2.0p25.anl&var_TMP=on&var_U-GWD=on&var_V-GWD=on&all_lev=on
- Dowload script:
▶download_gfs.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39#!/bin/bash
#
# define URL
#
workdir=/home/wpsze/mpas/GFS/
hr=00
#date_st=20240920
date_st=$(date -d "today -1 days" +%Y%m%d)
#wget
for iday in {0..0..1}; do
idate=$(date -d "$date_st + $iday days" +%Y%m%d)
echo $date_st $idate
for fhr in {000..120..1}; do
#for fhr in {076..76..1}; do
URL="https://nomads.ncep.noaa.gov/cgi-bin/filter_gfs_0p25_1hr.pl?\
dir=%2Fgfs.${idate}%2F${hr}%2Fatmos&\
file=gfs.t${hr}z.pgrb2.0p25.f${fhr}&\
var_HGT=on&var_PRATE=on&var_PRES=on&var_PRMSL=on&var_RH=on&var_TMP=on&var_UGRD=on&var_VGRD=on&\
lev_2_m_above_ground=on&lev_10_m_above_ground=on&lev_80_m_above_ground=on&lev_100_m_above_ground=on&\
lev_1000_m_above_ground=on&lev_4000_m_above_ground=on&lev_1000_mb=on&lev_975_mb=on&lev_950_mb=on&\
lev_925_mb=on&lev_900_mb=on&lev_850_mb=on&lev_700_mb=on&lev_600_mb=on&lev_500_mb=on&lev_surface=on&lev_mean_sea_level=on&\
subregion=&toplat=65&leftlon=70&rightlon=140&bottomlat=10"
yyyymm=${idate:0:6}
datapath=$workdir/0p25/$yyyymm/$idate/
mkdir -p $datapath
# download file
#curl "$URL" -o download_test$fhr.grb
wget "$URL" -O $datapath/gfs.t${hr}z.pgrb2.0p25.f${fhr}.grb
# add a sleep to prevent a denial of service in case of missing file
sleep 3
done
done

rda.ucar.edu
- https://rda.ucar.edu/datasets/d084001/dataaccess/#
- Sign up with orcid
- Customizable Data Requests > Subsetting
- Waiting for completion
- csh/python scripts are provided



1 |
|
1 |
|
Micromamba env setup
1 |
|
grib checking
take GFS-wave model as example,
grib_ls gfs.t00z.global.0p16.f000.grib2
▶gfs.t00z.global.0p16.f000.grib21
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24gfs.t00z.global.0p16.f000.grib2
edition centre date dataType gridType stepRange typeOfLevel level shortName packingType
2 kwbc 20250227 fc regular_ll 0 surface 1 ws grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 wdir grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 u grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 v grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 swh grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 perpw grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 dirpw grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 shww grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 1 swell grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 2 swell grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 3 swell grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 mpww grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 1 swper grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 2 swper grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 3 swper grid_jpeg
2 kwbc 20250227 fc regular_ll 0 surface 1 wvdir grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 1 swdir grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 2 swdir grid_jpeg
2 kwbc 20250227 fc regular_ll 0 orderedSequenceData 3 swdir grid_jpeg
19 of 19 messages in gfs.t00z.global.0p16.f000.grib2
19 of 19 total messages in 1 files- re-download dataset that only contains surface variables.
grib_to_netcdf gfs.t00z.global.0p16.f000.grib2 -o test.nc
ncvis/ncview test.nc
Read GFS grib2 files
To process a CSV file containing station information (latitude and longitude) and extract weather data from GFS GRIB files, you can follow the steps below. This example assumes you have a CSV file named stations.csv
with columns for station names, latitude, and longitude.
1 |
|
Step 1: Prepare Your CSV File
Ensure your stations.csv
has the following structure:
1 |
|
Step 2: Code to Extract Data and Save to CSV
Here's a complete Python script that reads the station information, extracts the required data from the GRIB files, and writes the results to a new CSV file.
1 |
|
Step 3: Run the Script
- Make sure to replace
'path_to_your_file.grib2'
with the actual path to your GRIB file. - Save the script to a
.py
file and run it using Python.
Output
The output will be a CSV file named output.csv
with the following columns:
station
t2m
(Temperature at 2m)u10
(U-component of wind at 10m)v10
(V-component of wind at 10m)rh2m
(Relative humidity at 2m)sdswrf
(The surface downward shortwave radiation flux)
1 |
|
Note
- Ensure that the indices for
t2m
,u10
,v10
,rh2m
, andsdswrf
are correctly set according to how your GRIB data is structured. - You may need to adjust the extraction logic based on the specific GRIB messages you are working with.
Read Multiple GFS grib files
Code to Extract Data and Save to CSV
1 |
|
Output
1 |
|
xarray
's interp
method with the "linear"
option on a 2D array
When using xarray
's interp
method with the "linear"
option on a 2D array, the method performs linear interpolation along the specified dimensions. This allows you to compute interpolated values at new coordinate points based on existing data in two dimensions.
How It Works for 2D Arrays
- Data Structure: A 2D array in
xarray
is typically represented as aDataArray
or aDataset
, where you have two dimensions (e.g., latitude and longitude, or time and another variable). - Linear Interpolation: The
"linear"
method calculates the interpolated values by creating linear relationships between existing data points. For each new coordinate point specified, it finds the nearest surrounding points in both dimensions and computes the interpolated value based on the linear ratio of the distances.
- For each new coordinate:
- The method identifies the surrounding points in the original 2D array.
- It calculates the interpolated value based on the linear relationship between the values at these surrounding points.
- The interpolation is done separately for each dimension, effectively creating a bilinear interpolation effect.
- 2D Linear Interpolation: The
"linear"
method allows you to compute intermediate values smoothly between known data points in a 2D grid. - Applications: This is useful in various fields such as geospatial analysis, climate modeling, and any scenario where a grid of values needs to be estimated at non-integer coordinates.
Using xarray
's interp
method in this way enables effective handling of multi-dimensional datasets, ensuring accurate and smooth transitions between data points.