亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python?Matplotlib實現(xiàn)三維數(shù)據(jù)的散點圖繪制

 更新時間:2022年04月21日 12:24:07   作者:清水寺種辣椒  
這篇文章主要為大家詳細(xì)介紹了Python?Matplotlib實現(xiàn)三維數(shù)據(jù)的散點圖繪制,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

一、背景

近期項目即將開展,計劃第一步就是實現(xiàn)數(shù)據(jù)的可視化,所以先學(xué)習(xí)一下數(shù)據(jù)展示相關(guān)Demo。選用Python2.7與Matplotlib來實現(xiàn),平臺采用Pycharm,值得一提的是,Matplotlib的安裝前首先要安裝Numpy包,但是在完成Numpy的安裝之后,樓主不能在PyCharm平臺下進(jìn)行自動安裝,或者CMD中使用類似pip install Matplotlib,參考網(wǎng)上解決方案后采用直接去官網(wǎng)下載相應(yīng)的安裝包直接運行安裝到相關(guān)目錄下。在此就不贅述了。

二、 參考

Python語言相對于其他語言對新手較為友好,不用花費太多時間進(jìn)行語法學(xué)習(xí),但是在實際使用的過程中,因為Python中包含有大量的包與資源,在做項目時,對于功能的堆積,實際上Python語言對于新手并不易于理解。相對于Java與C++是需要開發(fā)者從底層搭建,可能更易于理解修改(個人意見)。

Matplotlib的gallery部分

三、實現(xiàn)過程

其中就有我們需要參考的部分,也就是mplot3d example code : 2dcollections3d_demo.py。下面貼出其中的代碼段。

"""
=======================
Plot 2D data on 3D plot
=======================

Demonstrates using ax.plot's zdir keyword to plot 2D data on
selective axes of a 3D plot.
"""

from mpl_toolkits.mplot3d import Axes3D
import numpy as np
import matplotlib.pyplot as plt

fig = plt.figure()
ax = fig.gca(projection='3d')

# Plot a sin curve using the x and y axes.
x = np.linspace(0, 1, 100)
y = np.sin(x * 2 * np.pi) / 2 + 0.5
ax.plot(x, y, zs=0, zdir='z', label='curve in (x,y)')

# Plot scatterplot data (20 2D points per colour) on the x and z axes.
colors = ('r', 'g', 'b', 'k')
x = np.random.sample(20*len(colors))
y = np.random.sample(20*len(colors))
c_list = []
for c in colors:
 c_list.append([c]*20)
# By using zdir='y', the y value of these points is fixed to the zs value 0
# and the (x,y) points are plotted on the x and z axes.
ax.scatter(x, y, zs=0, zdir='y', c=c_list, label='points in (x,z)')

# Make legend, set axes limits and labels
ax.legend()
ax.set_xlim(0, 1)
ax.set_ylim(0, 1)
ax.set_zlim(0, 1)
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')

# Customize the view angle so it's easier to see that the scatter points lie
# on the plane y=0
ax.view_init(elev=20., azim=-35)

plt.show()

樣例的運行結(jié)果大致如下:

首先樣例的數(shù)據(jù)來自于隨機數(shù)的產(chǎn)生,但是在我實際使用的過程中,數(shù)據(jù)是需要預(yù)先存儲與導(dǎo)入的。因此我添加數(shù)據(jù)導(dǎo)入部分:

import scipy.io as sio
#get the data form F:\matlab.mat
data = sio.loadmat('F:\matlab.mat')
m = data['data']

值得一提的是這只是我測試的數(shù)據(jù),在實際應(yīng)用過程中,數(shù)據(jù)的格式是多種多樣的,所以需要做數(shù)據(jù)格式轉(zhuǎn)化的模塊。同時采用.mat數(shù)據(jù)的格式,用戶可以用matlab打開,并對數(shù)據(jù)進(jìn)行更改之類的操作。采用這種方法導(dǎo)入后,會自動形成數(shù)組。

如上圖所示,是數(shù)據(jù)在matlab中打開的形式,因為我們需要畫出三維散點圖,會自動產(chǎn)生3×60的數(shù)組,每行代表每一維的數(shù)據(jù)。貼一張做出的Demo的成果圖:   

因為我是用Time變量做為Xlabel,同時模擬數(shù)據(jù)是等時間間距進(jìn)行采樣的,同時想要在不同的時間點采用不同的顏色。因此需要對ax.scatter(x,y,z,c)中的c變量進(jìn)行更改,可以用變量代替,這樣就可以用個循環(huán)結(jié)構(gòu)實現(xiàn)顏色的切換功能。

