我想使用R编写一个netCDF文件,其维数为“无限”,以后可以扩展。
这就是我尝试过的:
创建netcdf文件
library(ncdf4)
## define lat, lon time dimensions
lat <- ncdim_def("latitude", "degrees_east", vals = 44.0, unlim = TRUE)
lon <- ncdim_def("longitude", "degrees_north", vals = -88.5, unlim = TRUE)
time <- ncdim_def("time", "days since 0000-01-01", 1:1000)
## define data with these dimensions
x <- ncvar_def("myvar", units = "m2", dim = list(lat, lon, time))
## create, write to, close nc file
nc <- nc_create(filename = "tmp.nc", vars = list(x))
ncvar_put(nc = nc, varid = x, vals = 1:1000)
nc_close(nc = nc)我想在不同的lat和lon添加一个新的向量
## reopen existing file
nc <- nc_open("tmp.nc", write = TRUE)
## define new lat, lon dimensions (keep time dim from above)
lat2 <- ncdim_def("latitude", "degrees_east", vals = 44.5, unlim = TRUE)
lon2 <- ncdim_def("longitude", "degrees_north", vals = -89.0, unlim = TRUE)
## define, write new dataset at new lat lon coordinates
x2 <- ncvar_def("myvar", units = "m2", dim = list(lat2, lon2, time))
ncvar_put(nc = nc, varid = x2, vals = 11:1011)我希望能找到两种不同的纬度和经度
ncvar_get(nc, 'latitude')
ncvar_get(nc, 'longitude')
ncvar_get(nc, 'myvar')这些结果表明,该文件是使用第一组lat/lon和“myvar”值编写的,但没有添加新的值集。
我做错了什么?
我知道,有多个无限维的能力,并增加他们,是一个特点的netCDF-4。我怎样才能在R中做到这一点?
我认识到,我一定是在混淆“维度定义”和其他一些概念。但我有点迷路了。
发布于 2015-05-13 17:42:04
是的,我认为您混淆了维度变量中的“维度定义”和实际数据。
如果您运行第一个代码片段,然后使用NetCDF转储ncdump文件,您将看到:
netcdf tmp {
dimensions:
latitude = UNLIMITED ; // (1 currently)
longitude = UNLIMITED ; // (1 currently)
time = 1000 ;
variables:
double latitude(latitude) ;
latitude:units = "degrees_east" ;
latitude:long_name = "latitude" ;
double longitude(longitude) ;
longitude:units = "degrees_north" ;
longitude:long_name = "longitude" ;
int time(time) ;
time:units = "days since 0000-01-01" ;
time:long_name = "time" ;
float myvar(time, longitude, latitude) ;
myvar:units = "m2" ;
data:
latitude = 44 ;
longitude = -88.5 ;
time = 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,
...
990, 991, 992, 993, 994, 995, 996, 997, 998, 999, 1000 ;
myvar =
{{1}},
{{2}},
{{3}},
...
{{1000}} ;
} 尺寸是说latitude和longitude是无限的,而time尺寸是固定在1000个点/天,自0000-01-01。这正是您所指定的,这是好的。
所以再加上一个纬度和经度。我会再次打开该文件,读取当前数据,并将其附加到其中,然后将其写回。
library(ncdf4)
nc <- nc_open("tmp.nc", write = TRUE)
lat <- ncvar_get(nc, varid='latitude')
lat <- append(lat, 44.5)
ncvar_put(nc, varid='latitude', vals=lat, start=c(1), count=2)
nc_close(nc)现在,ncdump将向您展示两个纬度:
data:
latitude = 44, 44.5 ;
longitude = -88.5 ;当然,对于不需要或不想读取所有数据和附件的大型数据集,您只需告诉NetCDF要将其写入何处即可。
library(ncdf4)
nc <- nc_open("tmp.nc", write = TRUE)
lon = -89.0
ncvar_put(nc, varid='longitude', vals=lon, start=c(2), count=1)
nc_close(nc)现在ncdump将向你们展示两个纬度和两个经度:
data:
latitude = 44, 44.5 ;
longitude = -88.5, -89 ;myvar的数据表示是一个3D数组,所以我的初始写入可能会有所不同。在创建数据和将其写入文件时,我会指定它的维度,如下所示:
data <- array(1:1000, c(1,1,1000))
ncvar_put(nc = nc, varid='myvar', vals=data, start=c(1,1,1), count=c(1,1,1000))然后附加到第二纬度和经度:
data <- array(11:1011, c(1,1,1000))
ncvar_put(nc = nc, varid='myvar', vals=data, start=c(2,2,1), count=c(1,1,1000))注意事项
我觉得R包对你隐藏的太多了。使用ncdim_def创建维度时,可以给它赋值。在我看来,这更像是一个3步的过程。
希望这能有所帮助。
https://stackoverflow.com/questions/30084261
复制相似问题