Matplotlib의 triangular grid 사용법#
Matplotlib 버전 1.3부터는 삼각 그리드(triangular grid)에 대한 지원이 추가되었다. 삼각 그리드를 사용하연 기존의 사각형 영역 뿐 아니라 임의의 영역에 대해서 컨투어 플롯이나 서피스 플롯을 그릴 수 있으므로 정의역(domain)이 직사각형이 아닌 2차원 함수도 시각화 할 수 있다.
패키지#
삼각 그리드 지원을 위한 코드 중 일부는 tri 서브 패키지 아래에 있으므로 미리 임포트한다.
import matplotlib.tri as mtri
삼각 그리드 클래스#
삼각 그리드 지원을 위한 클래스는 다음과 같다.
삼각 그리드 생성
삼각 그리드 세분화
삼각 그리드 플롯
triplot
tricontour
tricontourf
tripcolor
삼각 그리드 보간
TriInterpolator
LinearTriInterpolator
CubicTriInterpolator
삼각 그리드 생성#
삼각 그리드는 Triangulation
클래스로 생성한다. Triangulation
클래스는 x
. y
, triangles
세 개의 인수를 받는데 x
, y
는 일련의 점들의 x좌표와 y좌표를 나타내는 1차원 벡터들이고 triangles
는 이 점들에 대한 기하학적 위상 정보 즉, 어떤 삼각형이 있으며 각 삼각형이 어떤 점들로 이루어져있는가를 보인다. 만약 triangles
가 주어지지 않으면 자동으로 생성한다.
x = np.array([0, 1, 2])
y = np.array([0, np.sqrt(3), 0])
triangles = [[0, 1, 2]]
triang = mtri.Triangulation(x, y, triangles)
plt.title("삼각 그리드")
plt.triplot(triang, 'ko-')
plt.xlim(-0.1, 2.1)
plt.ylim(-0.1, 1.8)
plt.show()
data:image/s3,"s3://crabby-images/ae771/ae77100bfc054158d9e7d750926691c0ce908c0a" alt="../_images/d7b3f9b4668e95b0548861279abd1c25398b47bc54b480b00a5a9b63e7fd5a74.png"
x = np.asarray([0, 1, 2, 3, 4, 2])
y = np.asarray([0, np.sqrt(3), 0, np.sqrt(3), 0, 2*np.sqrt(3)])
triangles = [[0, 1, 2], [2, 3, 4], [1, 2, 3], [1, 3, 5]]
triang = mtri.Triangulation(x, y, triangles)
plt.title("여러개의 삼각형 그리기")
plt.triplot(triang, 'ko-')
plt.xlim(-0.1, 4.1)
plt.ylim(-0.1, 3.7)
plt.show()
data:image/s3,"s3://crabby-images/ad652/ad6527c3a2c071472be9414657d53ff3865a52f4" alt="../_images/a2926a67939a6327013c7a6744d605bbf2e060a7ca3d22b364af4411054c2c57.png"
그리드 세분화#
그리드를 더 세분화하려면 TriRefiner
또는 UniformTriRefiner
를 사용한다. 이 클래스들은 다음과 같은 메서드를 가진다.
refine_triangulation
: 단순히 삼각 그리드를 세분화refine_field
: 실제 함수 값에 대해 최적화된 삼각 그리드 생성
refiner = mtri.UniformTriRefiner(triang)
triang2 = refiner.refine_triangulation(subdiv=2)
plt.title("그리드 세분화")
plt.triplot(triang2, 'ko-')
plt.xlim(-0.1, 4.1)
plt.ylim(-0.1, 3.7)
plt.show()
data:image/s3,"s3://crabby-images/51121/5112134d84c1c59aebc6cd7d3150d34c510dca5d" alt="../_images/3e19f9d93dfae410576b62fe2cd08a61a0e3d73213a977a3bb68ede6905806a5.png"
그리드 플롯#
이렇게 만들어진 그리드상에 tricontour
, tricontourf
, plot_trisur
, plot_trisurf
등의 명령을 사용하여 2차원 등고선(coutour) 플롯이나 3차원 표면(surface) 플롯을 그릴 수 있다.
triang5 = refiner.refine_triangulation(subdiv=5)
z5 = np.cos(1.5*triang5.x)*np.cos(1.5*triang5.y)
plt.title("삼각 그리드에서의 3차원 데이터 시각화")
plt.tricontourf(triang5, z5, cmap="gray")
plt.show()
data:image/s3,"s3://crabby-images/dcea9/dcea990eda9f5259506c896ba25555116762692e" alt="../_images/cfee3e65bb80c55af57bd73fe95b9daee94922c6401f788b7b584823470a222f.png"
from mpl_toolkits.mplot3d import Axes3D
from matplotlib import cm
triang3 = refiner.refine_triangulation(subdiv=3)
z3 = np.cos(1.5 * triang3.x) * np.cos(1.5 * triang3.y)
fig = plt.figure()
ax = fig.gca(projection='3d')
ax.set_title("삼각 그리드에서의 3D Surface Plot")
ax.plot_trisurf(triang3.x, triang3.y, z3, cmap=cm.jet, linewidth=0.2)
ax.tricontourf(triang3, z3, zdir='z', offset=-1.2, cmap=cm.coolwarm)
ax.set_zlim(-1, 1)
ax.view_init(40, -40)
plt.show()
data:image/s3,"s3://crabby-images/2a9dc/2a9dcfc6f770b11f578428d8a7af3c35cfb0acd6" alt="../_images/ae359d592a522e69a07eb1139e0bcc839eb68bebec3b0ea29653aa33f4b87b8e.png"