盐分反演关键:批量计算常用的盐分指数反演变量

news2024/11/28 17:56:01

盐分反演关键:批量计算常用的盐分指数反演变量

一、引言

盐分指数反演是遥感应用中的一个重要方面,尤其在农业和环境监测中有着广泛的应用。通过遥感影像,研究人员可以高效地获取和分析地表盐分信息,为土地管理和作物生产提供重要支持。本文将介绍如何利用哨兵2号影像批量计算常用的盐分指数反演变量。

二、哨兵2号影像简介

哨兵2号(Sentinel-2)卫星是欧空局(ESA)哨兵计划中的一部分,主要用于地表监测。其多光谱仪(MSI)包含13个波段,覆盖可见光、近红外和短波红外波段,分辨率从10米到60米不等。这些波段为计算各种植被和盐分指数提供了丰富的数据源。

Sentinel-2 BandsCentral Wavelength (µm)Resolution (m)
Band 1 - Coastal aerosol0.44360
Band 2 - Blue0.49010
Band 3 - Green0.56010
Band 4 - Red0.66510
Band 5 - Vegetation Red Edge0.70520
Band 6 - Vegetation Red Edge0.74020
Band 7 - Vegetation Red Edge0.78320
Band 8 - NIR0.84210
Band 8A - Vegetation Red Edge0.86520
Band 9 - Water vapour0.94560
Band 10 - SWIR - Cirrus1.37560
Band 11 - SWIR1.61020
Band 12 - SWIR2.19020

三、常用盐分指数

盐分指数(Salinity Index,SI)是一种通过遥感数据定量描述地表盐分状况的指标。以下是几种常用的盐分指数公式和盐分反演需要用到的植被指数公式:

盐分指数
特征参数变量名称公式及描述
盐分指数 (SI_T)salinity index, SI_T ( R e d − N I R ) × 100 (Red - NIR) \times 100 (RedNIR)×100
盐分指数 (SI1)salinity index, SI1 G r e e n × R e d \sqrt{Green \times Red} Green×Red
盐分指数 (SI2)salinity index, SI2 G r e e n 2 + R e d 2 + N I R 2 \sqrt{Green^2 + Red^2 + NIR^2} Green2+Red2+NIR2
盐分指数 (SI3)salinity index, SI3 G r e e n 2 + R e d 2 \sqrt{Green^2 + Red^2} Green2+Red2
盐分指数 (SI4)salinity index, SI4 B l u e × R e d G r e e n \frac{Blue \times Red}{Green} GreenBlue×Red
盐分指数 (SI5)salinity index, SI5 G r e e n + R e d 2 \frac{Green + Red}{2} 2Green+Red
盐分指数 (S1)salinity index, S1 B l u e R e d \frac{Blue}{Red} RedBlue
盐分指数 (S2)salinity index, S2 B l u e − R e d B l u e + R e d \frac{Blue - Red}{Blue + Red} Blue+RedBlueRed
盐分指数 (S3)salinity index, S3 G r e e n × R e d B l u e \frac{Green \times Red}{Blue} BlueGreen×Red
盐分指数 (SAIO)salinity index, SAIO R e d − N I R G r e e n + N I R \frac{Red - NIR}{Green + NIR} Green+NIRRedNIR
复合盐分指数 (CRSI)composite salinity index, CRSI ( N I R − R e d ) × ( 1 + L ) N I R + R e d + L ; L = 0.5 \frac{(NIR - Red) \times (1 + L)}{NIR + Red + L}; L = 0.5 NIR+Red+L(NIRRed)×(1+L);L=0.5
植被指数
特征参数变量名称公式及描述
土壤调整植被指数 (SAVI)soil-adjusted vegetation index, SAVI ( N I R − R ) × 1.5 N I R + R + 0.5 \frac{(NIR - R) \times 1.5}{NIR + R + 0.5} NIR+R+0.5(NIRR)×1.5
归一化植被指数 (NDVI)normalized vegetation index, NDVI N I R − R N I R + R \frac{NIR - R}{NIR + R} NIR+RNIRR
重整化差异植被指数 (RDVI)renormalize differential vegetation index, RDVI N I R − R N I R + R \frac{\sqrt{NIR - R}}{NIR + R} NIR+RNIRR
绿色归一化差异植被指数 (GNDVI)green normalized differential vegetation index, GNDVI N I R − G N I R + G \frac{NIR - G}{NIR + G} NIR+GNIRG
三角植被指数 (TVI)triangular vegetation index, TVI N I R − R N I R + R + 0.5 \frac{NIR - R}{NIR + R + 0.5} NIR+R+0.5NIRR
差值植被指数 (DVI)differential vegetation index, DVI N I R − R NIR - R NIRR
归一化差异绿色指数 (NDGI)normalized difference green index, NDGI G − R G + R \frac{G - R}{G + R} G+RGR
增强归一化植被指数 (ENDVI)enhanced normalized vegetation index, ENDVI N I R + S W I R 2 − R N I R + S W I R 2 + R \frac{NIR + SWIR_2 - R}{NIR + SWIR_2 + R} NIR+SWIR2+RNIR+SWIR2R

