소개
이 튜토리얼에서는 Matplotlib 을 사용하여 각 기본 3D 뷰 평면을 보여주는 "전개된" 3D 플롯을 생성하는 방법을 배웁니다. 또한 각 뷰에 필요한 고도 (elevation), 방위각 (azimuth), 롤 (roll) 각도를 레이블링합니다. 이 이미지는 인쇄하여 각 평면이 상자의 한 면을 형성하는 상자로 접을 수 있습니다.
VM 팁
VM 시작이 완료되면 왼쪽 상단을 클릭하여 Notebook 탭으로 전환하여 실습을 위해 Jupyter Notebook에 액세스하십시오.
때로는 Jupyter Notebook 이 로딩을 완료하는 데 몇 초 정도 기다려야 할 수 있습니다. Jupyter Notebook 의 제한 사항으로 인해 작업의 유효성 검사는 자동화할 수 없습니다.
학습 중에 문제가 발생하면 Labby 에게 문의하십시오. 세션 후 피드백을 제공하면 문제를 즉시 해결해 드리겠습니다.
필요한 라이브러리 가져오기
이 튜토리얼에 필요한 라이브러리, 즉 Matplotlib 을 가져오는 것으로 시작합니다.
import matplotlib.pyplot as plt
축 주석 함수 정의
각 기본 3D 뷰 평면에 해당 각도를 레이블링하기 위해 나중에 사용할 annotate_axes 함수를 정의합니다.
def annotate_axes(ax, text, fontsize=18):
ax.text(x=0.5, y=0.5, z=0.5, s=text,
va="center", ha="center", fontsize=fontsize, color="black")
기본 3D 뷰 평면과 해당 각도 정의
기본 3D 뷰 평면과 해당 고도 (elevation), 방위각 (azimuth), 롤 (roll) 각도를 정의합니다.
views = [('XY', (90, -90, 0)),
('XZ', (0, -90, 0)),
('YZ', (0, 0, 0)),
('-XY', (-90, 90, 0)),
('-XZ', (0, 90, 0)),
('-YZ', (0, 180, 0))]
3D 플롯 레이아웃 정의
리스트의 리스트를 사용하여 3D 플롯의 레이아웃을 정의합니다. 리스트의 '.'는 빈 서브플롯을 나타냅니다.
layout = [['XY', '.', 'L', '.'],
['XZ', 'YZ', '-XZ', '-YZ'],
['.', '.', '-XY', '.']]
3D 플롯 생성
4 단계에서 정의된 레이아웃을 기반으로 subplot_mosaic를 사용하여 3D 플롯을 생성합니다.
fig, axd = plt.subplot_mosaic(layout, subplot_kw={'projection': '3d'},
figsize=(12, 8.5))
각 기본 3D 뷰 평면의 속성 설정
x, y, z 축의 레이블, 투영 유형 및 뷰 각도를 포함하여 각 기본 3D 뷰 평면의 속성을 설정합니다.
for plane, angles in views:
axd[plane].set_xlabel('x')
axd[plane].set_ylabel('y')
axd[plane].set_zlabel('z')
axd[plane].set_proj_type('ortho')
axd[plane].view_init(elev=angles[0], azim=angles[1], roll=angles[2])
axd[plane].set_box_aspect(None, zoom=1.25)
각 기본 3D 뷰 평면에 레이블 지정
2 단계에서 정의된 annotate_axes 함수를 사용하여 각 기본 3D 뷰 평면에 해당 각도로 레이블을 지정합니다.
for plane, angles in views:
label = f'{plane}\n{angles}'
annotate_axes(axd[plane], label, fontsize=14)
각 기본 3D 뷰 평면에 대한 눈금 레이블 및 축 레이블 사용자 정의
불필요한 레이블을 제거하기 위해 각 기본 3D 뷰 평면에 대한 눈금 레이블 및 축 레이블을 사용자 정의합니다.
for plane in ('XY', '-XY'):
axd[plane].set_zticklabels([])
axd[plane].set_zlabel('')
for plane in ('XZ', '-XZ'):
axd[plane].set_yticklabels([])
axd[plane].set_ylabel('')
for plane in ('YZ', '-YZ'):
axd[plane].set_xticklabels([])
axd[plane].set_xlabel('')
중앙 서브플롯에 레이블 추가
이것이 기본 3D 뷰 평면 플롯임을 나타내기 위해 중앙 서브플롯에 레이블을 추가합니다.
label = 'mplot3d primary view planes\n' + 'ax.view_init(elev, azim, roll)'
annotate_axes(axd['L'], label, fontsize=18)
axd['L'].set_axis_off()
3D 플롯 표시
plt.show()를 사용하여 3D 플롯을 표시합니다.
plt.show()
요약
이 튜토리얼에서는 Matplotlib 을 사용하여 각 기본 3D 뷰 평면을 보여주는 "전개된" 3D 플롯을 생성하는 방법을 배웠습니다. 또한 각 뷰에 필요한 고도 (elevation), 방위각 (azimuth), 롤 (roll) 각도에 레이블을 지정하고 각 기본 3D 뷰 평면에 대한 눈금 레이블과 축 레이블을 사용자 정의했습니다. 이 이미지는 인쇄하여 각 평면이 상자의 한 면을 형성하는 상자로 접을 수 있습니다.