首页 > 编程语言 >GEE中用JavaScript计算遥感数据在两个日期中变化值的多年平均

GEE中用JavaScript计算遥感数据在两个日期中变化值的多年平均

时间:2024-08-30 12:23:51浏览次数:17  
标签:ee JavaScript 遥感 GEE NDVI var ndvi 2013 history

  本文介绍在谷歌地球引擎GEE中,提取、计算某一种遥感影像产品在连续的多年中,2不同时相数据差值多年平均值,并将计算得到的这一景差值的结果图像导出的方法。

  首先,我们来看一下本文需要实现的需求。现在我们希望计算某一个地区中,在2013年到2020年的这8年中,第257天与249天的这2个时间节点上,NDVI数据的差值的平均值;换句话说,我们希望在2013年到2020年的这8年中,计算每一年里第257天与249天的NDVI数据的差值(也就是获得了8个差值),然后对这8个差值计算平均值,最终得到一景结果栅格图像。随后,我们还希望将这一景结果图像导出到本地。

  知道了需求,我们即可开始代码的撰写。本文需要用到的代码如下。

var ndvi = ee.ImageCollection("MODIS/MYD09GA_006_NDVI")
  .filterDate('2013-01-01', '2023-01-01')
  .select(["NDVI"]);
  
var filterByDay = function(date) {
  var start = ee.Date(date).advance(249, 'day');
  var end = start.advance(1, 'day');
  return ndvi.filterDate(start, end).mosaic();
};
var filterByDay_2 = function(date) {
  var start = ee.Date(date).advance(257, 'day');
  var end = start.advance(1, 'day');
  return ndvi.filterDate(start, end).mosaic();
};

var images = ee.List.sequence(2013, 2020)
  .map(function(year) {
    var date = ee.Date.fromYMD(year, 1, 1);
    return filterByDay(date);
  });
var images_2 = ee.List.sequence(2013, 2020)
  .map(function(year) {
    var date = ee.Date.fromYMD(year, 1, 1);
    return filterByDay_2(date);
  });

var result = ee.ImageCollection.fromImages(images);
var result_2 = ee.ImageCollection.fromImages(images_2);

// var chinaBoundary = ee.Geometry.Rectangle(73, 8, 136, 54);
var chinaBoundary = ee.Geometry.Rectangle(97, 26, 109, 35);

var ndvi_china = result.map(function(image) {
  return image.clip(chinaBoundary);
});
var ndvi_china_2 = result_2.map(function(image) {
  return image.clip(chinaBoundary);
});

var ndvi_history = ndvi_china.reduce(ee.Reducer.mean());
var ndvi_history_2 = ndvi_china_2.reduce(ee.Reducer.mean());

var ndvi_dif_history = ndvi_history_2.subtract(ndvi_history);

Map.addLayer(ndvi_dif_history, {}, 'NDVI_History');
Map.centerObject(ndvi_dif_history, 2);

var exportParams = {
  image: ndvi_dif_history,
  description: 'ndvi_dif_history',
  scale: 500,
  region: chinaBoundary,
  maxPixels: 10000000000000
};

Export.image.toDrive(exportParams);

  上述代码的具体含义如下。

  首先,加载MODIS/MYD09GA_006_NDVI产品,也就是MODISNDVI产品;随后,使用.filterDate()方法筛选出日期范围为2013-01-012023-01-01的图像(本文只需要计算2013年到2020年的这8年数据,所以这里的截止时间设置为2020-12-31之后的任意时间均可),并使用.select(["NDVI"])方法仅选择NDVI波段。

  随后,var filterByDay = function(date) { ... };var filterByDay_2 = function(date) { ... };这两个函数分别定义了2个不同天数(第257天与249天)的不同的筛选方式。filterByDay函数通过将日期向后推移249天来获取每年的第249天的NDVI图像,而filterByDay_2函数通过将日期向后推移257天来获取每年的第257天的NDVI图像。

  其次,var images = ee.List.sequence(2013, 2020).map(function(year) { ... });等两个部分使用ee.List.sequence() 函数生成从2013年到2020年的年份序列,随后通过.map()方法对每个年份应用相应的函数。images变量包含了每年的第249天的的NDVI图像,而images_2变量包含了每年的第257天的NDVI图像。这个函数和前面的函数相结合,就可以提取出从2013年到2020年中每一年的第257天与249天的数据。

  接下来,var result = ee.ImageCollection.fromImages(images);等两行代码将imagesimages_2转换为ee.ImageCollection对象,以便进行后续的图像处理;var ndvi_china = result.map(function(image) { ... });等两个部分使用.map()方法对resultresult_2中的每个图像应用函数,即将图像裁剪为我们需要的边界范围内的区域。

  随后,var ndvi_history = ndvi_china.reduce(ee.Reducer.mean());等两行代码对ndvi_chinandvi_china_2中的图像集合应用ee.Reducer.mean()函数进行降维,计算每个像素点在时间范围内的平均的NDVI图像值,也就是获得了2013年到2020年的这8年中,第257天与249天的这2个时间节点上,NDVI数据各自的平均值。随后的这行代码,就是计算ndvi_history_2ndvi_history之间的差异,相当于就是获得了NDVI数据平均值的差值

  接下来的两行代码,则将ndvi_dif_history图像添加到地图中,并将地图中心设置为该视图的范围。

  最后,var exportParams = { ... };Export.image.toDrive(exportParams);这两段代码为设置导出参数,并使用Export.image.toDrive()ndvi_dif_history图像导出到Google Drive中。之后,我们就可以到Google Drive中下载这一景导出的数据了。

  执行上述代码,如下图所示。首先可以在下方的地图中看到我们计算得到的结果图像,其次可以在右侧看到Tasks中生成的任务。

  在上图中,点击右侧的“Run”,如下图所示。在其中配置好相关的信息,即可开始结果文件的下载。

  随后,就可以在Google Drive中指定的位置看到我们的结果图像文件了;如下图所示。之后,我们就可以将这一景栅格图像文件下载到本地了。

  至此,大功告成。

