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

NumPy隨機數(shù)據(jù)分布與Seaborn可視化詳解

 更新時間:2024年05月22日 08:32:14   作者:小萬哥丶  
數(shù)據(jù)分布是指數(shù)據(jù)集中所有可能值出現(xiàn)的頻率,并用概率來表示,它描述了數(shù)據(jù)取值的可能性,Seaborn 是一個基于 Matplotlib 的 Python 數(shù)據(jù)可視化庫,用于創(chuàng)建統(tǒng)計圖表,本文就給大家詳細的介紹一下NumPy隨機數(shù)據(jù)分布與Seaborn可視化,需要的朋友可以參考下

隨機數(shù)據(jù)分布

什么是數(shù)據(jù)分布?

數(shù)據(jù)分布是指數(shù)據(jù)集中所有可能值出現(xiàn)的頻率,并用概率來表示。它描述了數(shù)據(jù)取值的可能性。

在統(tǒng)計學和數(shù)據(jù)科學中,數(shù)據(jù)分布是分析數(shù)據(jù)的重要基礎(chǔ)。

NumPy 中的隨機分布

NumPy 的 random 模塊提供了多種方法來生成服從不同分布的隨機數(shù)。

生成離散分布隨機數(shù)

choice(a, p, size):從數(shù)組 a 中隨機選擇元素,并根據(jù)概率 p 進行選擇。 a:源數(shù)組,包含所有可能值。 p:每個值的概率數(shù)組,總和必須為 1。 size:輸出數(shù)組的形狀。

示例:生成 100 個隨機數(shù),其中 3 出現(xiàn)的概率為 0.2,5 出現(xiàn)的概率為 0.4,7 出現(xiàn)的概率為 0.3,9 出現(xiàn)的概率為 0.1:

import numpy as np

x = np.random.choice([3, 5, 7, 9], p=[0.2, 0.4, 0.3, 0.1], size=100)
print(x)

生成連續(xù)分布隨機數(shù)

NumPy 提供了多種方法來生成服從不同連續(xù)分布的隨機數(shù),例如正態(tài)分布、均勻分布、指數(shù)分布等。

randn(size):生成服從標準正態(tài)分布的隨機數(shù)。 rand(size):生成服從均勻分布的隨機數(shù)。 beta(a, b, size):生成服從 Beta 分布的隨機數(shù)。 gamma(shape, scale, size):生成服從 Gamma 分布的隨機數(shù)。 poisson(lam, size):生成服從泊松分布的隨機整數(shù)。

示例:生成 10 個服從標準正態(tài)分布的隨機數(shù):

import numpy as np

x = np.random.randn(10)
print(x)

隨機排列

洗牌數(shù)組

shuffle(arr):對數(shù)組 arr 進行隨機洗牌,修改原始數(shù)組。

示例:隨機洗牌數(shù)組 [1, 2, 3, 4, 5]

import numpy as np
from numpy.random import shuffle

arr = np.array([1, 2, 3, 4, 5])

shuffle(arr)
print(arr)

生成數(shù)組的隨機排列

permutation(arr):生成數(shù)組 arr 元素的隨機排列,不修改原始數(shù)組。

示例:生成數(shù)組 [1, 2, 3, 4, 5] 的隨機排列:

import numpy as np
from numpy.random import permutation

arr = np.array([1, 2, 3, 4, 5])

x = permutation(arr)
print(x)

練習

  • 使用 choice 方法生成 200 個隨機數(shù),其中 1 出現(xiàn)的概率為 0.1,2 出現(xiàn)的概率為 0.2,3 出現(xiàn)的概率為 0.7。
  • 生成 10 個服從指數(shù)分布的隨機數(shù)。
  • 對數(shù)組 [10, 20, 30, 40, 50] 進行隨機洗牌。
  • 生成數(shù)組 [6, 7, 8, 9, 10] 元素的隨機排列。

解決方案

import numpy as np
from numpy.random import choice, permutation, expon

# 1. 使用 choice 方法生成隨機數(shù)
random_numbers = choice([1, 2, 3], p=[0.1, 0.2, 0.7], size=200)
print(random_numbers)

# 2. 生成服從指數(shù)分布的隨機數(shù)
exponential_randoms = expon(scale=1, size=10)
print(exponential_randoms)

# 3. 對數(shù)組進行隨機洗牌
arr = np.array([10, 20, 30, 40, 50])
shuffle(arr)
print(arr)

# 4. 生成數(shù)組的隨機排列
random_permutation = permutation([6, 7, 8, 9, 10])
print(random_permutation)

使用 Seaborn 可視化分布

簡介

Seaborn 是一個基于 Matplotlib 的 Python 數(shù)據(jù)可視化庫,用于創(chuàng)建統(tǒng)計圖表。它提供了一系列高級繪圖函數(shù),可以輕松創(chuàng)建美觀且信息豐富的統(tǒng)計圖形。

安裝 Seaborn

如果您已經(jīng)安裝了 Python 和 pip,可以使用以下命令安裝 Seaborn:

pip install seaborn

如果您使用的是 Jupyter Notebook,可以使用以下命令安裝 Seaborn:

!pip install seaborn

繪制分布圖

分布圖是一種可視化數(shù)據(jù)分布的圖表。它顯示了數(shù)據(jù)集中每個值的出現(xiàn)頻率。

在 Seaborn 中,可以使用 sns.distplot() 函數(shù)繪制分布圖。該函數(shù)接受以下參數(shù):

