基于R语言的NDVI的Sen-MK趋势检验

2024-01-19 10:04
文章标签 语言 趋势 检验 mk ndvi sen

本文主要是介绍基于R语言的NDVI的Sen-MK趋势检验,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本实验拟分析艾比湖地区2010年至2020年间的NDVI数据,数据从MODIS遥感影像中提取的NDVI值,在GEE遥感云平台上将影像数据下载下来。代码如下:

import ee
import geemap 
geemap.set_proxy(port=7890)# 设置全局网络代理
Map = geemap.Map()# 指定艾比湖地区数据范围
region = ee.Geometry.BBox(82.433,44.367,84.5,45.267)def get_mean_ndvi(year):y1,y2 = f'{year}-01-01', f'{year+1}-01-01'ndvi_collection = (ee.ImageCollection('MODIS/MCD43A4_006_NDVI') .filterDate(y1,y2) .filterBounds(region))ndvi = ndvi_collection.reduce(ee.Reducer.mean())geemap.ee_export_image_to_drive(ndvi, description=f'ndvi{year}', folder='image',scale=1000,region=region)for y in range(2010,2021):get_mean_ndvi(y)

影像会下载到Google云盘中,通过手动下载到本地,其根目录结构如下:
在这里插入图片描述

图1 根目录结构

下载该10年间的数据后,打开RStdio并导入将趋势检验中将使用的R包。代码如下:

library(sp)
library(raster)
library(rgdal)
library(trend)setwd('E:/CN/NDVI')
fl <- list.files(pattern = '*tif$')
firs <- raster(fl[1])for (i in 1:10) {r <- raster(fl[i])firs <- stack(firs, r)
}fun <- function(y){if(length(na.omit(y)) <10) return(c(NA, NA, NA))   #删除数据不连续含有NA的像元av <- mean(y,na.rm=T)MK_estimate <- sens.slope(ts(na.omit(y), start = 2010, end = 2020, frequency = 1), conf.level = 0.95) #Sen斜率估计slope <- MK_estimate$estimateMK_test <- MK_estimate$p.value
#    Zs <- MK_estimate$statisticreturn(c(av, slope, MK_test))
}e <- calc(firs, fun)   #栅格计算
#e_Zs <- subset(e,1)  #提取Z统计量
e_mean <- subset(e,1) #提取均值图层
e_slope <- subset(e,2)   #提取sen斜率
e_MKtest <- subset(e,3)   #提取p值plot(e_mean)
plot(e_slope)
plot(e_MKtest)writeRaster(e_mean, "E:/CN/NDVI/e_Zs.tif", format="GTiff", overwrite=T)
writeRaster(e_slope, "E:/CN/NDVI/e_slope.tif", format="GTiff", overwrite=T)
writeRaster(e_MKtest, "E:/CN/NDVI/e_MKtest.tif", format="GTiff", overwrite=T)

在这里插入图片描述

图2 2010-2020年间艾比湖地区NDVI均值图层

在这里插入图片描述

图3 R语言运行界面
在这里插入图片描述

图4 p值
在这里插入图片描述

图5 sen斜率
在这里插入图片描述

图6 Z统计量

R语言计算完slope和Z值后,根据这两个结果就可以进行NDVI趋势制图了。

一、变化趋势划分
结合SNDVI和Z统计量划分NDVI变化趋势:
1、slope
-0.0005~0.0005稳定区域
大于或等于0.0005植被改善区域
小于-0.0005为植被退化区域
2、Z统计量

二、Slope划分
置信水平0.05
Z绝对值大于1.96显著
Z绝对值小于等于1.96不显著
Slope被划分为三级:
SNDVI≤−0.0005 植被退化
−0.0005≥SNDVI≥0.0005 植被生长稳定
SNDVI≥0.0005 植被改善
使用重分类(Reclassify)对slope进行划分
由于slope.tif文件研究区范围外的值非空,所以在这里先裁剪了一下
裁剪所用矢量和栅格数据坐标系需要一致,否则范围容易出错
统一使用了WGS84地理坐标系作为空间参考
使用Model builder构建地理处理流
在这里插入图片描述

图7 重分类

三、Slope划分过程
重分类结果:
-1退化
0稳定
1改善
在这里插入图片描述

图8 重分类结果

四、Z值划分
对Z值进行重分类,确定显著性
|Zs|≤0.196 未通过95%置信度检验,不显著
|Zs|≥0.196 通过95%置信度检验,显著
在这里插入图片描述

图9 重分类
五、Z值重分类
重分类结果:
1不显著
2显著
在这里插入图片描述

图10 重分类结果

六、变化趋势计算
使用栅格计算器将Slope和Z值计算结果相乘,最后得到趋势变化划分
-2严重退化
-1轻微退化
0稳定不变
1轻微改善
2明显改善
在这里插入图片描述

图11 栅格计算器相乘
在这里插入图片描述

图12 arcgis计算NDVI趋势图

这篇关于基于R语言的NDVI的Sen-MK趋势检验的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.