四、GDAL简介

GDAL(Geospatial Data Abstraction Library)是一个用于处理栅格数据和矢量数据的开源库,是地理信息系统(GIS)和遥感领域的重要工具之一。GDAL的详细介绍及其安装可以查看这篇文章:GDAL介绍及安装。

五、 批量计算植被指数

1.指数命令

使用 gdal_calc.py 工具可以批量计算上述表格中各盐分指数和植被指数。以下是计算这些植被指数的命令示例:

python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 --outfile=savi.tif --calc="((A-B) * 1.5) / (A+B+0.5)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 --outfile=ndvi.tif --calc="(A-B) / (A+B)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 --outfile=rdvi.tif --calc="sqrt(A-B) / (A+B)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=3 --outfile=gndvi.tif --calc="(A-B) / (A+B)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 --outfile=tvi.tif --calc="(A-B) / (A+B+0.5)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 --outfile=dvi.tif --calc="A-B"
python gdal_calc.py -A S2.tif --A_band=3 -B S2.tif --B_band=4 --outfile=ndgi.tif --calc="(A-B) / (A+B)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 -C S2.tif --C_band=12 --outfile=endvi.tif --calc="(A+C-B)/(A+C+B)"
python gdal_calc.py -A S2.tif --A_band=4 -B S2.tif --B_band=8 --outfile=si_t.tif --calc="(A-B) * 100"
python gdal_calc.py -A S2.tif --A_band=3 -B S2.tif --B_band=4 --outfile=si1.tif --calc="sqrt(A*B)"
python gdal_calc.py -A S2.tif --A_band=3 -B S2.tif --B_band=4 -C S2.tif --C_band=8 --outfile=si2.tif --calc="sqrt(A**2 + B**2 + C**2)"
python gdal_calc.py -A S2.tif --A_band=3 -B S2.tif --B_band=4 --outfile=si3.tif --calc="sqrt(A**2 + B**2)"
python gdal_calc.py -A S2.tif --A_band=2 -B S2.tif --B_band=4 -C S2.tif --C_band=3 --outfile=si4.tif --calc="(A*B)/C"
python gdal_calc.py -A S2.tif --A_band=3 -B S2.tif --B_band=4 --outfile=si5.tif --calc="(A+B)/2"
python gdal_calc.py -A S2.tif --A_band=2 -B S2.tif --B_band=4 --outfile=s1.tif --calc="A/B"
python gdal_calc.py -A S2.tif --A_band=2 -B S2.tif --B_band=4 --outfile=s2.tif --calc="(A-B)/(A+B)"
python gdal_calc.py -A S2.tif --A_band=3 -B S2.tif --B_band=4 -C S2.tif --C_band=2 --outfile=s3.tif --calc="(A*B)/C"
python gdal_calc.py -A S2.tif --A_band=4 -B S2.tif --B_band=8 -C S2.tif --C_band=3 --outfile=saio.tif --calc="(A-B)/(C+B)"
python gdal_calc.py -A S2.tif --A_band=8 -B S2.tif --B_band=4 --outfile=crsi.tif --calc="(A-B)*(1+0.5)/(A+B+0.5)"

这些命令使用 gdal_calc.py 工具来计算表格中的各个植被指数,其中 A_bandB_bandC_band 分别对应 哨兵2号 的不同波段。请根据实际数据文件调整命令中的文件名和波段编号。

2.批处理脚本自动计算

手动运行每条命令会非常麻烦,因此可以将这些命令写入一个批处理文件(.bat),实现自动计算。

