Matplotlibのサーフェスプロット#
※記事内に商品プロモーションを含むことがあります。
公開日
この記事では、Matplotlibでサーフェスプロットを出力する方法を解説します。サーフェスプロットでは、複数のデータ点に囲まれた面を描画します。
サーフェスプロットの基本#
plt.subplots()
のsubplot_kw
オプションに{'projection': '3d'}
という辞書形式データを与えることで、3次元のプロットになります。サーフェスプロットとするには、さらにax.plot_surface()
メソッドを使います。
ax.plot_surface()
メソッドにはデータ点のx, y, z座標を与えます。以下に例を示します。
import matplotlib.pyplot as plt
import numpy as np
x = np.arange(0, 2*np.pi, 0.1)
y = np.arange(0, 4*np.pi, 0.1)
X, Y = np.meshgrid(x, y)
Z = np.sin(X) + np.sin(Y)
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
data:image/s3,"s3://crabby-images/da18c/da18c28a42f9b08eb6388aa87ad7d6727cd75c8b" alt="../_images/02c9cc9e0aab33c25fb4f5369dbda6a59b056bdb3519c1b8cf4b9bfd842d1e56.png"
なお、変数X
, Y
, Z
はいずれも同じ大きさの2次元配列となります。
print(X.shape)
print(Y.shape)
print(Z.shape)
(126, 63)
(126, 63)
(126, 63)
ax.plot_surface()
メソッドの主なオプションを以下に示します。
引数 |
型 |
説明 |
---|---|---|
rcount, ccount |
int |
行・列方向の最大サンプル数。データ点数がこれより多い場合、ダウンサンプリングされる(デフォルト値:50) |
rstride, cstride |
int |
ダウンサンプリングするときに飛ばすデータ点数 |
color |
str |
面の色 |
alpha |
float |
面の透明度 |
edgecolor |
str |
枠線の色 |
cmap |
str |
面のカラーマップ |
vmin, vmax |
float |
カラーマップ範囲の最小値、最大値 |
shade |
bool |
シェーディング(陰影)処理の有無(デフォルト: |
rcount
とrstride
は片方のみ指定できます。同様に、ccount
とcstride
も片方のみ指定できます。
データのダウンサンプリング#
rcount
, rstride
, ccount
, cstride
で描画する頂点の数を変更できます。
rcount=10
, ccount=10
として、描画点数をx, y軸方向にそれぞれ10点とした例を以下に示します。デフォルト値 (50) よりもメッシュが荒くなっていることが分かります。
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, rcount=10, ccount=10)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
data:image/s3,"s3://crabby-images/cf6c6/cf6c60e9b4e3bcafbe3a848edea151a9145f8364" alt="../_images/68d60dee982b7327a962f8f0bdf06044d580d503d1cf3cf9d1d6c7203a7c811a.png"
面の色#
color
オプションで面の色を指定できます。
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, color="green")
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
data:image/s3,"s3://crabby-images/19cb3/19cb3bba50c84c1a37fc3dec692082e07abe5629" alt="../_images/ba2337a0a3d6476548cfb21eeb384ca45b004d0f1f9aa0d42c73fa3b144dc02b.png"
指定可能な色については以下のページを参照下さい。
面の色の透明度#
面の色の透明度を指定するには、alpha
オプションを使用します。0から1の範囲の値を取り、値が小さいほど透明になります(デフォルトは1)。以下にalpha=0.3
とした例を示します。
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, alpha=0.3)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
data:image/s3,"s3://crabby-images/97506/97506b34ceac35ddc8b293fbfe4fcfdce6633d34" alt="../_images/614dd7bcd2c2f1d23ba279275e462f498246ebd179b948de935cbd42dc3d1ef3.png"
枠線の色#
枠線の色をedgecolor
オプションで指定できます。
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, edgecolor="black")
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
data:image/s3,"s3://crabby-images/f1107/f110730e27eb61510920ab3fae80c5d1a6715c37" alt="../_images/f28d6e1cb0301b4269f55cbbdad0d2923d52f2937bee491427e61a44409423cb.png"
カラーマップ#
cmap
オプションで面のカラーマップを指定できます。z軸の値に応じて面の色が変化します。
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, cmap="Blues")
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
plt.show()
data:image/s3,"s3://crabby-images/27374/27374c8bf1c54093427b2605a9e46efaf8d85b78" alt="../_images/43b03163ad50c920942225899a830f05c0e16c7dc3d551b73348e858f07a56a8.png"
指定可能なカラーマップについては以下のページを参照下さい。
カラーバーを表示する場合、plt.colorbar
を使用します。ax.pcolor
の戻り値はPolyCollection
というクラスのオブジェクトです。これをplt.colorbar
の最初の引数とします。また、ax
オプションにカラーバーを表示するグラフ(ここではax
)を指定します。
fig, ax = plt.subplots(figsize=(8, 5), subplot_kw={'projection': '3d'})
mappable = ax.plot_surface(X, Y, Z, cmap="Blues")
plt.colorbar(mappable, ax=ax)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
fig.tight_layout()
plt.show()
data:image/s3,"s3://crabby-images/17bf2/17bf26f0df6b62e75ec855116abc0e0481532df2" alt="../_images/4582273c10a795d5fcea1d0e028dbaa13a63d2d85c674b633c5117c50e606d52.png"
表示するカラーマップの範囲を固定したい場合、最小値と最大値をそれぞれvmin
, vmax
で指定します。
カラーバーにラベルを付ける場合、plt.colorbar
の戻り値を取得(以下ではcbar
としています)し、この戻り値のset_label
メソッドを使用します。
fig, ax = plt.subplots(figsize=(8, 5), subplot_kw={'projection': '3d'})
mappable = ax.plot_surface(X, Y, Z, cmap="Blues")
cbar = plt.colorbar(mappable, ax=ax)
cbar.set_label('Value')
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
fig.tight_layout()
plt.show()
data:image/s3,"s3://crabby-images/0cd43/0cd4350109195e3fbb97255334e391f49c9594ab" alt="../_images/a599d89a530ac192dd5d7c98a204891b52db197114c3428fc9a8743e3ccdf6aa.png"
シェーディング(陰影)#
ax.plot_surface()
メソッドのshade
オプションでシェーディング(陰影)処理を行うか指定できます。True
(デフォルト)の場合はシェーディング処理を行います。なお、cmap
オプションでカラーマップを指定した場合、shade=False
となります。
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, shade=True)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
ax.set_title("shade=True")
plt.show()
fig, ax = plt.subplots(figsize=(6, 6), subplot_kw={'projection': '3d'})
ax.plot_surface(X, Y, Z, shade=False)
ax.set_xlabel("x")
ax.set_ylabel("y")
ax.set_zlabel("z")
ax.set_title("shade=False")
plt.show()
data:image/s3,"s3://crabby-images/3db63/3db6393caeab6a47dd5a31169e604d24fcadb170" alt="../_images/f557e8dafe4dfba807a06497802d263d7537a508a55fb522b12df6c324026872.png"
data:image/s3,"s3://crabby-images/cb24f/cb24fffd3f829142ec14b40ee31aa99b96b7dc93" alt="../_images/17c18110e7fbcaf39199526f06ab65bcb75806f6404ba1b3e5ddc852df7e7162.png"