data:要繪制分布的數(shù)據(jù)??梢允菙?shù)組、列表或 Pandas 數(shù)據(jù)框。 hist:如果為 True(默認),則繪制直方圖;如果為 False,則只繪制密度曲線。 kde:如果為 True(默認),則使用核密度估計 (KDE) 來估計數(shù)據(jù)的分布;如果為 False,則使用直方圖。 bins:用于創(chuàng)建直方圖的直方圖數(shù)量。 norm:用于規(guī)范分布的類型。例如,norm='kde' 將使用 KDE 來規(guī)范分布。

示例:繪制正態(tài)分布

以下示例演示如何使用 Seaborn 繪制正態(tài)分布:

import seaborn as sns
import numpy as np

# 生成隨機數(shù)據(jù)
data = np.random.randn(1000)

# 繪制分布圖
sns.distplot(data)
plt.show()

該代碼將生成 1000 個服從標準正態(tài)分布的隨機數(shù),并使用 Seaborn 繪制它們的分布圖。

示例:繪制自定義分布

以下示例演示如何繪制自定義分布:

import seaborn as sns
import numpy as np

# 生成自定義數(shù)據(jù)
data = [1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 6, 7, 7, 8, 9]

# 繪制分布圖
sns.distplot(data, hist=False, kde=False)
plt.show()

該代碼將生成一個包含重復(fù)值的自定義數(shù)據(jù)數(shù)組,并使用 Seaborn 繪制它們的分布圖,不顯示直方圖或密度曲線。

練習

  • 生成 500 個服從均勻分布的隨機數(shù),并繪制它們的分布圖。
  • 生成 1000 個服從指數(shù)分布的隨機數(shù),并繪制它們的分布圖。
  • 從以下數(shù)據(jù)中繪制分布圖:
data = [23, 37, 43, 29, 31, 32, 36, 27, 31, 33, 34, 25, 27, 28, 42, 38, 27, 27, 33, 31, 26, 29, 31, 35, 33, 30, 30, 32, 36, 28, 31, 33, 38, 29, 31, 31, 34, 36, 26, 25, 26, 34, 37, 28, 36, 31, 29, 31, 27, 28, 32, 37, 30, 33, 33, 27, 31, 32, 32, 36, 25, 32, 35, 37, 37, 30, 31, 34, 33, 29, 32, 31, 36, 26, 29, 31, 37, 28, 28, 37, 31, 32, 36, 33, 27, 31, 32, 33, 32, 32, 30, 27, 36, 38, 35, 26, 32, 37, 31, 30, 33, 30, 27, 

到此這篇關(guān)于NumPy隨機數(shù)據(jù)分布與Seaborn可視化詳解的文章就介紹到這了,更多相關(guān)NumPy數(shù)據(jù)分布與Seaborn內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python實現(xiàn)的搖骰子猜大小功能小游戲示例

    Python實現(xiàn)的搖骰子猜大小功能小游戲示例

    這篇文章主要介紹了Python實現(xiàn)的搖骰子猜大小功能小游戲,涉及Python隨機數(shù)運算與數(shù)值判斷相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • 使用Python防止SQL注入攻擊的實現(xiàn)示例

    使用Python防止SQL注入攻擊的實現(xiàn)示例

    這篇文章主要介紹了使用Python防止SQL注入攻擊的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • Python實現(xiàn)在線批量美顏功能過程解析

    Python實現(xiàn)在線批量美顏功能過程解析

    這篇文章主要介紹了Python實現(xiàn)在線批量美顏功能過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • Python中self關(guān)鍵字的用法解析

    Python中self關(guān)鍵字的用法解析

    在Python中,self是一個經(jīng)常出現(xiàn)的關(guān)鍵字,特別是在類定義中的方法,這篇文章主要和大家self的作用和用法,希望可以幫助大家更好地理解為什么需要它以及如何正確使用它
    2023-11-11
  • jupyter notebook 的工作空間設(shè)置操作

    jupyter notebook 的工作空間設(shè)置操作

    這篇文章主要介紹了jupyter notebook 的工作空間設(shè)置操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 解決pycharm不能自動補全第三方庫的函數(shù)和屬性問題

    解決pycharm不能自動補全第三方庫的函數(shù)和屬性問題

    這篇文章主要介紹了解決pycharm不能自動補全第三方庫的函數(shù)和屬性問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • python實現(xiàn)的漢諾塔算法示例

    python實現(xiàn)的漢諾塔算法示例

    這篇文章主要介紹了python實現(xiàn)的漢諾塔算法,結(jié)合實例形式分析了漢諾塔算法的原理、實現(xiàn)方法及相關(guān)操作注意事項,需要的朋友可以參考下
    2019-10-10
  • Python Docx庫完美操作word文檔實例探究

    Python Docx庫完美操作word文檔實例探究

    這篇文章主要為大家介紹了Python Docx庫完美操作word文檔,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • Python3 執(zhí)行Linux Bash命令的方法

    Python3 執(zhí)行Linux Bash命令的方法

    今天小編就為大家分享一篇Python3 執(zhí)行Linux Bash命令的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python保留數(shù)據(jù)并刪除Excel單元格的函數(shù)和公式

    Python保留數(shù)據(jù)并刪除Excel單元格的函數(shù)和公式

    在分析處理Excel表格時,我們可能需要使用各種公式或函數(shù)對表格數(shù)據(jù)進行計算,從而分析出更多的信息,但在展示、分享或再利用分析結(jié)果時,我們可能需要將含有公式的單元格轉(zhuǎn)換為靜態(tài)數(shù)值,本文將介紹如何使用Python代碼批量移除Excel單元格中的公式并保留數(shù)值
    2024-10-10

最新評論