欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python+Matplotlib繪制3D圖像的示例詳解

 更新時間:2022年04月14日 08:37:07   作者:侯小啾  
這篇文章主要為大家介紹了如何使用python matplotlib繪制繪制出一系列酷炫的3D圖像,例如:3D散點圖,3D曲線圖等,感興趣的可以了解一下

1. 繪制3D柱狀圖

繪制3D柱狀圖使用的是axes3d.bar()方法。

可能跟我們中學學的有一點不同的是,其語法如下:

bar(left, height, zs=0, zdir=‘z’, *args, **kwargs)

其中l(wèi)eft表示指向側(cè)邊的軸,zs表示指向我們的方向的軸,height即表示高度的軸。這三者都需要是一維的序列對象。
在調(diào)用相關(guān)方法的時候,比如設置軸標簽,還有一點需要區(qū)分的是,left對應的是y軸,zs對應的是x軸。(意思就是說,比如使用plt.xticks()方法,操作的是zs;而使用plt.yticks()方法則操作的是left軸。height對應著z軸。)

一段完整的代碼示例如下:

import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d.axes3d import Axes3D
import numpy as np
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
plt.rcParams['font.sans-serif'] = ['STKAITI']
# 創(chuàng)建畫布
fig = plt.figure()
# 創(chuàng)建3D坐標系
axes3d = Axes3D(fig)
zs = range(5)
left = np.arange(0, 10)
height = np.array([])
for i in range(len(zs)):
    z = zs[i]
    np.random.seed(i)
    height = np.random.randint(0, 30, size=10)
    axes3d.bar(left, height, zs=z, zdir='x',
               color=['red', 'green', 'purple', 'yellow', 'blue', 'black', 'gray', 'orange', 'pink', 'cyan'])
plt.xticks(zs, ['1月份', '2月份', '3月份', '4月份', '5月份'])
plt.yticks(left, ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'G'])
plt.xlabel('月份')
plt.ylabel('型號')
plt.show()

圖像效果如下: 

2. 繪制3D曲面圖

示例1

繪制曲面圖使用的是plot_surface()方法,這個方法的參數(shù)相對而言更簡單。且X、Y、Z三者的順序相對較為容易分辨。

通過讀示例代碼,即可快速掌握其用法:

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(10, 8), facecolor='#cc00ff')
ax = Axes3D(fig)
delta = 0.125
# 生成代表X軸數(shù)據(jù)的列表
x = np.arange(-4.0, 4.0, delta)
# 生成代表Y軸數(shù)據(jù)的列表
y = np.arange(-3.0, 4.0, delta)
# 對x、y數(shù)據(jù)執(zhí)行網(wǎng)格化
X, Y = np.meshgrid(x, y)

Z1 = np.exp(-X**2 - Y**2)
Z2 = np.exp(-(X - 1)**2 - (Y - 1)**2)
# 計算Z軸數(shù)據(jù)(高度數(shù)據(jù))
Z = (Z1 - Z2) * 2
# 繪制3D圖形
ax.plot_surface(X, Y, Z,
    rstride=1,  # rstride(row)指定行的跨度
    cstride=1,  # cstride(column)指定列的跨度
    cmap=plt.get_cmap('rainbow'))  # 設置顏色映射
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《曲面圖》', y=1.02, fontsize=25, color='gold')
# 設置Z軸范圍
ax.set_zlim(-2, 2)
plt.show()

示例2

更換一組數(shù)據(jù),呈現(xiàn)的則是另一種藝術(shù)效果:

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(12, 10), facecolor='#cc00ff')
ax = Axes3D(fig)
delta = 0.125
# 生成代表X軸數(shù)據(jù)的列表
x = np.linspace(-2, 2, 10)
# 生成代表Y軸數(shù)據(jù)的列表
y = np.linspace(-2, 2, 10)
# 對x、y數(shù)據(jù)執(zhí)行網(wǎng)格化
X, Y = np.meshgrid(x, y)

# 計算Z軸數(shù)據(jù)(高度數(shù)據(jù))
Z = X**2 - Y**2
# 繪制3D圖形
ax.plot_surface(X, Y, Z,
    rstride=1,  # rstride(row)指定行的跨度
    cstride=1,  # cstride(column)指定列的跨度
    cmap=plt.get_cmap('rainbow'))  # 設置顏色映射
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《曲面圖》', y=1.02, fontsize=25, color='gold')
plt.show()

3.繪制3D散點圖

在3D曲面圖示例1的基礎(chǔ)上稍作修改。

繪制散點圖使用scatter()方法,將散點顏色設置為綠色,紅色邊沿。

