Google Earth Engine (GEE) 提取某一位置时间序列值

前言

做时间序列相关算法的同学,经常需要下载年际的数据来进行试验。而且算法研究的比较重要的步骤就是利用实测站点数据进行验证。本文讲述如何使用GEE下载指定卫星遥感/再分析数据集指定位置(实测站点位置)的时间序列值。

提取指定点年序列值-imageCollection

整个过程可以在imageCollection上进行操作,并且中间处理过程的返回对象都是image,这种情景非常简单直接。配合上篇博客,也可以进行QC过滤。
首先定义点的经纬度坐标。然后过滤数据集合,这里以MODIS的NDVI产品MOD13A2为例。由于MOD13A2在GEE中原始分辨率为900+m并且原始投影为正弦投影,而我需要在WGS84坐标系上1 km左右尺度的值,所以这里还包括了一个平均聚合和重投影的过程(非常重要)。如果需要从低分辨率向高分辨率采样,则将聚合过程替换为.resample(method)即可。最后就是生成指定点的时间序列图表。

var gwn = ee.Geometry.Point([-89.8729, 34.2574], 'EPSG: 4326');

var mod13a2Collection = ee.ImageCollection("MODIS/006/MOD13A2")
  .filterBounds(gwn)
  .filterDate('2010-01-01', '2011-01-01')
  .select('NDVI');

print(mod13a2Collection); 
 
var mod13a2Collection = mod13a2Collection.map(function(image){
  return image.reduceResolution({
      reducer: ee.Reducer.mean(),
    })
    .reproject({
      crs: 'EPSG: 4326',
      scale: 1000
    });
}); 
  
var chart = ui.Chart.image.series({
  imageCollection: mod13a2Collection,
  region: gwn,
  reducer: ee.Reducer.first(),
  scale: 1000
}).setOptions({title: 'NDVI'});

print(chart);

生成图表如下,右上角按钮可以在新标签页中打开并下载。
在这里插入图片描述

提取指定点年序列值-List

可以看出上边的情形是在最后一步使用ui.Chart.image.series时指定了提取位置。如果在中间过程中就对提取位置进行指定,即对image使用.reduceRegion,那么它的返回对象就是一个由指定位置值组成的年序列列表,无法再构成原始的imageCollection。这时候就需要额外的步骤进行提取。这里以GLDAS的10cm土壤水分为例:

var gwn = ee.Geometry.Point([-89.8729, 34.2574], 'EPSG: 4326');

var gldasSoilMoisture = ee.ImageCollection("NASA/GLDAS/V021/NOAH/G025/T3H")
  .filterDate('2010-01-01', '2011-01-01') 
  .filter(ee.Filter.eq('start_hour', 15))
  .select('SoilMoi0_10cm_inst');
 
//  
var gldasSoilMoisture = gldasSoilMoisture.toList(365).map(function(image){
  var soilMoisture = ee.Image(image)
    .resample('bicubic')
    .reduceRegion({
       geometry: gwn,
       reducer: ee.Reducer.first(),
       scale: 1000
    });
  return soilMoisture;
});
print(gldasSoilMoisture);

上述代码中,由于.reduceRegion返回的并不再是image,所以无法直接对原始imageCollection应用map,需要首先将其转换为List。此外,由于GLDAS原始影像分辨率为0.25°,我需要1 km尺度值,所以需要对它指定重采样方法(如果不指定,GEE默认为最邻近法,误差很大)。上述代码,print的结果为:
在这里插入图片描述
可以看出返回对象还是List,其中每个元素都是字典的形式,SoilMoi0_10cm_inst的值就是我们所需要的值。
所以,接下来需要把值单独提取出来构成一个``List`。

// the calculate result is a list with some dictionary
var gldasSoilMoisture = gldasSoilMoisture.map(function(object){
  return ee.Dictionary(object).get('SoilMoi0_10cm_inst');
});
print(gldasSoilMoisture);

var chart = ui.Chart.array.values({
  array: gldasSoilMoisture,
  axis: 0
});
print(chart);

上述代码即将列表中每个字典的值提取出来构成了新的列表,并进行绘图。
这种情况的代码其实写的麻烦了,不进行.reduceRegion,就可以和第一种情景的代码一致了。但是,掌握这种情景,以后也能更灵活的进行实现。
在这里插入图片描述
后续会更新一篇如何将GLDAS的3小时气温数据求均值转为日均值,并提取指定点年序列值的博客。

  • 6
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
gee是基于像素的时间序列处理的一个工具,通过使用Google Earth Engine (GEE) 平台,可以对遥感影像进行像素级时间序列分析。 基于像素的时间序列处理涉及对单个像素的遥感观测数据进行分析和处理,以了解该像素随时间的变化。gee提供了一套丰富的工具和功能,可以处理和分析各种空间分辨率的遥感数据。 在gee中,用户可以选择感兴趣的区域并提取该区域特定像素的时间序列数据。例如,用户可以获取某一区域的陆表温度、植被指数、降水量等变量的时间序列,并对其进行统计分析和可视化。 gee还提供了一系列的时间序列算法和指标,如平均、标准差、趋势分析等,帮助用户更好地理解像素随时间的变化趋势。用户可以通过这些算法和指标,进行地表覆盖分类、环境监测、农作物生长监测等应用。 另外,gee还支持用户自定义算法和函数,使用户能够根据自己的需求进行时间序列分析和处理。这种基于像素的时间序列处理方法,可以提供更精细和详细的遥感数据分析结果,有助于更好地理解和解释地表动态变化。 综上所述,gee提供了一个功能强大的平台,可以进行基于像素的时间序列处理,帮助用户分析和理解遥感数据随时间的变化及其特征。这种方法在环境科学、地学研究和资源管理等领域有着广泛的应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值