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

python如何用matplotlib創(chuàng)建三維圖表

 更新時間:2021年01月26日 10:17:37   作者:Chen洋  
這篇文章主要介紹了python如何在matplotlib中創(chuàng)建三維圖表,幫助大家更好的利用python進行數據分析,感興趣的朋友可以了解下

Matplotlib 最開始被設計為僅支持二維的圖表。到 1.0 版本發(fā)布左右,一些三維圖表的工具在二維展示的基礎上被創(chuàng)建了出來,結果就是 Matplotlib 提供了一個方便的(同時也是有限的)的可用于三維數據可視化的一套工具。三維圖表可以使用載入mplot3d工具包來激活,這個包會隨著 Matplotlib 自動安裝:

from mpl_toolkits import mplot3d

一旦模塊被導入,三維 axes 就可以像其他普通 axes 一樣通過關鍵字參數projection='3d'來創(chuàng)建:

import numpy as np
import matplotlib.pyplot as plt
fig = plt.figure()
ax = plt.axes(projection='3d')
plt.show()

三維 axes 激活后,我們可以在上面繪制不同的三維圖表類型。三維圖表在 notebook 中使用交互式圖表展示會優(yōu)于使用靜態(tài)展示;回憶我們前面介紹過,你可以使用%matplotlib notebook而不是%matplotlib inline來激活交互式展示模式。

三維的點和線

三維圖表中最基礎的是使用(x, y, z)坐標定義的一根線或散點的集合。前面介紹過普通的二維圖表,作為類比,使用ax.plot3D和ax.scatter3D函數可以創(chuàng)建三維折線和散點圖。這兩個函數的簽名與二維的版本基本一致,你可以參考[簡單折線圖]和[簡單散點圖]來復習一下這部分的內容。下面我們繪制一個三維中的三角螺旋,在線的附近在繪制一些隨機的點:

ax = plt.axes(projection='3d')

# 三維螺旋線的數據
zline = np.linspace(0, 15, 1000)
xline = np.sin(zline)
yline = np.cos(zline)
ax.plot3D(xline, yline, zline, 'gray')

# 三維散點的數據
zdata = 15 * np.random.random(100)
xdata = np.sin(zdata) + 0.1 * np.random.randn(100)
ydata = np.cos(zdata) + 0.1 * np.random.randn(100)
ax.scatter3D(xdata, ydata, zdata, c=zdata, cmap='Greens');

注意默認情況下,圖中的散點會有透明度的區(qū)別,用于體現在圖中散點的深度。雖然三維效果在靜態(tài)圖像中難以顯示,你可以使用交互式的視圖來獲得更佳的三維直觀效果。

三維輪廓圖

類似于我們在[密度和輪廓圖]中介紹的內容,mplot3d也包含著能夠創(chuàng)建三維浮雕圖像的工具。就像二維的ax.contour圖表,ax.contour3D要求輸入數據的格式是二維普通網格上計算得到的 Z 軸的數據值。下面我們展示一個三維的正弦函數輪廓圖:

def f(x, y):
  return np.sin(np.sqrt(x ** 2 + y ** 2))

x = np.linspace(-6, 6, 30)
y = np.linspace(-6, 6, 30)

X, Y = np.meshgrid(x, y)
Z = f(X, Y)
fig = plt.figure()
ax = plt.axes(projection='3d')
ax.contour3D(X, Y, Z, 50, cmap='binary')
ax.set_xlabel('x')
ax.set_ylabel('y')
ax.set_zlabel('z');

有時候默認的視角角度不是最理想的,在這種情況下我們可以使用view_init函數來設置水平角和方位角。在下面的例子中,我們使用的是 60° 的水平角(即以 60° 俯視 x-y 平面)和 35° 的方位角(即將 z 軸逆時針旋轉 35°):

ax.view_init(60, 35)
fig

同樣,注意到當使用 Matplotlib 交互式展示是,這樣的旋轉可以通過鼠標點擊和拖拽來實現。

框線圖和表面圖

使用網格數據生成的三維圖表還有框線圖和表面圖。這兩種圖表將網格數據投射到特定的三維表面,能夠使得結果圖像非常直觀和具有說服力。下面是一個框線圖的例子:

fig = plt.figure()
ax = plt.axes(projection='3d')
ax.plot_wireframe(X, Y, Z, color='black')
ax.set_title('wireframe');

表面圖類似框線圖,區(qū)別在于每個框線構成的多邊形都使用顏色進行了填充。添加色圖用于填充多邊形能夠讓圖形表面展示出來:

ax = plt.axes(projection='3d')
ax.plot_surface(X, Y, Z, rstride=1, cstride=1,
        cmap='viridis', edgecolor='none')
ax.set_title('surface');

注意雖然每個顏色填充的表面都是二維的,但是表面的邊緣不需要是直線構成的。下面的例子使用surface3D繪制了一個部分極坐標網格,能夠讓我們切入到函數內部觀察效果:

r = np.linspace(0, 6, 20)
theta = np.linspace(-0.9 * np.pi, 0.8 * np.pi, 40)
r, theta = np.meshgrid(r, theta)

X = r * np.sin(theta)
Y = r * np.cos(theta)
Z = f(X, Y)

ax = plt.axes(projection='3d')
ax.plot_surface(X, Y, Z, rstride=1, cstride=1,
        cmap='viridis', edgecolor='none');

表面三角剖分

在一些應用場合中,上面的這種均勻網格繪制的圖表方式太過于局限和不方便。在這些情況下,三角剖分的圖表可以派上用場。如果我們并不是使用笛卡爾坐標系或極坐標系的網格來繪制三維圖表,而是使用一組隨機的點來繪制三維圖表呢?

