ENVI下高分一号PMS相机多光谱数据大气校正
分享
高分一号 PMS相机的多光谱数据拥有很好的空间分辨率(8米)和幅宽(60km),包括蓝、绿、红、近红外4个波段。本文介绍利用ENVI FLAASH工具完成高分一号PMS多光谱图像的大气校正,主要分为以下三步:
注:本文是在ENVI5.0下和ENVI classic完成,其他版本基本类似。
1 数据定标
利用以下公式可将GF-1卫星各载荷的通道观测值计数值DN转换为卫星载荷入瞳处等效表观辐亮度数据。
式中:Gain为定标斜率;DN 为卫星载荷观测值; Bias为定标截距。
定标参数参照表1,来源于中国资源卫星应用中心:http://www.cresda.com/site1/Do ... shtml
表1 高分一号星PMS相机的定标系数
进行数据定标计算时候,我们可以有两种方法选择使用:
一、Bandmath
以下是利用Bandmath工具进行定标,这种方法灵活,不过需要一个一个波段定标。
1) 有了绝对定标参数和定标公式,选择Toolbox/Band Ratio/Band Math工具很容易进行传感器定标。
2) 由于是单个波段文件的定标,选择Toolbox/Raster Management/Layer Stacking将定标后的单波段文件组合成一个多波段文件。
二、Apply Gain and Offset工具
我们可以使用Apply Gain and Offset工具。。
1) 启动Toolbox/Radiometric Correction/Apply Gain and Offset。
2) 在Gain and Offset Values中填入 增益Gain值和偏移Offset。
3) 选择输出路径和文件名执行定标。
图1 Gain and Offset Values面板
计算好之后,继续执行以下步骤(原数据的储存顺序是BIP):
(1) 选择Toolbox/Raster Management/ Edit ENVI Header ->Edit Attributes->Wavelength,将每个波段的中心波长输入——b1(503nm),b2(576nm),b3(680nm) ,b4(810nm)
讨论:由于没有找到官方公布的中心波长信息,这里取与波谱响应中反射率为1的波长。
目前为止,影像数据准备工作完成了。
2 波谱响应函数
波段响应函数,英文名为spectral response function(SRF)或者叫Relative Spectral Response (RSR) ,与宽波段传感器出现。我们知道每一个波段都有一个波段范围,比如HJ-b1(475nm)波段为520-430纳米,实际上传感器的感光元件在这个波段范围内的每一点所感应的强度都是不一样。在成像中,原则上讲应该根据波段响应函数来进行加权平均,但由于处理起来比较麻烦,而且一般的精度要求不太高,所以大多数图像都是直接取了波段范围内的中点值来运算。波段响应函数是描述一定波长范围内(超出波段范围)的量子效应,当需要精确计算像元响应时候,比如大气校正反演真实地表反射率,就需要使用波谱响应函数。
任何传感器在设计时都会给出严格的波段响应函数,高分一号也不例外。在中国资源卫星应用中心可下载:http://218.247.138.119/CN/Downloads/gpxyhs/5836.shtml。与资源一号02c和资源三号一样,高分一号也是以.xls格式提供,值得注意的是,第三列和第四例后面有部分无值区,手动填入0。
将数据拷贝到文本文件中。如下图中为波谱响应函数数字表达的一部分,第一列表示波长,后面五列分别表示一个全色和4个多光谱对应波长的波谱响应值。
图2 高分一号波谱响应值
在ENVI中,使用波谱曲线来描述波谱响应函数,也就是以波长作为x轴,波谱响应值作为y轴,存储格式为ENVI波谱库文件(.sli)。下面介绍ENVI classic中的波谱响应函数的制作。
(1) 启动ENVI Classic
(2) 选择Window->Start New Plot Window,ENVI Plot Window窗口中,选择File->Input Data->ASCII,如图3所示,自动将第一列作为X轴,后面3-6列作为Y轴。单击OK。
(3) 如图所示,生成了4条曲线。选择Edit->Data Parameters,更改每一条曲线的名称:b1,b2,b3,b4,便于区分。
(4) 选择File- >Save Plot As->Spectral Library,将波谱曲线保存为波谱库文件.sli。
图3 导入ASCII文件
图4 高分一号波谱响应函数的曲线表达
注:如果出现以下情况,原因是没有将多光谱波段1和波段2空白部分填补0。
图5 错误情况
3 FLAASH大气校正
(1) 工具箱/Radiometric Correction/Atmospheric Correction Module/FLAASH Atmospheric Correction打开FLAASH大气校正模块;
(2) 点击Input Radiance Image,前面处理好的数据,在Radiance Scale Factors面板中选择Use single scale factor for all bands,由于定标的辐射量数据与FLAASH的辐射亮度的单位相差10倍,所以在此Single scale factor选择默认:10,单击OK;
注:定标后的单位是W⋅m−2⋅sr−1⋅μm−1,与FLAASH要求的单位(μW)/(cm2*nm*sr)相差10倍关系,因此在Radiance Scale Factors中输入10缩放系数。
(3) 设置输出文件及路径设置;
(4) 传感器基本信息设置:
注:写这篇文档时没有得到官方正式数据,下面截图是公布之前填写的505,最终公布的数据为645km。
(5) 大气模型和气溶胶模型,根据经纬度和影像区域选择。
(6) 气溶胶反演方法选择None(缺少短波红外),能见度设置为40km。
图6 FLAASH大气校正参数设置
(7) 单击Multispectral Setting按钮,在Filter Function File 导入光谱响应曲线“gf-1pms.sli”,单击OK;
(8) 单击Advanced Settings,在高级设置中
讨论:一般中低分辨率的影像近似天顶角:180和方位角:0,即垂直观测。ENVI FLAASH的天顶角:90-180度,方位角:-180 and 180,没有查到高分一号的角度说明,这里选择默认。
图7 大气校正高级参数设置
(9) 设置好后,在大气校正模块面板中,单击Apply。
(10) 大气校正完成后,检查大气校正的结果,分别加载校正前后的图像(选择CIR假彩色方式加载,可以更好的识别植被),查看典型地物的大气校正前后的光谱曲线。
4 总结
从上面可以看到,对于未知的多光谱传感器的FLAASH大气校正,关键是获取波谱响应函数,而波谱响应函数一般都是公开的。类似的方法可用于高分一号宽幅传感器的FLAASH大气校正。
文章来源:http://blog.sina.com.cn/s/blog_764b1e9d0101bob2.html
- 数据定标
- 波谱响应函数制作
- FLAASH大气校正
注:本文是在ENVI5.0下和ENVI classic完成,其他版本基本类似。
1 数据定标
利用以下公式可将GF-1卫星各载荷的通道观测值计数值DN转换为卫星载荷入瞳处等效表观辐亮度数据。
式中:Gain为定标斜率;DN 为卫星载荷观测值; Bias为定标截距。
定标参数参照表1,来源于中国资源卫星应用中心:http://www.cresda.com/site1/Do ... shtml
表1 高分一号星PMS相机的定标系数
进行数据定标计算时候,我们可以有两种方法选择使用:
一、Bandmath
以下是利用Bandmath工具进行定标,这种方法灵活,不过需要一个一个波段定标。
1) 有了绝对定标参数和定标公式,选择Toolbox/Band Ratio/Band Math工具很容易进行传感器定标。
2) 由于是单个波段文件的定标,选择Toolbox/Raster Management/Layer Stacking将定标后的单波段文件组合成一个多波段文件。
二、Apply Gain and Offset工具
我们可以使用Apply Gain and Offset工具。。
1) 启动Toolbox/Radiometric Correction/Apply Gain and Offset。
2) 在Gain and Offset Values中填入 增益Gain值和偏移Offset。
3) 选择输出路径和文件名执行定标。
图1 Gain and Offset Values面板
计算好之后,继续执行以下步骤(原数据的储存顺序是BIP):
(1) 选择Toolbox/Raster Management/ Edit ENVI Header ->Edit Attributes->Wavelength,将每个波段的中心波长输入——b1(503nm),b2(576nm),b3(680nm) ,b4(810nm)
讨论:由于没有找到官方公布的中心波长信息,这里取与波谱响应中反射率为1的波长。
目前为止,影像数据准备工作完成了。
2 波谱响应函数
波段响应函数,英文名为spectral response function(SRF)或者叫Relative Spectral Response (RSR) ,与宽波段传感器出现。我们知道每一个波段都有一个波段范围,比如HJ-b1(475nm)波段为520-430纳米,实际上传感器的感光元件在这个波段范围内的每一点所感应的强度都是不一样。在成像中,原则上讲应该根据波段响应函数来进行加权平均,但由于处理起来比较麻烦,而且一般的精度要求不太高,所以大多数图像都是直接取了波段范围内的中点值来运算。波段响应函数是描述一定波长范围内(超出波段范围)的量子效应,当需要精确计算像元响应时候,比如大气校正反演真实地表反射率,就需要使用波谱响应函数。
任何传感器在设计时都会给出严格的波段响应函数,高分一号也不例外。在中国资源卫星应用中心可下载:http://218.247.138.119/CN/Downloads/gpxyhs/5836.shtml。与资源一号02c和资源三号一样,高分一号也是以.xls格式提供,值得注意的是,第三列和第四例后面有部分无值区,手动填入0。
将数据拷贝到文本文件中。如下图中为波谱响应函数数字表达的一部分,第一列表示波长,后面五列分别表示一个全色和4个多光谱对应波长的波谱响应值。
图2 高分一号波谱响应值
在ENVI中,使用波谱曲线来描述波谱响应函数,也就是以波长作为x轴,波谱响应值作为y轴,存储格式为ENVI波谱库文件(.sli)。下面介绍ENVI classic中的波谱响应函数的制作。
(1) 启动ENVI Classic
(2) 选择Window->Start New Plot Window,ENVI Plot Window窗口中,选择File->Input Data->ASCII,如图3所示,自动将第一列作为X轴,后面3-6列作为Y轴。单击OK。
(3) 如图所示,生成了4条曲线。选择Edit->Data Parameters,更改每一条曲线的名称:b1,b2,b3,b4,便于区分。
(4) 选择File- >Save Plot As->Spectral Library,将波谱曲线保存为波谱库文件.sli。
图3 导入ASCII文件
图4 高分一号波谱响应函数的曲线表达
注:如果出现以下情况,原因是没有将多光谱波段1和波段2空白部分填补0。
图5 错误情况
3 FLAASH大气校正
(1) 工具箱/Radiometric Correction/Atmospheric Correction Module/FLAASH Atmospheric Correction打开FLAASH大气校正模块;
(2) 点击Input Radiance Image,前面处理好的数据,在Radiance Scale Factors面板中选择Use single scale factor for all bands,由于定标的辐射量数据与FLAASH的辐射亮度的单位相差10倍,所以在此Single scale factor选择默认:10,单击OK;
注:定标后的单位是W⋅m−2⋅sr−1⋅μm−1,与FLAASH要求的单位(μW)/(cm2*nm*sr)相差10倍关系,因此在Radiance Scale Factors中输入10缩放系数。
(3) 设置输出文件及路径设置;
(4) 传感器基本信息设置:
- 成像中心点经纬度FLAASH自动从影像中获取。
- 传感器高度(Sensor Altitude):645km
注:写这篇文档时没有得到官方正式数据,下面截图是公布之前填写的505,最终公布的数据为645km。
- 像元大小(pixel Size):8m
- 成像区域平均高度可以通过统计DEM数据获取
- 成像时间:从数据头文件中读取(.XML),位置为:2013-09-08 13:14:07;减去8换算GMT时间
(5) 大气模型和气溶胶模型,根据经纬度和影像区域选择。
(6) 气溶胶反演方法选择None(缺少短波红外),能见度设置为40km。
图6 FLAASH大气校正参数设置
(7) 单击Multispectral Setting按钮,在Filter Function File 导入光谱响应曲线“gf-1pms.sli”,单击OK;
(8) 单击Advanced Settings,在高级设置中
- Tile Size 默认的是Cash size 的大小,手动改为50-100Mb(根据内存大小设定),单击OK;
- 从xml文件中得到: 97.0867 79.1983
讨论:一般中低分辨率的影像近似天顶角:180和方位角:0,即垂直观测。ENVI FLAASH的天顶角:90-180度,方位角:-180 and 180,没有查到高分一号的角度说明,这里选择默认。
图7 大气校正高级参数设置
(9) 设置好后,在大气校正模块面板中,单击Apply。
(10) 大气校正完成后,检查大气校正的结果,分别加载校正前后的图像(选择CIR假彩色方式加载,可以更好的识别植被),查看典型地物的大气校正前后的光谱曲线。
4 总结
从上面可以看到,对于未知的多光谱传感器的FLAASH大气校正,关键是获取波谱响应函数,而波谱响应函数一般都是公开的。类似的方法可用于高分一号宽幅传感器的FLAASH大气校正。
文章来源:http://blog.sina.com.cn/s/blog_764b1e9d0101bob2.html
0 个评论
相关问题
- 作为Desktop用户对数据的获取比较乏力,可能缺了哪些知识?
- 有谁知道哪里可以免费获取各省市地图数据呢,包括详细的shape文件数据
- 安装完arcgis10.3后,为何没有Envi tools这个工具箱?
- 有栅格数据a(大数据),小数据b,怎么从a中扣掉b,得到a数据剩下的部分?栅格能裁剪取反吗?
- 在windows server2008 R2 64位中安装了portal 10.5 设置好托管arcgis server站点,并用data store为托管数据库,发布数据出错
- ArcGIS数据库数据逐图幅裁剪
- ENVI中Image to Map中X/Y Pixel Size的参数如何设置?
- cityengine怎么导入arcgis的shp数据,对shp数据有什么要求
- ArcEngine 复制镶嵌数据集
- ArcGis打开图层后显示unknown units,想要define一个投影坐标系,但数据大小似乎不一致
- 基于ArcGIS的CAD数据向GIS数据转换方法