見出し画像

GSMの500hPa面天気図作成 2

この第2回では、第1回で準備した気象庁全球モデルの格子点データセットを図にするコードを紹介します。

等値線やハッチ描画、地図の指定、グリッド描画などの参考になると思います。ただし、今回は、気象庁の数値予報天気図にある低気圧や高気圧のマークなどの表示について紹介できていません。第3回にご紹介します。

なお、第3回にJupyter Notebook用のコードを公開しています。適宜ご利用ください。

描画の準備

次のコードで、表示する図に必要なパラメーター、地図の図法や表示範囲、表示する等値線の高度や渦度の値などを指定します。

## 表示用の指定
# 図法指定 気象庁の数値予報資料と同じ図法に設定                                                                                
proj = ccrs.Stereographic(central_latitude=60, central_longitude=140)
latlon_proj = ccrs.PlateCarree() # 緯度経度の処理用に正距円筒図法も使う  
#
# 地図の描画範囲指定
areaAry = [108, 156, 17, 55]  # 極東
#areaAry = [115, 151, 20, 50]  # 日本付近
#
# 等値線の間隔を指定
levels_ht =np.arange(4800, 6000,  60)  # 高度を60m間隔で実線                       
levels_ht2=np.arange(4800, 6000, 300)  # 高度を300m間隔で太線
levels_vr =np.arange(-0.0002, 0.0002, 0.00004)  # 渦度4e-5毎に等値線
#
# 渦度のハッチの指定
levels_h_vr = [0.0, 0.00008, 1.0]    # 0.0以上で 灰色(0.9), 8e-5以上で赤
colors_h_vr = ['0.9','red']
alpha_h_vr = 0.3                     # 透過率を指定
#
# 緯度・経度線の指定
dlon,dlat=10,10   # 10度ごとに
#
## タイトル文字列用
# 予想時間を得る
ft_hours=int(i_ft/100) * 24 + int(i_ft%100)
# 初期時刻の文字列
dt_i = grbHt.analDate
dt_str = (dt_i.strftime("%H00UTC%d%b%Y")).upper()
dt_str2 = dt_i.strftime("%Y%m%d%H")

図のサイズなどの指定

図の大きさや余白などを指定するコードは次の通りです。

## 図のSIZE指定inch                                                                        
fig = plt.figure(figsize=(10,8))
#
## 余白設定                                                                                
plt.subplots_adjust(left=0, right=1, bottom=0.06, top=0.98)
#                 
## 作図開始                                                                                    
ax = fig.add_subplot(1, 1, 1, projection=proj)
ax.set_extent(areaAry, latlon_proj)

等値線やハッチの描画

次のコードで、相対渦度のハッチ描画、高度の等値線(太線、実線、特定の高度5820m(茶色)と5400m(青色))描画を行なっています。等値線の値表示も指定しています。しかし、値が表示されない等値線が出ることがあります。バグなのか仕様なのかわかっていません。

# 500hPa 相対渦度のハッチ 0.0以上:着色  0.8*10**-4以上:赤                                  
cn_relv_hatch2 = ax.contourf(ds['lon'], ds['lat'], ds['vorticity'],
       levels_h_vr, colors=colors_h_vr,
       alpha=alpha_h_vr, transform=latlon_proj)
# 5000hPa 相対渦度 実線 0.00004毎 負は破線                                                 
cn_relv = ax.contour(ds['lon'], ds['lat'], ds['vorticity'],
       levels_vr, colors='black', linewidths=1.0, transform=latlon_proj)
# 500hPa  等高度線 実線 step1:60m毎                                                                                                          
cn_hgt = ax.contour(ds['lon'], ds['lat'], ds['Geopotential_height'],
                   colors='black',
                   linewidths=1.2, levels=levels_ht, transform=latlon_proj )
ax.clabel(cn_hgt, levels_ht, fontsize=15, inline=True, inline_spacing=5,
         fmt='%i', rightside_up=True)
# 500hPa 等高度線 太線 step1:300m毎                                                        
cn_hgt2= ax.contour(ds['lon'], ds['lat'], ds['Geopotential_height'],
                   colors='black',
                   linewidths=1.5, levels=levels_ht2, transform=latlon_proj)
ax.clabel(cn_hgt2, fontsize=15, inline=True, inline_spacing=0,
         fmt='%i', rightside_up=True)
# 500hPa 5820gpm高度線 茶色                                                         
cn5820 = ax.contour(ds['lon'], ds['lat'], ds['Geopotential_height'],
                   colors='brown',linestyles='dashdot',
                   linewidths=1.2, levels=[5820], transform=latlon_proj )
# 500hPa 5400gpm高度線 青色                                                            
cn5400 = ax.contour(ds['lon'], ds['lat'], ds['Geopotential_height'],
                   colors='blue',linestyles='dashdot',
                   linewidths=1.2, levels=[5400], transform=latlon_proj )

海岸線やグリッド、タイトル描画

海岸線や緯度線、経度線、タイトルの描画などのコードを、次に示します。

## 海岸線                                                                                                                               
ax.coastlines(resolution='50m',)
## グリッド                                                                   
xticks=np.arange(0,360.1,dlon)
yticks=np.arange(-90,90.1,dlat)
gl = ax.gridlines(crs=ccrs.PlateCarree()
        , draw_labels=False
        , linewidth=1, alpha=0.8)
gl.xlocator = mticker.FixedLocator(xticks)
gl.ylocator = mticker.FixedLocator(yticks)
#                                                                                          
## Title                                                                        
fig.text(0.5,0.01,
        "GSM FT{0:d} IT:".format(ft_hours)+dt_str+" 500hPa Height(m),VORT" ,
        ha='center',va='bottom', size=18)
# 出力
plt.show()

このコードで出力される図は次の通りとなります。

画像1
第2回目までのコード紹介で作成できる500hPa面天気図

画像をファイル出力するには、次のコードを利用します

## ファイル出力                                                                                    
out_fn="gsm_{0}UTC_FT{1:03d}_50.png".format(dt_str2,ft_hours)
plt.savefig(out_fn)

第1回と第2回のコードについて、パラメータなど変更すれば、気圧面の気温などの等値線なども比較的簡単に作成できます。試してみてください。

次回は、極大値や極小値の位置にマークをつけるために必要なコードを紹介します。


いいなと思ったら応援しよう!