theta = 2 * np.pi * np.random.random(1000)
r = 6 * np.random.random(1000)
x = np.ravel(r * np.sin(theta))
y = np.ravel(r * np.cos(theta))
z = f(x, y)
ax = plt.axes(projection='3d')
ax.scatter(x, y, z, c=z, cmap='viridis', linewidth=0.5);

上圖并未形象的表示出表面情況。這種情況下我們可以使用ax.plot_trisurf函數,它能首先根據我們的數據輸入找到各點內在的三角函數形式,然后繪制表面(注意的是這里的 x,y,z 是一維的數組):

ax = plt.axes(projection='3d')
ax.plot_trisurf(x, y, z,
        cmap='viridis', edgecolor='none');

上圖的結果很顯然沒有使用網格繪制表面圖那么清晰,但是對于我們并不是使用函數構建數據樣本(數據樣本通常來自真實世界的采樣)的情況下,這能提供很大的幫助。例如我們下面會看到,能使用這種方法繪制一條三維的莫比烏斯環(huán)。

例子:繪制莫比烏斯環(huán)

theta = np.linspace(0, 2 * np.pi, 30)
w = np.linspace(-0.25, 0.25, 8)
w, theta = np.meshgrid(w, theta)

phi = 0.5 * theta

現在我們已經有了所有需要獲得三維坐標值的參數了。我們定義  為每個坐標點距離環(huán)形中間的位置,使用它來計算最終(x,y,z)  三維坐標系的坐標值:

# r是坐標點距離環(huán)形中心的距離值
r = 1 + w * np.cos(phi)
# 利用簡單的三角函數知識算得x,y,z坐標值
x = np.ravel(r * np.cos(theta))
y = np.ravel(r * np.sin(theta))
z = np.ravel(w * np.sin(phi))

最后,為了繪制對象,我們必須保證三角剖分是正確的。實現這個最好的方法是在底層的參數上面實現三角剖分,最后讓 Matplotlib 將這個三角剖分投射到三維空間中形成莫比烏斯環(huán)。下面的代碼最終繪制圖形:

# 在底層參數的基礎上進行三角剖分
from matplotlib.tri import Triangulation
tri = Triangulation(np.ravel(w), np.ravel(theta))

ax = plt.axes(projection='3d')
ax.plot_trisurf(x, y, z, triangles=tri.triangles,
        cmap='viridis', linewidths=0.2);

ax.set_xlim(-1, 1); ax.set_ylim(-1, 1); ax.set_zlim(-1, 1);

 結合這些技巧,能夠為你提供在 Matplotlib 創(chuàng)建和展現大量三維對象和模式的能力。

以上就是python如何用matplotlib創(chuàng)建三維圖表的詳細內容,更多關于python用matplotlib創(chuàng)建三維圖表的資料請關注腳本之家其它相關文章!

相關文章

  • Python如何將LabelMe生成的JSON格式轉換成YOLOv8支持的TXT格式

    Python如何將LabelMe生成的JSON格式轉換成YOLOv8支持的TXT格式

    標注工具 LabelMe 生成的標注文件為JSON格式,而YOLOv8中支持的為TXT文件格式,下面給大家分享Python如何將LabelMe生成的JSON格式轉換成YOLOv8支持的TXT格式,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • Python3中FuzzyWuzzy庫實例用法

    Python3中FuzzyWuzzy庫實例用法

    在本篇文章中小編給各位整理了關于Python3z中FuzzyWuzzy庫實例用法及相關代碼,有興趣的朋友們可以參考下。
    2020-11-11
  • tensorflow實現將ckpt轉pb文件的方法

    tensorflow實現將ckpt轉pb文件的方法

    這篇文章主要介紹了tensorflow實現將ckpt轉pb文件的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Python中的len()函數是什么意思

    Python中的len()函數是什么意思

    這篇文章主要介紹了Python中的len()函數是什么意思以及l(fā)en()函數使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 淺談python數據類型及其操作

    淺談python數據類型及其操作

    今天帶大家了解python數據類型的相關知識,文中介紹的非常詳細,對正在學習python的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05
  • Python random模塊的使用示例

    Python random模塊的使用示例

    這篇文章主要介紹了Python random模塊的使用示例,幫助大家更好的理解和使用python生成隨機數,感興趣的朋友可以了解下
    2020-10-10
  • Python 列表中的修改、添加和刪除元素的實現

    Python 列表中的修改、添加和刪除元素的實現

    這篇文章主要介紹了Python 列表中的修改、添加和刪除元素的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • python opencv 二值化 計算白色像素點的實例

    python opencv 二值化 計算白色像素點的實例

    今天小編就為大家分享一篇python opencv 二值化 計算白色像素點的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 分享Python開發(fā)中要注意的十個小貼士

    分享Python開發(fā)中要注意的十個小貼士

    不管是python開發(fā)還是其他什么語言的開發(fā),如果在開發(fā)中我們能掌握一些有用的貼士和技巧,那么肯定會大大提高我們的開發(fā)效率,今天小編和大家分享的就是python開發(fā)中,一些初學這門語言常常會犯的錯誤,一起來看看吧。
    2016-08-08
  • Python使用asyncio包處理并發(fā)的實現代碼

    Python使用asyncio包處理并發(fā)的實現代碼

    這篇文章主要介紹了Python使用asyncio包處理并發(fā),asyncio包使用事件循環(huán)驅動的協(xié)程實現并發(fā),本文通過實例代碼給大家介紹的非常詳細對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12

最新評論