[R-sig-Geo] Gaussian grids in R
landis at isciences.com
Thu Jul 1 16:05:32 CEST 2010
Dear R-sig-geo members,
I wonder if any of you have suggestions about how to import and use
rasters with a spectral Gaussian T62 CRS in R. I'm not very familiar
with this coordinate system (commonly used for climate models), and I
haven't been able to discover tools for dealing with them in R, either
in PROJ.4 or mapproj or anywhere else, despite extensive scouring of the
web. Details of Gaussian grids can be seen at
Specifically, I'm trying to use output from the NCEP CFS climate models
(see http://cfs.ncep.noaa.gov/cfs/monthly/tmp2m/ -- these are in GRIB
format). A different example of a T62 grid can be downloaded in netCDF
format at http://www.sage.wisc.edu/iamdata/grid.php.
The goal is to transform the CRS into geographic lat/lon coordinates to
be more compatible with our other datasets. The big problem with
getting these data into a SpatialGrid or SpatialPixelsDataFrame is that
the latitude cells are not equally spaced - they get smaller towards the
poles. I may be able to approximate it to a regular grid by ignoring
the changes to the poles (they are rather small after all), but I'd
rather do it properly if possible.
Code below shows extracting latitudes from a T62 grid and plotting the
changes in cell size with latitude.
nc <- 'C:/scratch/cfs/pop_den_1995_T62.nc' # Downloaded from
# Open the file and get latitude and longitude
nc <- open.ncdf(ncfile)
lat <- get.var.ncdf(nc, varid = 'latitude')
lon <- get.var.ncdf(nc, varid = 'longitude')
# Generate coordinates for each grid cell
x <- rep(lon, length(lat))
y <- rep(lat, each = length(lon))
sp <- SpatialPoints(cbind(x,y))
# temp <- SpatialPixels(points = sp) # Doesn't work. points have to be
# Show how the cell size changes with latitude
cell.size <- diff(rev(lat))
Many thanks for any suggestions!
Matthew Landis, Ph.D.
61 Main St. Suite 200
Burlington VT 05401
More information about the R-sig-Geo