代碼示例如下:

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(10, 8), facecolor='#cc00ff')
ax = Axes3D(fig)
delta = 0.125
# 生成代表X軸數(shù)據(jù)的列表
x = np.arange(-4.0, 4.0, delta)
# 生成代表Y軸數(shù)據(jù)的列表
y = np.arange(-3.0, 4.0, delta)
# 對x、y數(shù)據(jù)執(zhí)行網(wǎng)格化
X, Y = np.meshgrid(x, y)

Z1 = np.exp(-X**2 - Y**2)
Z2 = np.exp(-(X - 1)**2 - (Y - 1)**2)
# 計算Z軸數(shù)據(jù)(高度數(shù)據(jù))
Z = (Z1 - Z2) * 2
# 繪制3D圖形
ax.scatter(X, Y, Z,
           c='green',
           edgecolors='red')
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《散點圖》', y=1.02, fontsize=25, color='gold')
# 設置Z軸范圍
ax.set_zlim(-2, 2)
plt.show()

繪圖效果如下:

4. 繪制3D曲線圖

繪制曲線圖,使用的則是我們最最最熟悉的plot()方法。

其他部分基本不變,數(shù)據(jù)部分生成三組適合我們繪圖的數(shù)據(jù),線條為金色,寬度設定為3.

代碼如下:

import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(10, 8), facecolor='#cc00ff')
ax = Axes3D(fig)
theta = np.linspace(0, 3.14*10, 1000)
r = np.linspace(0, 1, 1000)
x = r * np.cos(theta)
y = r * np.sin(theta)
z = np.linspace(0, 4, 1000)
ax.plot(x, y, z, color='gold', lw=3)
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《曲線圖》', y=1.02, fontsize=25, color='gold')
plt.show()

圖像效果如下:

以上就是Python+Matplotlib繪制3D圖像的示例詳解的詳細內(nèi)容,更多關(guān)于Python Matplotlib 3D圖像的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python動態(tài)參數(shù)用法實例分析

    python動態(tài)參數(shù)用法實例分析

    這篇文章主要介紹了python動態(tài)參數(shù)用法,以實例形式較為詳細的分析了Python中動態(tài)參數(shù)的功能及使用技巧,需要的朋友可以參考下
    2015-05-05
  • Python機器學習之決策樹

    Python機器學習之決策樹

    這篇文章主要介紹了Python機器學習之決策樹,文中有非常詳細的代碼示例,對正在學習python的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • Python實現(xiàn)打印金字塔圖案的方法詳解

    Python實現(xiàn)打印金字塔圖案的方法詳解

    使用簡單的?for?循環(huán)在?python?中打印模式。第一個外循環(huán)用于處理行數(shù),?而內(nèi)嵌套循環(huán)用于處理列數(shù)。操作打印語句,可以打印不同的數(shù)字圖案、字母圖案或星形圖案。本文將利用這些方法實現(xiàn)打印金字塔圖案,需要的可以參考一下
    2022-09-09
  • Python調(diào)用ChatGPT的API實現(xiàn)文章生成

    Python調(diào)用ChatGPT的API實現(xiàn)文章生成

    最近ChatGPT大火,在3.5版本后開放了接口API,所以很多人開始進行實操,這里我就用python來為大家實現(xiàn)一下,如何調(diào)用API并提問返回文章的說明
    2023-03-03
  • Python?讀取?Word?文檔操作

    Python?讀取?Word?文檔操作

    這篇文章主要介紹了Python讀取Word文檔操作,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • Python中requests、aiohttp、httpx性能比拼

    Python中requests、aiohttp、httpx性能比拼

    本文主要介紹了Python中requests、aiohttp、httpx性能比拼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 詳解Python安裝tesserocr遇到的各種問題及解決辦法

    詳解Python安裝tesserocr遇到的各種問題及解決辦法

    這篇文章主要介紹了詳解Python安裝tesserocr遇到的各種問題及解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • 詳解從Django Rest Framework響應中刪除空字段

    詳解從Django Rest Framework響應中刪除空字段

    這篇文章主要介紹了詳解從Django Rest Framework響應中刪除空字段,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • python實現(xiàn)顏色空間轉(zhuǎn)換程序(Tkinter)

    python實現(xiàn)顏色空間轉(zhuǎn)換程序(Tkinter)

    這篇文章主要介紹了基于Tkinter利用python實現(xiàn)顏色空間轉(zhuǎn)換程序,感興趣的小伙伴們可以參考一下
    2015-12-12
  • python使用PyGame模塊播放聲音的方法

    python使用PyGame模塊播放聲音的方法

    這篇文章主要介紹了python使用PyGame模塊播放聲音的方法,實例分析了PyGame模塊的使用技巧,需要的朋友可以參考下
    2015-05-05

最新評論