Matplotlibの等高線図#
※記事内に商品プロモーションを含むことがあります。
公開日
Matplotlibで等高線図を出力するには、ax.contour
(線のみ)またはax.contourf
(塗り潰し)を使用します。
どちらの手法でも、最初の引数に2次元配列を与えます。このページでは前者のax.contour
を例としてオプションの指定方法を書いていますが、ax.contourf
も同様に指定できます。
import numpy as np
import matplotlib.pyplot as plt
C = np.arange(50).reshape(5, 10)
fig, ax = plt.subplots()
ax.contour(C) # 線のみ
plt.show()
fig, ax = plt.subplots()
ax.contourf(C) # 塗り潰し
plt.show()
data:image/s3,"s3://crabby-images/450fa/450fa8f20673744673d79a45b196971a6badbc57" alt="../_images/7b7ec5acf68c5ff1ae816220c39c4f1bd55b750faa37f746327629f786050d32.png"
data:image/s3,"s3://crabby-images/3fe7d/3fe7de64059d91bba5133e190de6f8763b7de85f" alt="../_images/a90290f8f022d716b4f90390fc832c8c543c586e9617b19c4937c6327c20c3fc.png"
上の等高線図では、値が小さい箇所は紫色、値が大きい箇所は緑色・黄色になります。
ここで、C
は以下のような5行10列の2次元配列です。等高線図の横軸は0から9, 縦軸は0から4の範囲で出力されています。
C
array([[ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19],
[20, 21, 22, 23, 24, 25, 26, 27, 28, 29],
[30, 31, 32, 33, 34, 35, 36, 37, 38, 39],
[40, 41, 42, 43, 44, 45, 46, 47, 48, 49]])
目盛りの指定#
等高線図の横幅と縦軸の目盛りを指定する場合、以下のようにax.pcolor
の1, 2番目の引数に配列として与えます。
X = np.arange(5,15) # 横幅の目盛り
Y = np.arange(5,10) # 縦幅の目盛り
fig, ax = plt.subplots()
ax.contour(X, Y, C)
plt.show()
data:image/s3,"s3://crabby-images/535b4/535b42cc47765380a9a657cd2ad955f5d23f19e2" alt="../_images/975076ef595155e63c819539000dd4508d6717e7e508f580187cfb239c308461.png"
カラーマップの指定#
cmap
オプションでカラーマップを指定します。
fig, ax = plt.subplots()
ax.contour(C, cmap="Reds")
plt.show()
data:image/s3,"s3://crabby-images/6d50d/6d50df22610dae22b10c1f44dc353a2da8b71b23" alt="../_images/266cd7453c233790c36b1f913892b7110e72f2df2ce53312cfe4ae3379e642fb.png"
指定可能なカラーマップについては、以下のページも参照下さい。
カラーバーを表示する場合、plt.colorbar
を使用します。ax.pcolor
の戻り値はPolyCollection
というクラスのオブジェクトです。これをplt.colorbar
の最初の引数とします。また、ax
オプションにカラーバーを表示するグラフ(ここではax
)を指定します。
fig, ax = plt.subplots()
mappable = ax.contour(C)
plt.colorbar(mappable, ax=ax)
plt.show()
data:image/s3,"s3://crabby-images/90846/90846819e0208975436808c7f99f6566c95b667f" alt="../_images/5b80f498e32e26764242f60ff4e53d7917f9b2581b0a1f21949a9287343d6b14.png"
表示するカラーマップの範囲を固定したい場合、最小値と最大値をそれぞれvmin
, vmax
で指定します。
カラーバーにラベルを付ける場合、plt.colorbar
の戻り値を取得(以下ではcbar
としています)し、この戻り値のset_label
メソッドを使用します。
fig, ax = plt.subplots()
mappable = ax.contour(C, vmin=10, vmax=40)
cbar = plt.colorbar(mappable, ax=ax)
cbar.set_label('Value')
plt.show()
data:image/s3,"s3://crabby-images/12c72/12c72b22cf9d9e459ce5bfee56bc4fb1474e9a0e" alt="../_images/665c46211e2ca0ea71d6681f6fed4a4aff1515daa5585a1a17197a12545d5bea.png"
等高線の間隔#
等高線の間隔を指定する場合、表示する等高線の値を配列として、levels
オプションに与えます。また、levels
オプションにint
型の数値を与えた場合、等高線の本数になります(間隔は自動的に決まります)。
fig, ax = plt.subplots()
mappable = ax.contour(C, levels=[0, 10, 20, 30, 40, 50])
plt.colorbar(mappable, ax=ax)
plt.show()
data:image/s3,"s3://crabby-images/df13b/df13b8d6173b8747efbd269b05945c4386c75a08" alt="../_images/5c2684d3943dc3725d78a00141be335ae32b7a90a2c0989707af32eed67fc326.png"
fig, ax = plt.subplots()
mappable = ax.contour(C, levels=6)
plt.colorbar(mappable, ax=ax)
plt.show()
data:image/s3,"s3://crabby-images/90846/90846819e0208975436808c7f99f6566c95b667f" alt="../_images/5b80f498e32e26764242f60ff4e53d7917f9b2581b0a1f21949a9287343d6b14.png"
等高線のラベル#
等高線の値をラベルとして表示するには、ax.contour()
の戻り値であるContourSet
クラスのオブジェクトを取得し、ax.clabel()
に渡します。
fig, ax = plt.subplots()
cs = ax.contour(C) # cs: ContourSetクラスのオブジェクト
ax.clabel(cs)
plt.show()
data:image/s3,"s3://crabby-images/88b49/88b49d88a6faaa2249b82087c61f6e6598a3fd0e" alt="../_images/6c5df9155a2f198de85c3183049e9f60f960a8d7e3d69c25b6840663f6dfc2e2.png"
ax.clabel
の主なオプションを以下の表に示します。
オプション |
説明 |
---|---|
|
フォントのサイズ |
|
ラベルの色 |
|
|
|
|
|
ラベルのフォーマットを指定(例: |
ラベルのフォントサイズはfontsize
, 色はcolors
オプションでそれぞれ指定できます。
fig, ax = plt.subplots()
cs = ax.contour(C)
ax.clabel(cs, fontsize=15, colors="black")
plt.show()
data:image/s3,"s3://crabby-images/01906/01906313ce45ebb7511d520b0fb56cd626d0f568" alt="../_images/1b2497aae34f91fef6cf1a696f042da698707edf94e52aa9c4fa14b9c477b6ac.png"
また、inline=False
(文字列を等高線を重ねる)、 fmt='%.2f'
(小数点以下2桁)とした例を以下に示します。
fig, ax = plt.subplots()
cs = ax.contour(C) # cs: ContourSetクラスのオブジェクト
ax.clabel(cs, inline=False, fmt='%.2f')
plt.show()
data:image/s3,"s3://crabby-images/560bb/560bbf782a86aac5b7f8a0cd01204ae5ee9b8978" alt="../_images/7885b4ad2494b12d34b80932ebf95de93ea8b64fa8119f03e0b5a1e36dcc6dc1.png"
等高線の色の上下限#
等高線の色の上限値と下限値は、それぞれvmax
, vmin
で指定します。vmax
以上の値とvmin
以下の値の色は、カラーマップの両端の色と同じになります。以下は0から49までの値をとる配列C
に対して、vmax=40, vmin=10
とした例です。10から40までの値の変化が分かりやすくなります。
fig, ax = plt.subplots()
mappable = ax.contour(C, vmax=40, vmin=10, levels=[0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50])
plt.colorbar(mappable, ax=ax)
plt.show()
data:image/s3,"s3://crabby-images/b432f/b432ff419d8dd0c06375618fa632098fe494b15e" alt="../_images/99a4eefc9fe22fee1087397c01d0eba3f0446413f23969c31d3f16c1dff6a466.png"
また、以下の例はvmax=70, vmin=-20
とした例です。こちらでは、値の変化が分かりづらくなります(値の変化が小さいことを示せます)。
fig, ax = plt.subplots()
mappable = ax.contour(C, vmax=70, vmin=-20, levels=[-20, -10, 0, 10, 20, 30, 40, 50, 60, 70])
plt.colorbar(mappable, ax=ax)
plt.show()
data:image/s3,"s3://crabby-images/80357/8035707fbb43356740d071f023db7a97ab16b5f8" alt="../_images/576c798a5771760f9e7205ce5acce7b2c1e94c426e7b3583eaa88e86e68c41ba.png"
線の太さの変更#
linewidths
オプションで線の太さを指定できます。
fig, ax = plt.subplots()
ax.contour(C, linewidths=8)
plt.show()
data:image/s3,"s3://crabby-images/93ca8/93ca82a6302b480f3eb08685c7ebd4895ab05cc8" alt="../_images/87315d4ed8cd32fcb777fbb4c09a388eba411131424cc6653debfef8d852a21a.png"
透明度の指定#
等高線図の塗り潰し(ax.contourf
)で透明度を指定するには、alpha
オプションを使用します。0から1の範囲の値を取り、値が小さいほど透明になります(デフォルトは1)。
fig, ax = plt.subplots()
ax.contourf(C, alpha=1) # デフォルト
plt.show()
fig, ax = plt.subplots()
ax.contourf(C, alpha=0.5)
plt.show()
data:image/s3,"s3://crabby-images/3fe7d/3fe7de64059d91bba5133e190de6f8763b7de85f" alt="../_images/a90290f8f022d716b4f90390fc832c8c543c586e9617b19c4937c6327c20c3fc.png"
data:image/s3,"s3://crabby-images/99270/9927063b73f85b54312e8f51096407f70c739b37" alt="../_images/8eecf5d96a46c397b65d465b35943941ec92cb16159b30a8b959fbfd2d130a66.png"