pythonはmatplotlibを利用して3 D空間に二次放物線を描いた事例を紹介します。
4781 ワード
図のプレビュー:
data:image/s3,"s3://crabby-images/4aaa7/4aaa72b53d18fd630667ba83c950956c1a38ba2c" alt=""
0、import
data:image/s3,"s3://crabby-images/28128/28128bdf473de581cca33c602654ed944d9d215a" alt=""
2、開口下の放物面
data:image/s3,"s3://crabby-images/daff3/daff34f76cbf36a113aab80e82279a500c348543" alt=""
3、マルチゾーンで異なる放物線を表示する
data:image/s3,"s3://crabby-images/4fbbd/4fbbd7dfee4d190d94fc34c6dcffb8ca57d129cf" alt=""
ソフトウェアバージョン:
data:image/s3,"s3://crabby-images/023a4/023a417a80b67c99fdf250faab8989c5a249f7c7" alt=""
以上は個人の経験ですので、参考にしていただければと思います。間違いがあったり、完全に考えていないところがあれば、教えてください。
data:image/s3,"s3://crabby-images/4aaa7/4aaa72b53d18fd630667ba83c950956c1a38ba2c" alt=""
0、import
import numpy as np
from matplotlib import pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
1、開口から上への放物線
fig = plt.figure(figsize=(9,6),
facecolor='khaki'
)
ax = fig.gca(projection='3d')
#
x = np.linspace(start=-3,
stop=3,
num=100
)
y = np.linspace(start=-3,
stop=3,
num=100
)
X, Y = np.meshgrid(x, y) #
Z = np.power(X, 2) + np.power(Y, 2) # z = x**2 + y**2
#
surf = ax.plot_surface(X=X,
Y=Y,
Z=Z,
rstride=2, # row stride,
cstride=2, # column stride,
color='r',
linewidth=0.5,
)
#
ax.view_init(elev=7, #
azim=30 #
)
#
plt.show()
図:data:image/s3,"s3://crabby-images/28128/28128bdf473de581cca33c602654ed944d9d215a" alt=""
2、開口下の放物面
fig = plt.figure(figsize=(9,6),
facecolor='khaki'
)
ax = fig.gca(projection='3d')
#
x = np.linspace(start=-3,
stop=3,
num=100
)
y = np.linspace(start=-3,
stop=3,
num=100
)
X, Y = np.meshgrid(x, y) #
Z = np.power(X, 2) + np.power(Y, 2) # z = x**2 + y**2
#
surf = ax.plot_surface(X=X,
Y=Y,
Z=-Z,
rstride=2, # row stride,
cstride=2, # column stride,
color='g',
linewidth=0.5,
)
#
ax.view_init(elev=7, #
azim=30 #
)
#
plt.show()
図:data:image/s3,"s3://crabby-images/daff3/daff34f76cbf36a113aab80e82279a500c348543" alt=""
3、マルチゾーンで異なる放物線を表示する
fig = plt.figure(figsize=(24, 16),
facecolor='khaki'
)
#
x = np.linspace(start=-3,
stop=3,
num=100
)
y = np.linspace(start=-3,
stop=3,
num=100
)
X, Y = np.meshgrid(x, y) #
Z = np.power(X, 2) + np.power(Y, 2) # z = x**2 + y**2
# -------------------------------- subplot(221) --------------------------------
ax = fig.add_subplot(221, projection='3d')
#
surf = ax.plot_surface(X=X,
Y=Y,
Z=Z,
rstride=2, # row stride,
cstride=2, # column stride,
color='r',
linewidth=0.5,
)
# -------------------------------- subplot(223) --------------------------------
ax = fig.add_subplot(223, projection='3d')
#
surf = ax.plot_surface(X=X,
Y=Y,
Z=-Z,
rstride=2, # row stride,
cstride=2, # column stride,
color='g',
linewidth=0.5,
)
# -------------------------------- subplot(22, (2,4)) --------------------------------
ax = plt.subplot2grid(shape=(2,2),
loc=(0, 1),
rowspan=2,
projection='3d'
)
#
surf1 = ax.plot_surface(X=X,
Y=Y,
Z=Z,
rstride=2, # row stride,
cstride=2, # column stride,
color='r',
linewidth=0.5,
)
#
surf2 = ax.plot_surface(X=X,
Y=Y,
Z=-Z,
rstride=2, # row stride,
cstride=2, # column stride,
color='g',
linewidth=0.5,
)
#
ax.view_init(elev=7, #
azim=30 #
)
# -------------------------------- fig --------------------------------
#
fig.subplots_adjust(wspace=0.1, # width space
hspace=0.15 # height space
)
#
plt.show()
図:data:image/s3,"s3://crabby-images/4fbbd/4fbbd7dfee4d190d94fc34c6dcffb8ca57d129cf" alt=""
ソフトウェアバージョン:
data:image/s3,"s3://crabby-images/023a4/023a417a80b67c99fdf250faab8989c5a249f7c7" alt=""
以上は個人の経験ですので、参考にしていただければと思います。間違いがあったり、完全に考えていないところがあれば、教えてください。