Python中使用OpenCV库来进行简单的气象学遥感影像计算


Posted in Python onFebruary 19, 2016

OpenCV的全称是Open Source Computer Vision Library,是一个跨平台的计算机视觉库。OpenCV是由英特尔公司发起并参与开发,以BSD许可证授权发行,可以在商业和研究领域中免费使用。OpenCV可用于开发实时的图像处理、计算机视觉以及模式识别程序。该程序库也可以使用英特尔公司的IPP进行加速处理。
OpenCV用C++语言编写,它的主要接口也是C++语言,但是依然保留了大量的C语言接口。该库也有大量的Python, Java and MATLAB/OCTAVE (版本2.5)的接口。这些语言的API接口函数可以通过在线文档获得。现在也提供对于C#, Ch,Ruby的支持。
在Windows上编译OpenCV中与摄像输入有关部分时,需要DirectShow SDK中的一些基类。该SDK可以从预先编译的Microsoft Platform SDK (or DirectX SDK 8.0 to 9.0c / DirectX Media SDK prior to 6.0)的子目录Samples\Multimedia\DirectShow\BaseClasses获得。

下面我们就来看看OpenCV在Python编程下的应用,我们来处理一下简单的气象学计算,用python里面的opencv库写个脚本批处理图像反射率的计算试试~

核心步骤就是 遥感影像光谱辐射定标 →大气校正→计算反射率这三步了

1、遥感影像的光谱辐射定标
由遥感器的灵敏度特征引起的辐射畸变主要由其光学系统或光电转换系统的特征形成的,光电转换系统的灵敏性特征通常很重复,其校正一般是通过定期的地面测定值进行的。
遥感器光谱辐射定标时采用以下转换算式:

Python中使用OpenCV库来进行简单的气象学遥感影像计算

遥感器各波段偏移与增益值从论文找了找后,找到这么一张表~

Python中使用OpenCV库来进行简单的气象学遥感影像计算

那么这么个函数就能定标咯:

def computL(gain,Dn,bias): 
    return (gain*Dn+bias)

2、遥感影像的大气校正
任何一种依赖大气物理模型的大气校正方法都需要先进行遥感器的辐射校准。
公式是这个咯(Chavez P S,Jr. Image -Based Atmospheric Correction Revisited and Improved Photogrammetric Engineering and Remote Sensing, 1996,62,1025 -1036)

Python中使用OpenCV库来进行简单的气象学遥感影像计算

其中:Lhazel——大气层光谱辐射值;LI,min——遥感器每一波段最小光谱辐射值;LI,1%——反射率为1%的黑体辐射值。

关于LI,min和LI,1%的计算公式就省略了啊,感兴趣的同学可以自己去查查论文~

而计算Lhazel需要的参数可以从遥感图像的头文件中获得一部分,还有一部分是固定的参数~这些都藏在ENVI的背后,不过自己写脚本的时候找出他们还是废了一番功夫的。

计算Lhazel的代码如下:

#ESUN 
ESUNI71=196.9 
cos=math.cos(math.radians(90-41.3509605)) 
# 
Lmini=-6.2 
Lmax=293.7 
# 
Qcal=1 
Qmax=255 
LIMIN=Lmini+(Qcal*(Lmax-Lmini)/Qmax) 
LI=(0.01*ESUNI71*cos*cos)/(math.pi*D*D) 
Lhazel=LIMIN-LI

 

3、计算遥感影像的反射率
根据太阳辐射和大气传输原理与过程,TM/ETM+数据地面反射率反演的数学模型可综合表达为:

Python中使用OpenCV库来进行简单的气象学遥感影像计算

其中:ρ——地面相对反射率;D——日地天文单位距离;LsatI——传感器光谱辐射值,即大气顶层的辐射能量;LhazeI——大气层辐射值;ESUNl——大气顶层的太阳平均光谱辐射,即大气顶层太阳辐照度;SZ——太阳天顶角。

这里提一下其中两个参数的计算公式:
日地天文单位距离 D=1 -0.01674 cos(0.9856×(JD-4)×π/180);
(JD为遥感成像的儒略日(Julian Day),计算公式为:

JD=K-32075+1461*(I+4800+(J-14)/12)/4+367*(J-2-(J-14)/12*12)/12-3*((I+4900+(J-14)/12)/100)/4

I、J、K分别为年、月、日

有了这些,最后就能直接算出来反射率啦,粗糙代码如下,因为是写着玩的,也没怎么处理:
不过需要注意的是,遥感图像进行计算跟输出的时候,需要使用uint16类型的数组来存储的(uint8长度不够啊。。)
一些参数涉及到浮点数计算,如果对处理结果有极高要求的话,最好使用专门的科学运算库(像我这种渣学校才不介意这些)

import cv2 
import numpy as np 
import math 
 
img1=cv2.imread('F:\L71121040_04020030220_B10.TIF') 
#图像格式转换 
img10=cv2.cvtColor(img1,cv2.COLOR_BGR2GRAY) 
 
#计算JD 
I=2003 
J=2 
K=20 
JD=K-32075+1461*(I+4800+ (J-14)/12)/4+367*(J-2-(J-14)/12*12)/12-3*((I+4900+(J-14)/12)/100)/4 
#设置ESUNI值 
ESUNI71=196.9 
#计算日地距离D 
D=1-0.01674*math.cos((0.9856*(JD-4)*math.pi/180)) 
#计算太阳天顶角 
cos=math.cos(math.radians(90-41.3509605)) 
 
inter=(math.pi*D*D)/(ESUNI71*cos*cos) 
 
#大气校正参数设置 
Lmini=-6.2 
Lmax=293.7 
Qcal=1 
Qmax=255 
LIMIN=Lmini+(Qcal*(Lmax-Lmini)/Qmax) 
LI=(0.01*ESUNI71*cos*cos)/(math.pi*D*D) 
Lhazel=LIMIN-LI 
 
 
def copy(img,new1): 
  new1= np.zeros(img.shape,dtype='uint16') 
  new1[:,:] = img[:,:] 
 
def computL(gain,Dn,bias): 
  return (gain*Dn+bias) 
 
if __name__ == '__main__': 
  print 'D=',D 
  print 'cosZS=',cos 
  print 'Lhazel=',Lhazel 
  #计算图像反射率  
  result=np.zeros(img.shape,dtype='uint16') 
  for i in range(0,img.shape(1)): 
    for j in range(0,img.shape(0)): 
      Lsat=computL(1.18070871,img10[i,j],-7.38070852) 
      result[i,j]=inter*(Lsat-Lhazel)*1000 
       
#保存图像 
  cv2.imwrite("F:\\result.tif", result) 
  cv2.namedWindow("Image") 
  cv2.imshow("Image", result) 
  cv2.waitKey(0)
Python 相关文章推荐
python 字符串格式化代码
Mar 17 Python
python从sqlite读取并显示数据的方法
May 08 Python
将python代码和注释分离的方法
Apr 21 Python
解决Python pandas df 写入excel 出现的问题
Jul 04 Python
Python走楼梯问题解决方法示例
Jul 25 Python
python实现归并排序算法
Nov 22 Python
python实现各种插值法(数值分析)
Jul 30 Python
python实现PID算法及测试的例子
Aug 08 Python
Python run()函数和start()函数的比较和差别介绍
May 03 Python
详解向scrapy中的spider传递参数的几种方法(2种)
Sep 28 Python
Python .py生成.pyd文件并打包.exe 的注意事项说明
Mar 04 Python
CocosCreator ScrollView优化系列之分帧加载
Apr 14 Python
Python实现以时间换空间的缓存替换算法
Feb 19 #Python
Python使用爬虫猜密码
Feb 19 #Python
使用Python简单的实现树莓派的WEB控制
Feb 18 #Python
在Ubuntu系统下安装使用Python的GUI工具wxPython
Feb 18 #Python
以一个投票程序的实例来讲解Python的Django框架使用
Feb 18 #Python
使用Python生成随机密码的示例分享
Feb 18 #Python
使用Python的urllib2模块处理url和图片的技巧两则
Feb 18 #Python
You might like
[原创]PHP正则匹配中英文、数字及下划线的方法【用户名验证】
2017/08/01 PHP
php微信公众号开发之二级菜单
2018/10/20 PHP
Laravel 修改验证异常的响应格式实例代码详解
2020/05/25 PHP
PHP反射基础知识回顾
2020/09/10 PHP
基于jquery的代码显示区域自动拉长效果
2011/12/07 Javascript
extjs 分页使用jsp传递数据示例
2014/07/29 Javascript
JQuery悬停控制图片轮播——代码简单
2015/08/05 Javascript
JavaScript自定义函数实现查找两个字符串最长公共子串的方法
2016/11/24 Javascript
jQuery使用Layer弹出层插件闪退问题
2016/12/22 Javascript
微信小程序实现缓存根据不同的id来进行设置和读取缓存
2017/06/12 Javascript
jQuery实现动态添加节点与遍历节点功能示例
2017/11/09 jQuery
webpack4实现不同的导出类型
2019/04/09 Javascript
微信小程序实现左侧滑动导航栏
2020/04/08 Javascript
基于jQuery实现挂号平台首页源码
2020/01/06 jQuery
[01:04:01]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第一场
2014/05/24 DOTA
使用IPython下的Net-SNMP来管理类UNIX系统的教程
2015/04/15 Python
在Apache服务器上同时运行多个Django程序的方法
2015/07/22 Python
Python的collections模块中namedtuple结构使用示例
2016/07/07 Python
python实现单向链表详解
2018/02/08 Python
Numpy 将二维图像矩阵转换为一维向量的方法
2018/06/05 Python
Python读取txt文件数据的方法(用于接口自动化参数化数据)
2018/06/27 Python
详解python使用turtle库来画一朵花
2019/03/21 Python
如何通过python画loss曲线的方法
2019/06/26 Python
详解将Pandas中的DataFrame类型转换成Numpy中array类型的三种方法
2019/07/06 Python
Python3操作Excel文件(读写)的简单实例
2019/09/02 Python
Django关于admin的使用技巧和知识点
2020/02/10 Python
django迁移文件migrations的实现
2020/03/31 Python
python基本算法之实现归并排序(Merge sort)
2020/09/01 Python
使用css3背景渐变中的透明度来设置不同颜色的背景渐变
2014/03/31 HTML / CSS
HTML5 实战PHP之Web页面表单设计
2011/10/09 HTML / CSS
关于HTML5+ API plusready的兼容问题
2020/11/20 HTML / CSS
英国最大的化装舞会服装网站:Fancydress.com
2017/08/15 全球购物
澳大利亚一站式数码相机商店:CameraPro
2020/03/09 全球购物
机电一体化专业毕业生自荐信
2014/06/19 职场文书
经典导游欢迎词
2015/01/26 职场文书
Python Django获取URL中的数据详解
2021/11/01 Python