메모
전체 예제 코드를 다운로드 하려면 여기 를 클릭 하십시오.
삼각 3D 등고선 플롯 #
구조화되지 않은 삼각형 그리드의 등고선도.
사용된 데이터는 trisurf3d_demo2의 두 번째 플롯과 동일합니다. tricontour3d_demo는 이 예제의 채워진 버전을 보여줍니다.
import matplotlib.pyplot as plt
import matplotlib.tri as tri
import numpy as np
n_angles = 48
n_radii = 8
min_radius = 0.25
# Create the mesh in polar coordinates and compute x, y, z.
radii = np.linspace(min_radius, 0.95, n_radii)
angles = np.linspace(0, 2*np.pi, n_angles, endpoint=False)
angles = np.repeat(angles[..., np.newaxis], n_radii, axis=1)
angles[:, 1::2] += np.pi/n_angles
x = (radii*np.cos(angles)).flatten()
y = (radii*np.sin(angles)).flatten()
z = (np.cos(radii)*np.cos(3*angles)).flatten()
# Create a custom triangulation.
triang = tri.Triangulation(x, y)
# Mask off unwanted triangles.
triang.set_mask(np.hypot(x[triang.triangles].mean(axis=1),
y[triang.triangles].mean(axis=1))
< min_radius)
ax = plt.figure().add_subplot(projection='3d')
ax.tricontour(triang, z, cmap=plt.cm.CMRmap)
# Customize the view angle so it's easier to understand the plot.
ax.view_init(elev=45.)
plt.show()