for a in x:
 if a == 0.1:
  C.append('c')
 elif a == 0.2:
  C.append('r')
 elif a == 0.3:
  C.append('y')
 elif a == 0.4:
  C.append('k')
ax.scatter(x, y, z, c=C)

顏色切換部分代碼如下:

import scipy.io as sio
from mpl_toolkits.mplot3d import Axes3D
import matplotlib.pyplot as plt
import numpy as np

def Singleplot():
 data = sio.loadmat('F:\matlab.mat')
 m = data['data']

 x = m[0]
 y = m[1]
 z = m[2]

 C = []
 ax = plt.subplot(111, projection='3d')

 for a in x:
 if a == 0.1:
  C.append('c')
 elif a == 0.2:
  C.append('r')
 elif a == 0.3:
  C.append('y')
 elif a == 0.4:
  C.append('k')

 ax.scatter(x, y, z, c=C)

 ax.set_xlabel('Time')
 ax.set_ylabel('Frequence')
 ax.set_zlabel('Amplitude')

 plt.show()

singleplot()

需要注意的是Python是屬于相對集成度較高的語言,之所以方便使用,是因為存在許多大牛已經(jīng)完成底層的內(nèi)容,開發(fā)者只需要遵從下載的包中的使用規(guī)則,因此過程中對于許多函數(shù)不懂的地方,可以用Pycharm的Go to和Declaration功能進(jìn)入申明區(qū),并且可以從中看到函數(shù)的整體介紹,使用語法以及example。因此其中的功能較為有限,如果在短時間內(nèi)用Python做項目可能對于新手來說,由上到下的形式可能較為簡易,但是對于個性化定制功能的話還有待探究。

第一篇博客。記錄一下,本周將學(xué)習(xí)Logistic回歸預(yù)測,以及部分TensorFlow的原理與Demo,卡爾曼濾波,和一點數(shù)據(jù)融合算法。該篇屬于數(shù)據(jù)可視化,還會有3D柱狀圖的繪制與顯示將會盡快整理。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python多線程下信號處理程序示例

    python多線程下信號處理程序示例

    這篇文章主要為大家詳細(xì)介紹了python多線程下信號處理程序示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • python數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實例講解)

    python數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實例講解)

    下面小編就為大家?guī)硪黄猵ython數(shù)據(jù)結(jié)構(gòu)鏈表之單向鏈表(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Requests什么的通通爬不了的Python超強反爬蟲方案!

    Requests什么的通通爬不了的Python超強反爬蟲方案!

    今天帶大家學(xué)習(xí)Requests什么的通通爬不了的Python超強反爬蟲方案,文中有非常詳細(xì)的圖文介紹及代碼示例,對正在學(xué)習(xí)python的小伙伴們有很好的幫助,需要的朋友可以參考下
    2021-05-05
  • Python基礎(chǔ)教程之if判斷,while循環(huán),循環(huán)嵌套

    Python基礎(chǔ)教程之if判斷,while循環(huán),循環(huán)嵌套

    這篇文章主要介紹了Python基礎(chǔ)教程之if判斷,while循環(huán),循環(huán)嵌套 的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • python第三方庫easydict的使用實例詳解

    python第三方庫easydict的使用實例詳解

    在?Python?中當(dāng)我們需要訪問字典中的元素的時候,我們需要使用類似?a['example']?的形式來進(jìn)行使用,這個時候就可以使用 easydict 這個模塊了,今天通過本文給大家講解python第三方庫easydict的使用,感興趣的朋友跟隨小編一起看看吧
    2022-11-11
  • ERLANG和PYTHON互通實現(xiàn)過程詳解

    ERLANG和PYTHON互通實現(xiàn)過程詳解

    這篇文章主要介紹了ERLANG和PYTHON互通過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • 出現(xiàn)module 'queue' has no attribute 'Queue'問題的解決

    出現(xiàn)module 'queue' has no attrib

    這篇文章主要介紹了出現(xiàn)module 'queue' has no attribute 'Queue'問題的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Python 爬蟲多線程詳解及實例代碼

    Python 爬蟲多線程詳解及實例代碼

    這篇文章主要介紹了Python 爬蟲多線程詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • Python+Sklearn實現(xiàn)異常檢測

    Python+Sklearn實現(xiàn)異常檢測

    這篇文章主要為大家詳細(xì)介紹了Python如何利用Sklearn實現(xiàn)異常檢測,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Python有一定的幫助,感興趣的可以跟隨小編一起學(xué)習(xí)一下
    2022-12-12
  • python?Scala函數(shù)與訪問修辭符實例詳解

    python?Scala函數(shù)與訪問修辭符實例詳解

    這篇文章主要為大家介紹了python?Scala函數(shù)與訪問修辭符實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評論