GEE代码实例教程详解:长时间序列NDVI分析

简介

本篇博客将介绍如何使用Google Earth Engine (GEE) 对长时间序列的Landsat数据进行归一化植被指数(NDVI)分析。通过此分析,可以监测和评估1982年至2024年间的植被变化趋势。

背景知识

Landsat数据集

Landsat是美国地质调查局和美国航天局联合发射的一系列卫星,提供地表的长时间序列、中等分辨率的遥感数据。

NDVI

归一化植被指数(NDVI)是一种常用的遥感指数,用于估算植被覆盖度和植被健康状态。

完整代码

// 定义研究区域的坐标点
var cor = [
  [48.62559911358055, 31.65418476680761],
  [48.91124364483055, 31.65418476680761],
  [48.91124364483055, 31.885355756064595],
  [48.62559911358055, 31.885355756064595],
  [48.62559911358055, 31.65418476680761]
];

// 创建多边形区域
var roi = ee.Geometry.Polygon(cor);

// 将地图中心设置为研究区域
Map.centerObject(roi);

// 定义NDVI计算函数
function ndvi_tm_etm(img) {
  var bands = img.multiply(0.0000275).add(-0.2);
  var ndvi = bands.normalizedDifference(['SR_B4', 'SR_B3']).rename('ndvi');
  return ndvi.copyProperties(img, img.propertyNames());
}

// 定义SLC偏移修正函数
function slc_off(img) {
  var bands = img.multiply(0.0000275).add(-0.2);
  var ndvi = bands.normalizedDifference(['SR_B4', 'SR_B3']).rename('ndvi');
  var filter = ndvi.focalMedian(1, 'square', 'pixels', 10);
  var filled = filter.blend(ndvi).rename('ndvi');
  return filled.copyProperties(img, img.propertyNames());
}

// 定义OLI传感器NDVI计算函数
function ndvi_oli(img) {
  var bands = img.multiply(0.0000275).add(-0.2);
  var ndvi = bands.normalizedDifference(['SR_B5', 'SR_B4']).rename('ndvi');
  return ndvi.copyProperties(img, img.propertyNames());
}

// 筛选Landsat 4-9数据集并计算NDVI
var landsat4 = ee.ImageCollection("LANDSAT/LT04/C02/T1_L2")
  .select('SR_B.*')
  .filterDate('1982', '1994')
  // ... 其他筛选条件 ...
  .map(ndvi_tm_etm);

var landsat5 = ee.ImageCollection("LANDSAT/LT05/C02/T1_L2")
  .select('SR_B.*')
  .filterDate('1984', '2013')
  // ... 其他筛选条件 ...
  .map(ndvi_tm_etm);

// ... Landsat 7 SLC正常和偏移后的数据 ...

var landsat8 = ee.ImageCollection("LANDSAT/LC08/C02/T1_L2")
  .select('SR_B.*')
  .filterDate('2013', '2024')
  // ... 其他筛选条件 ...
  .map(ndvi_oli);

var landsat9 = ee.ImageCollection("LANDSAT/LC09/C02/T1_L2")
  .select('SR_B.*')
  .filterDate('2021', '2024')
  // ... 其他筛选条件 ...
  .map(ndvi_oli);

// 合并所有Landsat数据集并排序
var landsat_collections = landsat4.merge(landsat5)
  .merge(landsat7_slcon).merge(landsat7_slcoff).merge(landsat8).merge(landsat9)
  .sort('system:time_start');

// 打印NDVI时间序列图表
print(
  ui.Chart.image.series({
    imageCollection: landsat_collections,
    region: roi,
    reducer: ee.Reducer.mean(),
    scale: 100,
    xProperty: 'system:time_start'
  })
);

// 导出2010年的NDVI图像到Google Drive
Export.image.toDrive({
  image: landsat_collections.filterDate('2010', '2011').toBands().clip(roi).float(),
  description: 'landsat2010',
  scale: 30,
  crs: 'EPSG:4326',
  maxPixels: 1e13,
  region: roi,
  folder: 'test'
});

