GEE谷歌地球引擎计算每隔8天的遥感影像数据的平均值

本文涉及的产品
实时数仓Hologres,5000CU*H 100GB 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
简介: 【2月更文挑战第5天】本文介绍在谷歌地球引擎(Google Earth Engine,GEE)中,计算长时间序列遥感影像数据在多年中,在每一个指定天数的时间范围内的平均值的方法~

  本文介绍在谷歌地球引擎(Google Earth Engine,GEE)中,计算长时间序列遥感影像数据在多年中,在每一个指定天数的时间范围内的平均值的方法。本文是谷歌地球引擎(Google Earth Engine,GEE)系列教学文章的第二十篇。

  首先,我们来看一下本文需要实现的需求。现在我们希望,计算某个研究区域中,2022年内每一个8天的时间范围内,NDVI数据的平均值。换句话说,我们希望对于2022年的001天到008天内的全部NDVI数据计算平均值,然后再对009天到016天内的全部NDVI数据计算平均值,然后再对017天到024天内的全部NDVI数据计算平均值,依此类推。最后,我们对每一个8天范围内的平均值结果图像加以导出。这个需求和我们之前的Python自动计算Excel数据指定范围内的区间最大值有些类似,不过当时的文章中,我们是将遥感影像中某一个像元的多年数据提取到Excel中,且计算的是最大值;而在本文中,我们希望是对整个研究区域内的全部遥感影像加以指定间隔时期内数据的计算,且计算的是平均值

  明确了需求,我们即可开始代码的撰写。本文所用代码如下。

var year = ee.String("2022");
var ndvi = ee.ImageCollection("MODIS/MYD09GA_006_NDVI")
  .filterDate('2022-01-01', '2023-01-01')
  .select(["NDVI"]);
var chinaBoundary = ee.Geometry.Rectangle(70, 14, 137, 52);
var selectedDays = ee.List.sequence(1, 366, 8);

var filterAndClip = function(day) {
   
   
  var start = ee.Number(day);
  var end = start.add(7);
  var filtered = ndvi.filter(ee.Filter.calendarRange(start, end, 'day_of_year'))
    .map(function(image) {
   
   
      // print(start);
      // print(end);
      // return image.clip(chinaBoundary).reproject('EPSG:4326', null, 500);
    return image.clip(chinaBoundary)
    });
  // Map.addLayer(filtered, {}, 'NDVI');
  var filtered_mean = filtered.reduce(ee.Reducer.mean());
  // Map.addLayer(filtered_mean, {}, "NDVI_Mean");
  // return filtered;
  return filtered_mean;
  // return filtered.reduce(ee.Reducer.mean());
};

var ndvi_china = ee.ImageCollection([]);

for (var i = 0; i < selectedDays.length().getInfo(); i++) {
   
   
  var day = selectedDays.get(i);
  var filtered = filterAndClip(day);
  var exportParams = {
   
   
    image: filtered,
    description: year.cat(ee.Number(day).format('%03d')).getInfo(),
    folder: "ndvi_8_days_new",
    scale: 500,
    region: chinaBoundary,
    maxPixels: 10000000000000
  };
  Export.image.toDrive(exportParams);
  ndvi_china = ndvi_china.merge(filtered);
}

  首先,定义变量和数据源。其中,year是一个包含字符串值2022Earth Engine字符串对象,后面我们导出遥感影像的时候,需要将其作为导出文件的文件名前缀。ndvi是通过筛选日期和选择NDVI波段来创建的MODIS NDVI影像集合。chinaBoundary是本文中研究区域边界的矩形几何对象。selectedDays是一个包含从1366的数值列表,表示一年中每8天的时间间隔。

  随后,定义一个函数filterAndClip,用于筛选指定时间范围内的NDVI影像集合,并对每个影像进行边界裁剪;最后,它返回裁剪后影像集合的平均值。对于这个函数,首先,函数接受一个参数day,表示时间值。其次,将传入的时间值day转换为Earth Engine数值对象,分别存储在startend变量中;这里的day是一个整数,表示一年中的某个时间。接下来,使用ee.Filter.calendarRange函数对ndvi影像集合进行筛选,根据daystartend的值,筛选出位于指定时间范围内的影像;这里使用'day_of_year'参数表示筛选基于一年中的日期。随后,使用map函数对筛选后的影像集合中的每个影像进行边界裁剪;image.clip(chinaBoundary)将每个影像裁剪为中国边界范围内的部分。裁剪后的影像集合存储在filtered变量中。其次,使用reduce函数和ee.Reducer.mean()对裁剪后的影像集合进行平均值计算;filtered.reduce(ee.Reducer.mean())将每个像素位置的影像值取平均,生成一个表示平均值的影像。最后,函数返回裁剪和平均值计算后的影像集合filtered_mean

  接下来,创建一个空的影像集合ndvi_china,用于存储最后裁剪和筛选后的NDVI影像(但是我这里后面没有用上这个影像集合ndvi_china,之所以有这个是之前别的需求会用到,后来更换需求了但是代码这里没有删除)。

  其次,我们使用循环处理每个时间段。在循环中,我们遍历selectedDays列表中的每个时间值。对于每个时间值,我们调用filterAndClip函数来获取裁剪和筛选后的NDVI影像的平均值。

  然后,我们定义了导出参数exportParams,包括要导出的影像、描述、文件夹、比例尺、区域和最大像素数等。

  最后,我们使用Export.image.toDrive函数将筛选后的影像导出到Google Drive,并将其添加到ndvi_china影像集合中。

  执行上述代码,我们来看一下效果。这里需要注意,为了更好地展示代码的效果,运行时我将代码中如下所示位置的2Map.addLayer()函数取消注释了。

  首先,看一下“Inspector”。如下图所示,每一个NDVI_Mean图像(下图中下方的紫色框内),都是其上方8景图像(下图中上方的紫色框内)的平均值,也就是这8天的NDVI的平均值。不难看出,下图中上方的紫色框内,8景图像就是从当年第001天到第008天的NDVI,那么下图中下方的紫色框内就是从001天到008天的NDVI的平均值。

  其次,看一下“Tasks”。如下图所示,这一年内每隔8天的NDVI平均值结果图像都可以加以导出了。

  至此,大功告成。

相关文章
|
8月前
GEE——在GEE中计算地形位置指数TPI
GEE——在GEE中计算地形位置指数TPI
507 0
|
数据挖掘 编译器 Python
忽略NoData计算多时相遥感影像各个像元的平均值:Python
本文介绍基于Python中whitebox模块,对大量长时间序列栅格遥感影像的每一个像元进行忽略NoData值的多时序平均值求取~
203 2
忽略NoData计算多时相遥感影像各个像元的平均值:Python
|
8月前
Google Earth Engine(GEE)—— 基于MODIS影像单点缓冲区长时序温度时序变化和线性趋势分析
Google Earth Engine(GEE)—— 基于MODIS影像单点缓冲区长时序温度时序变化和线性趋势分析
97 0
|
8月前
|
定位技术 计算机视觉
Google Earth Engine谷歌地球引擎计算多年中某两个时间点之间遥感数据差值的平均值
Google Earth Engine谷歌地球引擎计算多年中某两个时间点之间遥感数据差值的平均值
130 2
|
8月前
|
定位技术 Python
Python中GDAL批量绘制多时相栅格遥感影像的像元时间序列曲线图
Python中GDAL批量绘制多时相栅格遥感影像的像元时间序列曲线图
|
8月前
|
传感器
遥感应用中常用的23个植被指数公式大全和GEE目前最常用Landsat影像时间和名称
遥感应用中常用的23个植被指数公式大全和GEE目前最常用Landsat影像时间和名称
364 0
|
存储 Python
Python对多时相的遥感影像加以各像元平均值的求取
本文介绍基于Python中ArcPy模块,对大量长时间序列栅格遥感影像文件的每一个像元进行多时序平均值的求取~
258 1
Python对多时相的遥感影像加以各像元平均值的求取
|
存储 安全 定位技术
如何利用 ArcGIS Pro 和 Landsat 8 图像计算叶绿素指数和全球环境监测指数
如何利用 ArcGIS Pro 和 Landsat 8 图像计算叶绿素指数和全球环境监测指数
386 0
如何利用 ArcGIS Pro 和 Landsat 8 图像计算叶绿素指数和全球环境监测指数
|
编解码
Google Earth Engine(GEE)——美国近地表高精度实时气象数据集(2500米分辨率)
Google Earth Engine(GEE)——美国近地表高精度实时气象数据集(2500米分辨率)
475 0
Google Earth Engine(GEE)——美国近地表高精度实时气象数据集(2500米分辨率)
|
ice
Google Earth Engine(GEE)——基于s2影像的实时全球10米土地利用/土地覆盖(LULC)数据集
Google Earth Engine(GEE)——基于s2影像的实时全球10米土地利用/土地覆盖(LULC)数据集
569 0
Google Earth Engine(GEE)——基于s2影像的实时全球10米土地利用/土地覆盖(LULC)数据集