利用高分五号02星高光谱数据进行地物识别

2024-03-13 08:12

本文主要是介绍利用高分五号02星高光谱数据进行地物识别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        高分五号02星搭载了一台60公里幅宽、330谱段、30米分辨率的可见短波红外高光谱相机(AHSI),可见近红外(400~1000nm)和短波红外光谱(1000~2500nm)分辨率分别达到5纳米和10纳米。单看参数性能优越,忍不住想试试利用这个数据进行地物识别。

本文介绍利用光谱分析方法从高分五号02星AHSI的反射率影像(可见近红外VN、短波红外SW组合的330个波段影像)上识别一些地物信息,如云层、农作物等地物信息。在ENVI5.6下(ENVI5.3.1及以上版本类似)操作完成,主要包括坏波段标识、端元波谱获取、光谱分析地物识别步骤。

注:可访问 envi.geoscene.cn/envi_license 获取最新ENVI5.6.3软件试用。

1坏波段标识(选做)

        AHSI反射率影像中有一些波段有一些条带噪声(竖条带或者横条带),主要集中在短波红外SW中,如下图所示,这些条带噪声对识别结果有一定影响,得到的结果也可能存在竖条带或者横条带的类别,如果不影响最终应用可忽略。感兴趣的可以尝试用可见近红外VN波段,”坏波段”会更少一些。

图1:部分波段上的条带噪声

可在ENVI中标注为bad bands不参与光谱分析,这些波段目前没有在官方渠道上公布,可通过波谱曲线辨别,如下图所示,有一个波段值非常高鼠标定位到这个点,从左边就可以获取该波段。定位像素点波谱曲线可通过地物识别结果进行定位。

图2:通过像素点波谱曲线定位“坏波段”

(1)显示AHSI反射率影像的图层上右键选择 View metadata,打开Edit metadata。

(2)切换到Spectral选项,在Bad Bands List点击按钮,按住Ctrl选择需要标识Bad bands的波段。这里选择标识202、263、264、271、274、277、269、320、325、326。

(3)点击Ok完成标识。

注:经过FLAASH大气校正的反射率影像上已经自动标识了一些水汽吸收波段为坏波段,这些波段全是0值或者噪声非常大。

图3:标识Bad Bands

2获取端元波谱

端元波谱实际就是需要识别地物的波谱样本,可以通过很多种方式获取,包括标准波谱库、波谱仪实测、影像上获取等。其中影像获取也有多种方式,最简单的方式就是从影像上选择感兴趣区(ROI),获取感兴趣的平均波谱曲线作为端元波谱,本文采用这种方式。

(1)在ENVI中,打开Roi Tool工具,通过目视解译方式绘制需要识别的地物。

(2)通过目视判读,真彩色合成识别和绘制云层、作物1、作物2和作物3 四类需要识别的地物,数量不用太多,需要准确。

注:在绘制云层时候,按住Ctrl+鼠标左键打开魔术棒,使用魔术棒绘制更便捷。

图4:绘制ROI感性兴趣

(3)打开/Classification/Endmember Collection工具,在文件选择对话框中选择AHSI反射率影像。

注:如果影像有背景,可以在此对话框中生成或使用掩膜文件。

(4)在Endmember Collection面板里,选择Import->from ROI/EVF from input file,选择前面选择的感兴趣区。

(5)在Endmember Collection面板里,点击Plot按钮绘制感兴趣的平均波谱曲线。

这里绘制得到的四种地物波谱曲线,三种作物都是未知类型。为了识别三种未知作物类型,一种方法是参照实际调查结果,另外一种方法是用已知的波谱库去识别,采用的工具为/Spectral/Spectral Analyst。这里没有相应的农作物波谱库文件,不对采集的端元波谱做波谱识别。

图5:Endmember Collection面板和平均波谱曲线

3光谱分析地物识别

光谱分析有很多算法,比较常用的是波谱角制图(Spectral Angle Mapper,SAM)。ENVI中可以直接在Endmember Collection中进行SAM分析,也可以打开Classification/Supervised Classification/Spectral Angle Mapper Classification工具。

Endmember Collection中可以预览,还可以分别为每一类单独设置波谱角阈值。本文直接在Endmember Collection中进行SAM地物识别。

(1)接着上一步打开的Endmember Collection面板,选择Algorithm-> Spectral Angle Mapper。

(2)点击Apply,弹出Spectral Angle Mapper参数面板。

  • Set Maximum Angle:设置最大波谱角阈值(0~1.0),以弧度为单位。这里可以统一设置一个阈值,也可以分别为每一类设置阈值。这里阈值越小,识别精度越高。
  • Output Rule Images:是否输出规则文件。规则文件就是生成波谱角为像素值的图像文件,选择输出可以采用密度分割方式进行分类,也可以作为获取阈值的一个参考。

图6:Spectral Angle Mapper参数面板

(3)点击Previw可以预览识别结果,点击OK进行处理。

结果为分类结果文件,可以进行小斑点去除、结果编辑、精度验证、分类转矢量等后续的处理,本文就不进行进一步的介绍。

4 总结

将识别的结果与AHSI反射率影像叠加显示,得益于330多个波段,通过目视判读识别精度还是挺不错的。

图7:SAM识别结果(局部)

原文链接:https://bbs.csdn.net/forums/gisrs?spm=1001.2014.3001.6682

这篇关于利用高分五号02星高光谱数据进行地物识别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java