代码详解

1. 定义研究区域

创建一个多边形区域roi,用于限定分析的地理范围,并设置地图中心。

2. 定义NDVI计算函数

定义ndvi_tm_etm函数,用于计算Landsat 4-5和7(SLC正常)的NDVI。

3. 定义SLC偏移修正函数

定义slc_off函数,用于处理Landsat 7 SLC偏移后的数据。

4. 定义OLI传感器NDVI计算函数

定义ndvi_oli函数,用于计算Landsat 8-9的NDVI。

5. 筛选和处理Landsat数据集

分别筛选Landsat 4-9的数据集,应用相应的NDVI计算函数,并处理SLC偏移问题。

6. 合并和排序数据集

将所有处理过的Landsat数据集合并,并按时间排序。

7. 可视化NDVI时间序列

使用ui.Chart.image.series打印NDVI时间序列图表。

8. 导出数据

将2010年的NDVI图像导出到Google Drive。

结论

本教程展示了如何使用GEE对长时间序列的Landsat数据进行NDVI分析。通过此分析,可以监测植被覆盖度的变化,为生态研究和环境监测提供支持。

进一步探索

GEE提供了多种工具和方法来进行时间序列分析和环境监测。在后续的教程中,我们将继续探索GEE在不同领域的应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/784559.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Java14】构造器

Java中的构造器在创建对象(实例)的时候执行初始化。Java类必须包含一个或一个以上的构造器。 Java中的构造器类似C中的构造函数。 Java中对象(object)的默认初始化规则是: 数值型变量初始化为0;布尔型变量…

为什么KV Cache只需缓存K矩阵和V矩阵,无需缓存Q矩阵?

大家都知道大模型是通过语言序列预测下一个词的概率。假定{ x 1 x_1 x1​, x 2 x_2 x2​, x 3 x_3 x3​,…, x n − 1 x_{n-1} xn−1​}为已知序列,其中 x 1 x_1 x1​, x 2 x_2 x2​, x 3 x_3 x…

EAI四个层次服务-系统架构师(二十六)

1、(重点)系统应用集成提供了4个不同层次服务,最上层服务是()服务。 解析: EAI(Enterprise Application Integration)系统应用集成,相关概念。 实施EAI必须保证:应用程…

2024年信息素养大赛图形化编程小低组复赛真题-附答案 6547网

2024年全国青少年信息素养大赛图形化编程小低组复赛真题 题目总数:6 总分数:100 第1部分 第 1 题 问答题 【编程实现】点击小绿旗,实现将鱼的所有造型印到舞台区 【具体要求】 1. 将鱼显示出来 全部擦除所有内容 2. 将鱼的造型设…

202488读书笔记|《365日创意文案》——无聊的 到底是这世间, 还是自己?懂得忘却的人才能前进

202488读书笔记|《365日创意文案》——无聊的 到底是这世间, 还是自己?懂得忘却的人才能前进 1月2月3月4月5月6月7月8月9月10月11月12月 《365日创意文案》WRITES PUBLISHING,一些日常,是烟火,也是幸福的印记。 当下也…

二次元转向SLG,B站游戏的破圈之困

文 | 螳螂观察 作者 | 夏至 2023年是B站游戏的滑铁卢,尽管这年B站的游戏营收还有40多亿,但相比去年大幅下降了20%,整整少了10亿,这是过去5年来的最大跌幅,也是陈睿接管B站游戏业务一年以来,在鼻子上碰的第…

超详细版阿里云控制台环境配置+数据库配置