3.创建批处理文件

  1. 打开记事本,将上述命令内容复制进去。

  2. 保存文件,将文件名命名为run.bat

  3. 将gdal_calc.py文件和遥感影像文件放入同一文件夹下。

    gdal.py/ run.bat/ run.txt文件已经上传到百度网盘,需要可搜索关注作者微信公众号:Python与遥感 获取
    在这里插入图片描述

4.运行批处理文件

  1. 打开Anaconda Prompt。
  2. 输入以下命令进入相应的驱动器和目录:
    F:
    cd path\to\your\folder
    
  3. 输入并运行批处理文件:
    run.bat
    

运行后,批处理文件将自动依次执行每个命令,计算所有植被指数和盐分指数,并将结果保存到相应的文件中。

注:这里的图示范,采用的是上一篇文章代替的,能看懂就行。

5. 结果展示

每条命令运行后,对应的植被指数会保存在文件夹中,黑窗里的数字到99就代表计算完了一个植被指数。只需等待一小会儿,即可计算完所有的植被指数计算。

六、 总结

盐分指数反演在农业和环境监测中具有重要意义。利用哨兵2号影像和GDAL工具,研究人员可以批量计算常用的盐分指数,获取详细的地表盐分信息。这不仅提高了工作效率,还为科学研究和实际应用提供了强有力的支持。

欢迎关注我的公众号:python与遥感,或许里面有你想要的免费教程。
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YOLOX+PyQt5交通路口智能监测平台设计与实现

1.概述 交通要道的路口上人车穿行,特别是上下班早高峰,且时常发生交通事故。因此对交通路口的车流量和人流量的监测必不可少。 2.检测模型 使用的检测模型为YOLOX模型,模型权重为训练VOC数据集得来,其中包括了二十个类别&#…

ONLYOFFICE 协作空间 2.6 已发布:表单填写房间、LDAP、优化房间和文件管理等

更新后的 ONLYOFFICE 协作空间带来了超过 20 项新功能和优化,让工作更加高效和舒适。阅读本文了解详情。 表单填写房间 这次更新增加了一种新的房间类型,可在 ONLYOFFICE 协作空间中组织简单的表单填写流程。 通过表单填写房间,目前可以完成…

仓库物品与装备物品位置更换

一、装备物品与选中的仓库物品位置交换 1、准备工作 2、Inventory Items 3、给Warehouse添加Grid Layout Group组件 4、复制Inventory Items,设置Grid Layout Group组件 5、创建文本ItemName和ItemDescription 6、设置物品数据 (1) 创建 ItemData.cs using Syst…

Spring boot tomcat 读写超时时间设置

