GEE15:获取不同遥感指数的时间序列及不同指数间的关系

GEE

    • [1. 不同遥感指数间的时间序列分析](#1. 不同遥感指数间的时间序列分析)
    • [2. 不同指数之间的关系](#2. 不同指数之间的关系)

1. 不同遥感指数间的时间序列分析

GPP数据在一定程度上和植被指数(如NDVI和EVI)有着显著的相关性,那么其相关性如何?如何从时间序列的角度来思考呢?下面我将用GEE代码解答这个问题。

数据:

  • GPP MOD17A2H.006 Terra Gross Primary Productivity 8-Day Global 500m
  • NDVI & EVI MOD13Q1.006 Terra Vegetation Indices 16-Day Global 250m
  • DEM Copernicus DEM GLO-30 Global 30m Digital Elevation Model
javascript 复制代码
// 不同数据源的时间序列分析(GPP,NDVI and EVI)
// 研究区设置
var ROI = ee.FeatureCollection('projects/ee-*******736/assets/Sichuan_province')
var styling = {color:"red",fillColor:"00000000"}
Map.centerObject(ROI,5)
Map.addLayer(ROI.style(styling),{},"geometry")

// 数据预处理
// 选择数据集并进行波段比例换算
var years = ee.List.sequence(2000, 2022);
var collectYear = ee.ImageCollection(years
  .map(function(y) {
    var start = ee.Date.fromYMD(y, 1, 1);
    var end = start.advance(12, 'month');
    var GPP = ee.ImageCollection('MODIS/006/MOD17A2H')
                  .select('Gpp')
                  .filterDate(start, end)
                  .map(function(image){
                    return image.multiply(0.001).set(image.toDictionary(image.propertyNames()));// 此处将GPP扩大了10倍
                  }).mean().rename('GPP')
    var NDVI = ee.ImageCollection("MODIS/006/MOD13Q1")
                  .filterDate(start, end)
                  .select("NDVI")
                  .map(function(image){
                    return image.multiply(0.0001).set(image.toDictionary(image.propertyNames()))
                  }).mean().rename('NDVI');
    var EVI = ee.ImageCollection("MODIS/006/MOD13Q1")
                  .filterDate(start, end)
                  .select("EVI")
                  .map(function(image){
                    return image.multiply(0.0001).set(image.toDictionary(image.propertyNames()))
                  }).mean().rename('EVI');
    return GPP.addBands(NDVI).addBands(EVI).set('year',y)
	}
  )
);
print (collectYear);


// 计算研究区域内的波段时间序列
var Yearlychart = ui.Chart.image.series({
  imageCollection : collectYear.select('NDVI','EVI','GPP'),
  region : ROI,
  reducer:ee.Reducer.mean(),
  scale:500,
  xProperty: 'year',})
  .setChartType('LineChart').setOptions({
  interpolateNulls: true,
  title: 'GPP & NDVI time series',
  hAxis: {title: 'Date'},
  vAxis: {title: 'GPP & NDVI & EVI',viewWindowMode: 'explicit'}
  });
print('GPP & NDVI & EVI 时间序列',Yearlychart);

结果:

可见GPP在一定程度上和植被指数有着显著的相关性,其中EVI的变化趋势与GPP变化趋势更相近。

2. 不同指数之间的关系

为了了解不同指数之间的关系,如线性,我在这里使用GPP与EVI进行分析:

javascript 复制代码
// 不同数据源的时间序列分析(GPP,NDVI and EVI)
// 研究区设置
var ROI = ee.FeatureCollection('projects/ee-******736/assets/Sichuan_province')
var styling = {color:"red",fillColor:"00000000"}
Map.centerObject(ROI,5)
Map.addLayer(ROI.style(styling),{},"geometry")

//数据选择Gpp和EVI(EVI与Gpp的时间序列更加契合)
var start = ee.Date.fromYMD(2022, 3, 1);
var end = start.advance(6, 'month');    // 选择生长季
var GPP = ee.ImageCollection('MODIS/006/MOD17A2H') // 空间分辨率为500m
                  .select('Gpp')
                  .filterDate(start, end)
                  .map(function(image){
                    return image.multiply(0.0005).set(image.toDictionary(image.propertyNames()));
					         //此处将GPP扩大了5倍
                  }).mean().rename('GPP')
                  .clip(ROI);
var EVI = ee.ImageCollection("MODIS/006/MOD13Q1")  // 空间分辨率为250m
                  .filterDate(start, end)
                  .select("EVI")
                  .map(function(image){
                    return image.multiply(0.0001).set(image.toDictionary(image.propertyNames()));
                  }).mean().reproject('EPSG:4326',null,500)
                  .clip(ROI);
				  


// 建立EVI与Gpp两个数组,需要保持两个数据的空间分辨率一致,500m即可
var merge = EVI.addBands(GPP).clip(ROI);
var array = merge.reduceRegion({reducer: ee.Reducer.toList(), geometry: ROI, scale: 1000});
var x = ee.List(array.get('GPP')).slice(0, 5000);//注意:此处的切片范围不能超过数据向量本身的范围,否则会报错
var y = ee.List(array.get('EVI')).slice(0, 5000);


// 数据可视化
var chart = ui.Chart.array.values({array: y, axis: 0, xLabels: x}).setOptions({
  title: 'Relationship between the EVI and GPP',
  colors: ['green'],
  hAxis: {
    title: 'GPP(kg*C/m^2)',
    titleTextStyle: {italic: false, bold: true},
    viewWindow: {min: 0, max: 0.3}
  },
  vAxis: {
    title: 'EVI values',
    titleTextStyle: {italic: false, bold: true},
    viewWindow: {min: -0.1, max: 0.7}
  },
  pointSize: 2, //调整点的大小
  legend: {position: 'none'},
});

print('Relationship between the EVI and GPP',chart);

结果:

可以看出GPP与EVI存在着一定的线性相关性。

EVI与地形 (海拔高度) 之间的变化关系:

javascript 复制代码
// 研究区设置
var ROI = ee.FeatureCollection('projects/ee-yipeizhao736/assets/Sichuan_province')
var styling = {color:"red",fillColor:"00000000"}
Map.centerObject(ROI,5)
Map.addLayer(ROI.style(styling),{},"geometry")

//数据选择DEM和EVI
var start = ee.Date.fromYMD(2022, 3, 1);
var end = start.advance(6, 'month');    // 选择生长季
var DEM = ee.ImageCollection('COPERNICUS/DEM/GLO30') // 空间分辨率为30m
                  .select('DEM')
                  .map(function(image){
                    return image.set(image.toDictionary(image.propertyNames()));
                  }).mean().rename('DEM')
                  .clip(ROI);
var EVI = ee.ImageCollection("MODIS/006/MOD13Q1")  // 空间分辨率为250m
                  .filterDate(start, end)
                  .select("EVI")
                  .map(function(image){
                    return image.multiply(0.0001).set(image.toDictionary(image.propertyNames()));
                  }).mean().rename('EVI')
                  .clip(ROI);
				  


var merge = EVI.addBands(DEM).clip(ROI);
var array = merge.reduceRegion({reducer: ee.Reducer.toList(), geometry: ROI, scale: 250}); //
var x = ee.List(array.get('DEM')).slice(0, 5000);
var y = ee.List(array.get('EVI')).slice(0, 5000);


// 数据可视化
var DEM_EVIchart = ui.Chart.array.values({array: y, axis: 0, xLabels: x}).setOptions({
  title: 'Relationship between the EVI and DEM',
  colors: ['green'],
  hAxis: {
    title: 'DEM(m)',
    titleTextStyle: {italic: false, bold: true},
    viewWindow: {min: 2000, max: 5500}
  },
  vAxis: {
    title: 'EVI values',
    titleTextStyle: {italic: false, bold: true},
    viewWindow: {min: -0.1, max: 0.9}
  },
  pointSize: 2, //调整点的大小
  legend: {position: 'none'},
});
print('Relationship between the EVI and DEM', DEM_EVIchart);

结果:

修改数据集,考虑NDVI与海拔之间的关系,结果如下:

可见,随着海拔上升,植被复杂存在着复杂且不均匀的变化,值得注意的是在3250 ~ 3500之间的植被分布较为集中,且包含了各种类型或者密度的植被;植被分布峰值位于3500 ~ 4000m海拔之间;通过这种方法,我们可以了解植被丰富度随海拔的变化情况。

相关推荐
酒尘&5 小时前
JS数组不止Array!索引集合类全面解析
开发语言·前端·javascript·学习·js
用户47949283569157 小时前
"讲讲原型链" —— 面试官最爱问的 JavaScript 基础
前端·javascript·面试
用户47949283569157 小时前
2025 年 TC39 都在忙什么?Import Bytes、Iterator Chunking 来了
前端·javascript·面试
大怪v8 小时前
【Virtual World 04】我们的目标,无限宇宙!!
前端·javascript·代码规范
databook9 小时前
数据会说谎?三大推断方法帮你“审问”数据真相
后端·python·数据分析
蓝瑟11 小时前
告别重复造轮子!业务组件多场景复用实战指南
前端·javascript·设计模式
渴望成为python大神的前端小菜鸟11 小时前
浏览器及其他 面试题
前端·javascript·ajax·面试题·浏览器
1024肥宅12 小时前
手写 new 操作符和 instanceof:深入理解 JavaScript 对象创建与原型链检测
前端·javascript·ecmascript 6
soda_yo12 小时前
浅拷贝与深拷贝: 克隆一只哈基米
前端·javascript·面试
用户66006766853913 小时前
从“养猫”看懂JS面向对象:原型链与Class本质拆解
前端·javascript·面试