一、登录阿里云控制台 登录阿里云控制台,找到实例,切到阿里云服务器所在地址 🍭不知道自己的服务器地址在哪边也没有关系,随便选择一个,查询不到记录的话会有以下提示,可以根据提示进行切换(适…

基于docker的prometheus+grafana+altermanager+prometheus-webhook-dingtalk钉钉报警

一、各软件功能简介 prometheus:Prometheus(是由go语言(golang)开发)是一套开源的监控&报警&时间序列数 据库的组合。主要优点:外部依赖安装使用超简单、系统集成 多等 grafana:Grafana 是一款采用 go 语言编写的开源应用&#xff0…

APP明暗主题设置

1.preference.xml 增加一个暗色主题 SwitchPreference 2.每个 Activity 的 setContentView 前面增加 setTheme SharedPreferences sharedPreferences PreferenceManager.getDefaultSharedPreferences(this); if (sharedPreferences.getBoolean("switch_dark_theme"…

uniapp-小程序获取用户位置

1. 需要在微信公众平台进行接口的申请。选择自己需要用的接口。 2. 在app.json文件中配置permission和requiredPrivateInfos。requiredPrivateInfos里面是你需要使用的接口。 3. 配置完成后,就可以使用了。 相关获取位置API的链接 4. 如果要获取当前位置到某一个指…

电商数据仓库

目录 1.数据仓库的数据来源为业务数据库(mysql) 初始化脚本 2.通过sqoop将mysql中的业务数据导入到大数据平台(hive) 在hive中建立映射的数据库 导入数据 3.通过hive进行数据计算和数据分析 形成数据报表 补全用户信息表中的…

DNS知识点

📑打牌 : da pai ge的个人主页 🌤️个人专栏 : da pai ge的博客专栏 ☁️宝剑锋从磨砺出,梅花香自苦寒来 ​ 目录 一、DNS概念 二hosts 文件 DNS优缺点 三客户端域名解析顺序(优先级) 四原…

数据结构--堆,堆排序

1.树概念及结构 1.1树的概念 树是一种 非线性 的数据结构,它是由 n ( n>0 )个有限结点组成一个具有层次关系的集合。 把它叫做树是因 为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的 。 有一个 特殊的结…

PCIe 入门 Demo(一):基础知识

PCIe 入门 Demo(一):基础知识 主要参考 up主 芯片人阿伟 的教程【针对 RISC-V 架构】 视频介绍:https://www.bilibili.com/video/BV1Xm4y1V757 源码仓库:https://github.com/oldawei/show_me_the_code 本文主要补充一些…

STM32对数码管显示的控制

1、在项目开发过程中会遇到STM32控制的数码管显示应用,这里以四位共阴极数码管显示控制为例讲解;这里采用的控制芯片为STM32F103RCT6。 2、首先要确定数码管的段选的8个引脚连接的单片机的引脚是哪8个,然后确认位选的4个引脚连接的单片机的4…

OS Copilot测评-CSDN

登录控制台 安装插件 sudo yum install -y os-copilot效果如下 配置 AccessKey ID 与 AccessKey Secret 注意安全,使用完成后,别忘了去控制台删除,一般情况使用子Key就可以 检测是否可用 co hi实际操作(当前为官方案例请求) 实操1&…

电脑找回彻底删除文件?四个实测效果的方法【一键找回】

电脑数据删除了还能恢复吗?可以的,只要我们及时撤销上一步删除操作,还是有几率找回彻底删除文件。 当我们的电脑文件被彻底删除后,尽管恢复的成功率可能受到多种因素的影响,但仍有几种方法可以尝试找回这些文件。本文整…

c向c++的过渡

目录 1.不同版本的hello word! 2.namespace和::域作用限定符以及using 2.1 namespace 2.2:: 2.3using用于展开域 3.C输入和输出 4.缺省参数 5.重载 6.引用 1.不同版本的hello word! 还记得第一次写C语…

手写简单模拟mvc

目录结构: 两个注解类: Controller: package com.heaboy.annotation;import java.lang.annotation.*;/*** 注解没有功能只是简单标记* .RUNTIME 运行时还能看到* .CLASS 类里面还有,构建对象久没来了,这个说明…

Java信号量semaphore的原理与使用方法

Semaphore的基本概念 在Java中,Semaphore是位于java.util.concurrent包下的一个类。它的核心就是维护了一个许可集。简单来说,就是有一定数量的许可,线程需要先获取到许可,才能执行,执行完毕后再释放许可。 那么&…