标签:ee,JavaScript,遥感,GEE,NDVI,var,ndvi,2013,history
From: https://blog.51cto.com/fkxxgis/11875217

相关文章

  • JavaScript开发学习札记:一位Java后端程序员的成长之路
    前言:        这是一篇关于JavaScript的学习笔记,目的是针对java后端开发人员,快速入门并掌握JavaScript这门语言的基本使用,并且能够进入下一阶段框架的学习。引言:为什么学习JavaScript?JavaScript是web开发人员必须学习的3门语言中的一门:HTML定义了网页的内......
  • GEE 更新和优化:利用GEE在线处理1985-2024年NDVI、EVI、SAVI、NDMI等指数归一化教程!(Lan
    简介本次的归一化教程,优化了数据去云,预处理等过程,同事将landsat5/7/8集合分别进行了数据整合,也就是原始波段的处理,从而我们可以调用1985-至今任何一个时期的影像进行归一化处理。具体的原文介绍请看原始的博客原始博客利用GEE(GoogleEarthEngine)在线处理NDVI、EVI、SAVI......
  • GEE APP:利用夜间灯光数据建立一个简易的逐年影像查看器
    简介很多时候我们可以通过简单的滑块进行逐年影像的查看,slider这个工具可以进行每一年的夜间灯光数据的查看,这里主需要设定其实和后续的年份,另外,并给每一年进行属性设定对应的影像即可。这里最关键的就是一个返回值函数的设定,也就是滑块中的onchange函数的设定,这里我们首先要......
  • JavaScript高阶 day-04
    目录一.严格模式1.1什么是严格模式1.2开启严格模式1.3严格模式中的变化二.高阶函数三.闭包3.1变量的作用域3.2什么是闭包3.3闭包的作用3.4闭包的案例四.递归4.1什么是递归4.2利用递归求1~n的阶乘五.赋值(地址传递)-浅拷贝-深拷贝5.1地址传递5.2Object.......
  • JavaScript高阶 day-03
    目录一.函数内部的this指向二.函数对象的原型的方法2.1Function.prototype.call()---call()方法2.2Function.prototype.apply()---apply()方法2.3Function.prototype.bind()---bind()方法2.4call、apply、bind三者的异同2.5Object.prototype.toString()判断数据类......
  • 博客园-awescnb插件-geek皮肤优化--浏览器ico图标修改
    简介通过js方式自定义修改博客园-awescnb插件-geek皮肤下浏览器ico图标图标准备准备自定义的图标,上传至博客园个人的相册中代码注入定义自定义HTML:博客园->管理->设置->页脚HTML代码添加相关代码//更换ico图标functionupdateICO(){varlink=docum......
  • Javascript里的闭包
    闭包闭包,允许函数访问创建时的作用域中的变量,即使该函数在其原始作用域之外被执行。这使得闭包非常适合用于封装私有变量和创建具有特定状态的函数。Javascript里的闭包functioncreateCounter(){letcount=0;//计数器的私有变量return{increment:f......
  • JavaScript
    一,js中的数据类型1数值型:number整数和浮点数统称为数值。例如85或3.1415926等。2字符串型:String由0个,1个或多个字符组成的序列。在JavaScript中,用双引号或单引号括起来表示,如"您好"、'学习JavaScript'等。3逻辑(布尔)型:boolean用true或false来表示。4空(null)值:表示没有......
  • JavaScript变量和数据类型
    一、变量1、简介​在程序运行过程中其值可以改变的量,是一个数据存储空间的表示,即给内存空间起别名​将数值通过变量进行存储,以便程序随时使用,通俗点来说,变量就是用来存储数据的​JavaScript是弱变量类型的语言,声明变量只需要使用var关键字​语法:var变量名=变量值;<s......
  • JavaScript 模块化开发:ES6 模块与 CommonJS 的对比与应用
    ​​您好,我是程序员小羊!前言随着前端项目规模的增长,代码组织和管理变得越来越复杂。模块化开发成为解决这一问题的有效手段,能够帮助开发者将代码进行分割、复用和维护。JavaScript在发展过程中出现了多种模块化规范,其中最为广泛使用的有ES6模块(也称为ESModules)......