Python可视化DPR(hdf5格式)降水

 前言:最近大创开始学习卫星数据了,建议先学习hdf5格式再来学习数据画图~

参考网页:Learning HDF5

(可以下载user guide)

本文使用的数据是CMB数据,时间是2014年7月3日

废话不多说,上代码:

import h5py
from collections import namedtuple
import numpy as np
import matplotlib.cm as cm
import matplotlib.colors as mcolors
import matplotlib.ticker as mticker
import matplotlib.pyplot as plt
import cmaps
import cartopy.crs as ccrs
import cartopy.feature as cfeature
from cartopy.mpl.ticker import LongitudeFormatter, LatitudeFormatter
import pandas as pd
import warnings
warnings.filterwarnings('ignore')


def region_mask(vars, extents):
    '''返回切割好的经纬度和降水信息
    vars:带切割变量
    extents:画图经纬范围
    此方法是根据扫描中心线判断范围
    若中心线不在范围内,失败
    '''
    lonmin, lonmax, latmin, latmax = extents
    nscan, nray = vars[0].shape
    midray = nray // 2
    mask = (vars[0][:, midray] >= lonmin) & (vars[0][:, midray] <= lonmax) & (vars[1][:, midray] >= latmin) & (vars[1][:, midray] <= latmax)
    x = pd.DataFrame(mask)
    x.columns = ['Bool']
    var_new = []
    for i in range(len(vars)):
        var = pd.DataFrame(vars[i])
        var_s = pd.merge(x,var,left_index=True,right_index=True)
        var_new.append(var_s.loc[var_s['Bool']==True,~var_s.columns.isin(['Bool'])])
    return var_new


def make_Rr_cmap(levels):
    '''制作降水的colormap.'''
    nbin = len(levels) - 1
    cmap = cm.get_cmap('jet', nbin)
    norm = mcolors.BoundaryNorm(levels, nbin)
    return cmap, norm


#28.5 108.5中心,5°*5°大小


path = r"\HDF5学习\1955.HDF5"
with h5py.File(str(path), 'r') as f:
    lon = f['NS/Longitude'][:]
    lat = f['NS/Latitude'][:]
    surfacePrecipitation = f['NS/surfPrecipTotRate'][:]
 
time = '2014-07-03 07:31:30-09:04:03'

extents = [106, 111, 26,31]
var=[lon,lat,surfacePrecipitation]
var_new= region_mask(var, extents)
lon_c = var_new[0]
lat_c = var_new[1]
surfacePrecipitation = var_new[2]

#设置缺测
surfacePrecipitation.replace(-9999.9,np.nan)

levels_Rr = [0.1, 0.5, 1.0, 2.0, 3.0, 5.0, 10.0, 15.0, 20.0, 25]
cmap_Rr, norm_Rr = make_Rr_cmap(levels_Rr)

proj = ccrs.PlateCarree()
fig = plt.figure(figsize=(10, 8))
ax = fig.add_subplot(111, projection=proj)
ax.coastlines(resolution='50m', lw=0.5)
ax.add_feature(cfeature.OCEAN.with_scale('50m'))
ax.add_feature(cfeature.LAND.with_scale('50m'))
ax.xaxis.set_minor_locator(mticker.AutoMinorLocator(2))
ax.yaxis.set_minor_locator(mticker.AutoMinorLocator(2))
ax.xaxis.set_major_formatter(LongitudeFormatter())
ax.yaxis.set_major_formatter(LatitudeFormatter())
ax.set(xlim=(extents[0], extents[1]),ylim=(extents[-2], extents[-1]))
'''
url = 'http://map1c.vis.earthdata.nasa.gov/wmts-geo/wmts.cgi'
layer = 'BlueMarble_ShadedRelief'
ax.add_wmts(url, layer)  
#使用上面三行的底图需先下载owslib
#conda install -c conda-forge owslib
'''

ax.grid()
ax.tick_params(labelsize='large')
im = ax.contourf(
        lon_c, lat_c, surfacePrecipitation, levels_Rr,
        cmap=cmap_Rr, norm=norm_Rr, extend='both', transform=proj
    )
cb = fig.colorbar(im, ax=ax, ticks=levels_Rr)
cb.set_label('Rain Rate (mm/hr)', fontsize='large')
cb.ax.tick_params(labelsize='large')
ax.set_xticks(np.arange(extents[0], extents[1]+1, 1), crs=proj)
ax.set_yticks(np.arange(extents[-2], extents[-1]+1, 1), crs=proj)
ax.set_title(f'Rain Rate on {time}', fontsize='x-large')
plt.show()

 出图:

本代码更新版见Python | GPM CMB 单个文件SurfPrecipTotRate 绘制_HHHH1014的博客-优快云博客

Vivado2023是一款集成开发环境软件,用于设计和验证FPGA(现场可编程门阵列)和可编程逻辑器件。对于使用Vivado2023的用户来说,license是必不可少的。 Vivado2023的license是一种许可证,用于授权用户合法使用该软件。许可证分为多种类型,包括评估许可证、开发许可证和节点许可证等。每种许可证都有不同的使用条件和功能。 评估许可证是免费提供的,让用户可以在一段时间内试用Vivado2023的全部功能。用户可以使用这个许可证来了解软件的性能和特点,对于初学者和小规模项目来说是一个很好的选择。但是,使用评估许可证的用户在使用期限过后需要购买正式的许可证才能继续使用软件。 开发许可证是付费的,可以永久使用Vivado2023的全部功能。这种许可证适用于需要长期使用Vivado2023进行开发的用户,通常是专业的FPGA设计师或工程师。购买开发许可证可以享受Vivado2023的技术支持和更新服务,确保软件始终保持最新的版本和功能。 节点许可证是用于多设备或分布式设计的许可证,可以在多个计算机上安装Vivado2023,并共享使用。节点许可证适用于大规模项目或需要多个处理节点进行设计的用户,可以提高工作效率和资源利用率。 总之,Vivado2023 license是用户在使用Vivado2023时必须考虑的问题。用户可以根据自己的需求选择合适的许可证类型,以便获取最佳的软件使用体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值