我有一个RasterBrick,其中包含每日积雪数据,其值为 1、2 和 3(1= 下雪,2= 无雪,3= 被云遮挡)。
一天的积雪示例:
> snowcover
class : Large RasterBrick
dimensions : 26, 26, 2938 (nrow, ncol, nlayers)
resolution : 231, 232 (x, y)
extent : 718990, 724996, 5154964, 5160996 (xmin, xmax, ymin, ymax)
crs : +proj=utm +zone=32 +datum=WGS84 +units=m +no_defs +ellps=WGS84
+towgs84=0,0,0
现在我希望插入被云遮挡的像素(但仅限于单个 RasterLayer 中云量少于 90% 的情况,否则应为该图层保留原始值)。
对于空间插值,我想使用数字高程模型(相同的研究区域并且已经具有相同的分辨率)分别为RasterBrick 的每个图层提取上下雪线边界。上方的雪线表示所有无云像素都归类为雪的海拔高度。较低的雪线标识了所有无云像素也无雪的高度。
> dem
class : RasterLayer
resolution : 231, 232 (x, y)
extent : 718990.2, 724996.2, 5154964, 5160996 (xmin, xmax, ymin, ymax)
crs : +proj=utm +zone=32 +datum=WGS84 +units=m +no_defs +ellps=WGS84
+towgs84=0,0,0
values : 1503, 2135 (min, max)
对于上部雪线,我需要雪覆盖像素的最小高度(值 = 1)。现在,RasterBrick 的 RasterLayer 中高于此最小高程的所有值为 3 的像素都应重新分类为值 1(假设被雪覆盖)。
另一方面,对于较低的雪线,我需要确定无雪像素的最大海拔(值 = 2)。现在,RasterBrick 的 RasterLayer 中高于此最大高程的所有值为 3 的像素都应重新分类为值 2(假设无雪)。
这可能使用R吗?
我试图利用覆盖功能,但我被困在那里。
# For the upper snowline:
overlay <- overlay(snowcover, dem, fun=function(x,y){ x[y>=minValue(y[x == 1])] <- 1; x})