yaml配置 connection-timeout: 20000 server:port: 9898servlet:context-path: /testtomcat:connection-timeout: 20000max-connections: 250accept-count: 300 spring源码设置自定义tomcat参数 customizeConnector(connector); Overridepublic WebServer getWebServer(Serv…

【MySQL】表的约束{ 常见约束 空属性 默认值 列描述comment zerofill 主键 复合主键 自增长 唯一键 外键 }

文章目录 常见约束空属性默认值列描述commentzerofill主键复合主键自增长唯一键外键 2.总结 真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比…

MySQL基础练习题12-使用唯一标识码替换员工ID

题目:展示每位用户的 唯一标识码(unique ID );如果某位员工没有唯一标识码,使用 null 填充即可。 准备数据 分析数据 题目:展示每位用户的 唯一标识码(unique ID );如果…

一, 创建工程,引入依赖

一, 创建工程,引入依赖 文章目录 一, 创建工程,引入依赖创建工程工程间的关系的建立配置各个工程当中的 pow 配置信息,相关的依赖父工程(也就是总项目工程)的 pow 配置demo-module06-generate 模块中pow 配置&#xff…

基于IEC61499标准的在线工业编程平台open61499

基于IEC61499标准的在线工业编程平台open61499是一个专为工业自动化领域设计的编程环境,它遵循IEC 61499标准,为开发者提供了一种高效、灵活的方式来创建、配置和管理分布式控制系统(DCS)的应用程序。以下是对open61499的详细解析…

LeetCode热题 翻转二叉树、二叉树最大深度、二叉树中序遍历

目录 一、翻转二叉树 1.1 题目链接 1.2 题目描述 1.3 解题思路 二、二叉树最大深度 2.1 题目链接 2.2 题目描述 2.3 解题思路 三、二叉树中序遍历 3.1 题目链接 3.2 题目描述 3.3 解题思路 一、翻转二叉树 1.1 题目链接 翻转二叉树 1.2 题目描述 1.3 解题思路 根…

【多模态大模型】 BLIP in ICML 2022

一、引言 论文: BLIP: Bootstrapping Language-Image Pre-training for Unified Vision-Language Understanding and Generation 作者: Salesforce Research 代码: BLIP 特点: 该方法分别使用ViT和BERT进行图像和文本特征提取&am…

【changchain-community安装失败】‘EntryPoints‘ object has no attribute ‘get‘报错解决

在安装changchain-community时报错信息如下: WARNING: Keyring is skipped due to an exception: EntryPoints object has no attribute get ERROR: Could not find a version that satisfies the requirement changchain-community ERROR: No matching distributio…

进程间通信与线程间通信的方法汇总

目录 一、进程间通信机制 管道(pipe): 命名管道(FIFO): 消息队列(MQ): 信号量(semaphore): 共享内存(shared memory): 信号(signal): 内存映射(mapped memory): 内存映射和共享内存的区…

华杉研发九学习日记20 LinkedHashMap TreeMap Arrays 函数式接口 方法引用

华杉研发九学习日记20 一&#xff0c;LinkedHashMap 与HashMap相比&#xff0c;key是有序的 Map<Integer,String> map new LinkedHashMap<Integer,String>(); map.put(1, "one"); map.put(2, "two"); map.put(3, "three"); map.…

GitHub Desktop commit文件到repository

1. Clone a repository到本地 2. 在本地仓库修改/添加需要提交的文件或者文档 3. 添加comments并commit 4. 提交完成&#xff0c;点击Push origin提交代码到Github远程仓库 上传成功后&#xff0c;刷新Github网站页面就会出现上传的项目

鸿蒙应用框架开发【自绘编辑框】 输入法框架

自绘编辑框 介绍 本示例通过输入法框架实现自会编辑框&#xff0c;可以绑定输入法应用&#xff0c;从输入法应用输入内容&#xff0c;显示和隐藏输入法。 效果预览 使用说明 1.点击编辑框可以绑定并拉起输入法&#xff0c;可以从输入法键盘输入内容到编辑框。 2.可以点击a…

SSM老人服务管理系统小程序-计算机毕业设计源码91022

摘 要 21世纪的今天&#xff0c;随着社会的不断发展与进步&#xff0c;人们对于信息科学化的认识&#xff0c;已由低层次向高层次发展&#xff0c;由原来的感性认识向理性认识提高&#xff0c;管理工作的重要性已逐渐被人们所认识&#xff0c;科学化的管理&#xff0c;使信息存…

跨网段 IP 地址通信故障分析

现如今计算机网络的规模和复杂性不断增加&#xff0c;跨网段通信成为网络运行中的常见需求。但如果设备处于不同网段且路由设置出现偏差时就会导致通信故障&#xff0c;严重影响网络的正常运行和数据传输。 1.跨网段通信的基本原理 跨网段通信依赖于路由器的路由功能。路由器根…

vue3.0 入门基础知识汇总【1】 全面 精简 推荐

这篇博文主要对一些刚入门vue框架的同学&#xff0c;以及对vue基本知识进行巩固的&#xff0c;最后就是精简一下基本知识&#xff0c;以方便自己查看&#xff0c;感谢参考&#xff0c;有问题评论区交流&#xff0c;谢谢。 目录 1.component组件的基本结构和使用 2.method方法…

全网最适合入门的面向对象编程教程:28 类和对象的Python实现-Python编程原则、哲学和规范大汇总

全网最适合入门的面向对象编程教程&#xff1a;28 类和对象的 Python 实现-Python 编程原则、哲学和规范大汇总 摘要&#xff1a; 本文主要介绍了在使用 Python 进行面向对象编程时&#xff0c;Python 异常处理的原则-“请求谅解&#xff0c;而非许可”&#xff0c;以及软件设…

什么是安全编程?

安全编程&#xff08;Secure Programming&#xff09;是一种编程方法论&#xff0c;旨在通过编写安全可靠的代码来保护计算机系统和数据的安全性。它涵盖了软件设计、开发、测试和维护的整个生命周期&#xff0c;旨在最大程度地降低软件漏洞和安全缺陷的风险。以下是对安全编程…