이 글에서는 3D 이미지를 그리는 데 사용되는 Matplotlib의 예제 코드를 주로 소개합니다. 관심이 있는 경우 학습할 수 있습니다.
Matplotlib은 2차원 이미지와 달리 3D 이미지도 그릴 수 있습니다. 주로 mplot3d 모듈을 통해 3차원 이미지를 그립니다. 그러나 Matplotlib을 사용하여 3차원 이미지를 그리는 것은 실제로 2차원 캔버스에 표시되므로 일반적으로 3차원 이미지를 그릴 때는 pyplot 모듈도 로드해야 합니다.
mplot3d 모듈에는 주로 4가지 주요 범주가 포함되어 있습니다.
3차원 산점도
import numpy as np # x, y, z 均为 0 到 1 之间的 100 个随机数 x = np.random.normal(0, 1, 100) y = np.random.normal(0, 1, 100) z = np.random.normal(0, 1, 100)
from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt두 번째 단계는 Axes3D()를 사용하여 3D 그래픽 개체를 만드는 것입니다.
fig = plt.figure() ax = Axes3D(fig)
마지막으로 산점도 그리기 메서드를 호출하여 그려서 표시합니다.
ax.scatter(x, y, z) plt.show()
3차원 꺾은선형 차트
# 载入模块 from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt import numpy as np # 生成数据 x = np.linspace(-6 * np.pi, 6 * np.pi, 1000) y = np.sin(x) z = np.cos(x) # 创建 3D 图形对象 fig = plt.figure() ax = Axes3D(fig) # 绘制线型图 ax.plot(x, y, z) # 显示图 plt.show()
3차원 막대 차트
꺾은선형 차트를 그린 후 계속해서 3차원 막대 차트를 그리려고 노력합니다. 실제로 그리는 단계도 위와 매우 유사합니다.
# 载入模块 from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt import numpy as np # 创建 3D 图形对象 fig = plt.figure() ax = Axes3D(fig) # 生成数据并绘图 x = [0, 1, 2, 3, 4, 5, 6] for i in x: y = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] z = abs(np.random.normal(1, 10, 10)) ax.bar(y, z, i, zdir='y', color=['r', 'g', 'b', 'y']) plt.show()
3차원 표면 그래프
다음으로 그려야 할 3차원 표면 그래프는 데이터에 대한 행렬 처리를 수행해야 합니다. 실제로 차원이 하나 더 추가된다는 점만 빼면 2차원 등고선 지도를 그리는 것과 매우 유사합니다.
# 载入模块 import numpy as np import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D # 创建 3D 图形对象 fig = plt.figure() ax = Axes3D(fig) # 生成数据 X = np.arange(-2, 2, 0.1) Y = np.arange(-2, 2, 0.1) X, Y = np.meshgrid(X, Y) Z = np.sqrt(X ** 2 + Y ** 2) # 绘制曲面图,并使用 cmap 着色 ax.plot_surface(X, Y, Z, cmap=plt.cm.winter) plt.show()cmap=plt.cm.winter는 겨울색상을 사용한다는 뜻인데, 아래 사진의 그라데이션 색상입니다.
혼합 그래프는 하나의 그래프에 서로 다른 두 가지 유형의 그래프를 그리는 것입니다. 혼합 다이어그램을 그리기 위해서는 일반적으로 전제 조건이 있습니다. 즉, 서로 다른 두 유형의 다이어그램의 범위가 대략 동일해야 합니다. 그렇지 않으면 심각한 비례 부조화가 발생하여 혼합 다이어그램이 의미가 없게 됩니다.
# -*- coding: utf-8 -* # 载入模块 from mpl_toolkits.mplot3d import Axes3D import numpy as np import matplotlib.pyplot as plt # 创建 3D 图形对象 fig = plt.figure() ax = Axes3D(fig) # 生成数据并绘制图 1 x1 = np.linspace(-3 * np.pi, 3 * np.pi, 500) y1 = np.sin(x1) ax.plot(x1, y1, zs=0, c='red') # 生成数据并绘制图 2 x2 = np.random.normal(0, 1, 100) y2 = np.random.normal(0, 1, 100) z2 = np.random.normal(0, 1, 100) ax.scatter(x2, y2, z2) # 显示图 plt.show()
# -*- coding: utf-8 -* # 载入模块 from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt import numpy as np # 创建 1 张画布 fig = plt.figure() #=============== # 向画布添加子图 1 ax1 = fig.add_subplot(1, 2, 1, projection='3d') # 生成子图 1 数据 x = np.linspace(-6 * np.pi, 6 * np.pi, 1000) y = np.sin(x) z = np.cos(x) # 绘制第 1 张图 ax1.plot(x, y, z) #=============== # 向画布添加子图 2 ax2 = fig.add_subplot(1, 2, 2, projection='3d') # 生成子图 2 数据 X = np.arange(-2, 2, 0.1) Y = np.arange(-2, 2, 0.1) X, Y = np.meshgrid(X, Y) Z = np.sqrt(X ** 2 + Y ** 2) # 绘制第 2 张图 ax2.plot_surface(X, Y, Z, cmap=plt.cm.winter) # 显示图 plt.show()이 코드를 살펴볼 수 있습니다. 두 개의 하위 사진은 하나의 캔버스에 그려지기 때문에 미리 캔버스를 생성해 주어야 합니다. 그런 다음 .add_subplot()을 통해 서브플롯을 추가합니다. 서브플롯 일련 번호는 2차원 플로팅과 유사합니다. 3D 플로팅을 수행할 때 project='3d' 매개변수를 추가해야 합니다.
위 내용은 Python에서 Matplotlib을 사용하여 3D 그래프를 그리는 방법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!