GEE:变化检测算法,干扰检测,LandTrendr代码与说明(变化年份和扰动幅度示例)

本文主要是介绍GEE:变化检测算法,干扰检测,LandTrendr代码与说明(变化年份和扰动幅度示例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LandTrendr是什么?

LandTrendr是一组频谱时间分割算法,可用于中等分辨率卫星图像(主要是Landsat)的时间序列中的变化检测以及生成很大程度上不存在年际信号噪声的基于轨迹的频谱时间序列数据。LT最初是用IDL(交互式数据语言)实现的,但是在Google工程师的帮助下,它已移植到GEE平台。


LandTrendr官方说明网站:

https://emapr.github.io/LT-GEE/index.html
该网站介绍了在Google Earth Engine(GEE)中运行LandTrendr(LT)的基础知识。
它描述了LT概念框架,运行LT-GEE所需的内容,如何运行它,输出是什么以及如何格式化它们。它还提供了三个示例脚本,用于LT操作的一系列用户界面以及一个有目的但易于使用的API。
GEE框架几乎消除了IDL实施中繁琐的数据管理和图像预处理方面。它比IDL实施要快几光年,后者的计算时间以分钟而不是天为单位。(GEE谷歌云平台动用全球的服务器运算)


以下介绍动用API,运行LandTrendr的代码。输出结果为最大的扰动发生的幅度和年份。
完整代码:https://code.earthengine.google.com/65d284842e453de5731810be16bfccf3?noload=true
扰动幅度结果如下图所示,(不同颜色代表扰动强度不同)
在这里插入图片描述
扰动发生的年份,结果如下图所示:(不同颜色代表扰动发生的不同年份)
在这里插入图片描述

// 定义影像集参数
var startYear = 1984;
var endYear = 2019;
var startDay = '06-20';
var endDay = '09-01';
//var aoi = ee.Geometry.Point(-122.8848, 43.7929);
var index = 'NBR';
var maskThese = ['cloud', 'shadow', 'snow', 'water'];// 定义landtrendr参数
var runParams = { maxSegments:            6,spikeThreshold:         0.9,vertexCountOvershoot:   3,preventOneYearRecovery: true,recoveryThreshold:      0.25,pvalThreshold:          0.05,bestModelProportion:    0.75,minObservationsNeeded:  6
};// 定义变化参数
var changeParams = {delta:  'loss',sort:   'greatest',year:   {checked:true, start:1986, end:2019},mag:    {checked:true, value:200,  operator:'>'},dur:    {checked:true, value:4,    operator:'<'},preval: {checked:true, value:300,  operator:'>'},mmu:    {checked:true, value:11},};//各项参数设置好了,就可以开始运行LandTrendr了!// 加载API
var ltgee = require('users/emaprlab/public:Modules/LandTrendr.js'); // add index to changeParams object
changeParams.index = index;// 运行landtrendr
var lt = ltgee.runLT(startYear, endYear, startDay, endDay, aoi, index, [], runParams, maskThese);// 得到 change map layers
var changeImg = ltgee.getChangeMap(lt, changeParams);// 可视化字典
var palette = ['#9400D3', '#4B0082', '#0000FF', '#00FF00', '#FFFF00', '#FF7F00', '#FF0000'];
var yodVizParms = {min: startYear,max: endYear,palette: palette
};// 可视化参数
var magVizParms = {min: 200,max: 800,palette: palette
};// 将扰动图可视化
Map.centerObject(aoi, 11);
Map.addLayer(changeImg.select(['mag']), magVizParms, 'Magnitude of Change');
Map.addLayer(changeImg.select(['yod']), yodVizParms, 'Year of Detection');//设置显示样式:color代表边界颜色;fillcolor代表填充颜色
var styling={color:'red',fillColor:'00000000'}
//JX就是矢量边界
Map.addLayer(aoi.style(styling),{},"JX")// 将结果下载到谷歌云盘var exportImg = changeImg.clip(aoi).unmask(0).short();
Export.image.toDrive({image: exportImg, description: 'lt-gee_disturbance_map', folder: 'lt-gee_disturbance_map_test', fileNamePrefix: 'lt-gee_disturbance_map', region: aoi, scale: 30, crs: 'EPSG:5070', maxPixels: 1e13
});

这篇关于GEE:变化检测算法,干扰检测,LandTrendr代码与说明(变化年份和扰动幅度示例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428314

相关文章

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Before和BeforeClass的区别及说明

《Before和BeforeClass的区别及说明》:本文主要介绍Before和BeforeClass的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Before和BeforeClass的区别一个简单的例子当运行这个测试类时总结Before和Befor

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma