python如何處理衛(wèi)星云圖獲取亮溫值
在處理衛(wèi)星云圖hdf文件時(shí),matlab非常好用,但隨著python的流行,還是想學(xué)習(xí)一下python處理衛(wèi)星云圖數(shù)據(jù)獲取亮溫值。
我處理數(shù)據(jù)的前提是:
- 根據(jù)最佳路徑數(shù)據(jù)集,獲取經(jīng)緯度和時(shí)間。
- 根據(jù)時(shí)間找對(duì)應(yīng)的hdf文件,獲取其中的經(jīng)緯度,然后根據(jù)hdf文件中的經(jīng)度確定是哪顆衛(wèi)星的。
- 在全圓盤標(biāo)對(duì)稱文件經(jīng)緯度對(duì)照表dat文件獲取經(jīng)緯度時(shí)加上相應(yīng)的經(jīng)度。
- 最后根據(jù)最佳路徑的經(jīng)緯度獲取dat文件中最近格點(diǎn)的經(jīng)緯度索引,再通過(guò)hdf文件獲得亮溫值。
1.處理hdf文件
import h5py hdfFile = h5py.File('F:/新建文件夾/Satellite_Imagery/IR_data/韋森特/FY2D_FDI_ALL_NOM_20120723_1945.hdf', 'r') db1 = hdfFile['/CALChannelIR1'] hw1 = hdfFile['/NOMChannelIR1'] db2 = hdfFile['/CALChannelIR2'] hw2 = hdfFile['/NOMChannelIR2'] db3 = hdfFile['/CALChannelIR3'] hw3 = hdfFile['/NOMChannelIR3'] db4 = hdfFile['/CALChannelIR4'] hw4 = hdfFile['/NOMChannelIR4'] infoh = hdfFile['/NomFileInfo'] a = hdfFile['NomFileInfo'][()] print(a[0][3]) # 獲取緯度 print(a[0][4]) # 獲取經(jīng)度
對(duì)于風(fēng)云衛(wèi)星的數(shù)據(jù)格式,可以查閱相應(yīng)的資料,獲取靜止氣象衛(wèi)星的數(shù)據(jù)格式。這里不再詳細(xì)描述。
亮溫值的獲取分為四個(gè)IR通道和一個(gè)可見(jiàn)光通道,不同通道的用處不同,根據(jù)自己的需求選取數(shù)據(jù)。
對(duì)于獲取衛(wèi)星經(jīng)緯度等數(shù)據(jù),需要,根據(jù)NomFileInfo的數(shù)據(jù)集分析。
a = hdfFile['NomFileInfo'][()] print(a) [(b'FY2D', b'NOM', b'Nomalized Projection Full Disc Image', 0., 86.5, 35785864., b'fit', 2012, 7, 10, 12, 34, 0, 2012, 7, 23, 19, 45, 1, 2012, 7, 23, 19, 58, 58, 2012, 7, 23, 20, 0, 27, 6378137., 3.5e-05, 0.00014, 298.25722356, b'NOM Fit HDF5')]
對(duì)應(yīng)信息見(jiàn)下圖數(shù)據(jù)集。
獲取亮溫值:
獲取通道1的亮溫值,代碼如下:
hw = hw1[()] # 通道IR1,定標(biāo)表 db = db1[()] # 獲取定標(biāo)表的值 tb = np.zeros(shape=(2288, 2288)) # 2288*2288的圖像每個(gè)具體的亮溫值 for i in range(2288): for j in range(2288): if hw[i][j] == 65535 or hw[i][j] == 65534: # 判斷缺省值 tb[i][j] = 0 else: a = hw[i][j] tb[i][j] = db[0][a] print(tb) tb = tb.T # 注意需要轉(zhuǎn)置
2. 處理dat文件
對(duì)于FY2氣象衛(wèi)星而言,經(jīng)緯度查找表文件(NOM_ITG_2288_2288(0E0N)_LE.zip)可以從網(wǎng)上下載。
數(shù)據(jù)解壓之后,里面有三個(gè)文件,分別是:
在數(shù)據(jù)說(shuō)明文件中,詳細(xì)說(shuō)明了經(jīng)緯度查找表數(shù)據(jù)的使用方法,同時(shí)針對(duì)FY2系列衛(wèi)星的經(jīng)度進(jìn)行了說(shuō)明,由于上述經(jīng)緯度數(shù)據(jù)是以中心點(diǎn)為0度經(jīng)度生成的,所以對(duì)于FY2的數(shù)據(jù),需要在經(jīng)度數(shù)據(jù)上加上衛(wèi)星所在的經(jīng)度。
5 | FY-2G | 104.5°E |
---|---|---|
6 | FY-2H | 79°E |
對(duì)于不同的星可以根據(jù)hdf文件中的經(jīng)度,判斷對(duì)應(yīng)的查找表的經(jīng)度。
下面以H星為例,讀取dat文件,獲取網(wǎng)格經(jīng)緯度
lonlatfile = 'F:/Satellite_Imagery/Code/NOM_ITG_2288_2288(0E0N)_LE.dat' with open(lonlatfile, 'rb') as f: #lon_fy = np.fromfile(f, count=2288 * 2288, dtype='float32') + 79 # 先存經(jīng)度,根據(jù)衛(wèi)星的不同加上對(duì)應(yīng)的經(jīng)度值 #lat_fy = np.fromfile(f, count=2288 * 2288, dtype='float32') # 再存緯度 data = np.fromfile(f, dtype='float32') data = data.reshape([2288, 2288, 2], order='F') #lon = lon_fy.reshape([2288, 2288], order='F') #lat = lat_fy.reshape([2288, 2288], order='F') lon = data[:, :, 0] + 104.5 lat = data[:, :, 1]
這里需要注意的是,需要先取出來(lái)經(jīng)度,再取出緯度,這是經(jīng)緯度在dat文件中的存儲(chǔ)順序,然后加上衛(wèi)星的經(jīng)度,這里是79,故經(jīng)度加79,獲取經(jīng)緯度。
# 經(jīng)度表 [[379. 379. 379. ... 379. 379. 379.] [379. 379. 379. ... 379. 379. 379.] [379. 379. 379. ... 379. 379. 379.] ... [379. 379. 379. ... 379. 379. 379.] [379. 379. 379. ... 379. 379. 379.] [379. 379. 379. ... 379. 379. 379.]] # 緯度表 [[300. 300. 300. ... 300. 300. 300.] [300. 300. 300. ... 300. 300. 300.] [300. 300. 300. ... 300. 300. 300.] ... [300. 300. 300. ... 300. 300. 300.] [300. 300. 300. ... 300. 300. 300.] [300. 300. 300. ... 300. 300. 300.]]
這樣就獲取了dat文件中的網(wǎng)格經(jīng)緯度,即2288*2288的對(duì)照表,這樣根據(jù)最佳路徑數(shù)據(jù)集中的經(jīng)緯度,找到網(wǎng)格中最近的經(jīng)緯度。
注:因?yàn)榫W(wǎng)格存儲(chǔ)的經(jīng)緯度不是等間距的,所以不能直接近似找最近的點(diǎn),需要根據(jù)角度計(jì)算距離,找到網(wǎng)格上離所求經(jīng)緯度最近的網(wǎng)格點(diǎn),找到對(duì)應(yīng)的索引值,再根據(jù)索引值找到亮溫值。
總結(jié)
以上就是我通過(guò)python讀取hdf,dat文件,根據(jù)經(jīng)緯度獲取衛(wèi)星云圖的亮溫值的過(guò)程,僅為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
繪制登陸時(shí)的衛(wèi)星云圖亮溫值請(qǐng)參考python繪制登陸時(shí)的衛(wèi)星云圖(TBB)。
相關(guān)文章
Python實(shí)戰(zhàn)之MNIST手寫(xiě)數(shù)字識(shí)別詳解
MNIST數(shù)據(jù)集是機(jī)器學(xué)習(xí)領(lǐng)域中非常經(jīng)典的一個(gè)數(shù)據(jù)集,由60000個(gè)訓(xùn)練樣本和10000個(gè)測(cè)試樣本組成,每個(gè)樣本都是一張28 * 28像素的灰度手寫(xiě)數(shù)字圖片。本文主要介紹了通過(guò) MNIST實(shí)現(xiàn)手寫(xiě)數(shù)字識(shí)別,需要的可以參考一下2022-01-01python異步的ASGI與Fast Api實(shí)現(xiàn)
本文主要介紹了python異步的ASGI與Fast Api實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能
這篇文章主要介紹了基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08解讀MaxPooling1D和GlobalMaxPooling1D的區(qū)別
這篇文章主要介紹了MaxPooling1D和GlobalMaxPooling1D的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12Python中實(shí)現(xiàn)對(duì)list做減法操作介紹
這篇文章主要介紹了Python中實(shí)現(xiàn)對(duì)list做減法操作介紹,需要的朋友可以參考下2015-01-01Python pip安裝lxml出錯(cuò)的問(wèn)題解決辦法
這篇文章主要介紹了Python pip安裝lxml出錯(cuò)的問(wèn)題解決辦法的相關(guān)資料,需要的朋友可以參考下2017-02-02Python遠(yuǎn)程linux執(zhí)行命令實(shí)現(xiàn)
這篇文章主要介紹了Python遠(yuǎn)程linux執(zhí)行命令實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11