主頁 > 知識庫 > 深入解析NumPy中的Broadcasting廣播機制

深入解析NumPy中的Broadcasting廣播機制

熱門標簽:小蘇云呼電話機器人 市場上的電銷機器人 朝陽手機外呼系統(tǒng) 所得系統(tǒng)電梯怎樣主板設(shè)置外呼 地圖標注面積 北京電銷外呼系統(tǒng)加盟 儋州電話機器人 佛山400電話辦理 北瀚ai電銷機器人官網(wǎng)手機版

前言

在吳恩達老師的深度學習專項課程中,老師有提到NumPy中的廣播機制,同時那一周的測驗也有涉及到廣播機制的題目。那么,到底什么是NumPy中的廣播機制?

官方文檔

接下來到了看官方文檔的時間。

Array Broadcasting in Numpy

廣播機制概述

讓我們探索numpy中一個更高級的概念,這個概念被稱為廣播。 廣播展現(xiàn)了NumPy在算術(shù)運算期間是如何處理具有不同形狀的數(shù)組的。 受到某些約束,較小的陣列將在較大的陣列上“廣播”,以使它們具有相同形狀。 廣播提供了一種數(shù)組矢量化操作,從而使得循環(huán)在C而不是Python中發(fā)生。 它無需復制不必要的數(shù)據(jù)即可完成,并且通常算法的效率還挺高。 當然在某些情況下,廣播并不是一個好辦法,因為它會導致內(nèi)存使用效率低,從而減慢計算速度。 本文通過示例,對廣播進行了詳盡的介紹。 它還提供何時使用廣播的提示。

numpy操作通常是逐個元素完成的,這就需要兩個數(shù)組具有完全相同的形狀

Example 1

>>> from numpy import array
>>> a = array([1.0, 2.0, 3.0])
>>> b = array([2.0, 2.0, 2.0])
>>> a * b
array([ 2.,  4.,  6.])

當數(shù)組的形狀滿足某些條件時,numpy的廣播規(guī)則將放寬這種數(shù)組限制。 將數(shù)組和標量值在一起運算時,會出現(xiàn)最簡單的廣播示例

Example 2

>>> from numpy import array
>>> a = array([1.0,2.0,3.0])
>>> b = 2.0
>>> a * b
array([ 2.,  4.,  6.])

盡管只有一個變量是數(shù)組,但是結(jié)果和之前的一個代碼例子是一樣的。 我們可以認為其中的標量在算術(shù)運算中被拓展成與數(shù)組a變量形狀相同的數(shù)組。 例如下圖中顯示的中拓展的新元素只是原始標量的副本。這種拓展只是概念上的。 numpy的明智之處在于使用原始標量值而不必要創(chuàng)建副本,從而使廣播操作盡可能地節(jié)省內(nèi)存提高計算效率。 由于上面的代碼例子中,乘法過程中標量移動的內(nèi)存較少,所以在具有一百萬個元素數(shù)組的Windows 2000上,廣播機制與之前的兩個數(shù)組相加相比大概快10%。

在最簡單的廣播示例中,標量b被拉伸為與a相同形狀的數(shù)組,使得這些形狀適用于逐元素乘法。

下面的規(guī)則決定了兩個具有兼容形狀的數(shù)組是否可以在單個代碼段中進行廣播。

廣播機制規(guī)則

廣播規(guī)則

為了廣播,操作中兩個陣列的尾軸的大小必須相同,或者其中一個必須是一個。

問題來了,尾軸是什么?

為此我找到了python - numpy broadcasting - explanation of trailing axes - Stack Overflow這篇解答。

If you have two arrays with different dimensions number, say one 1x2x3 and other 2x3, then you compare only the trailing common dimensions, in this case 2x3. But if both your arrays are two-dimensional, then their corresponding sizes have to be either equal or one of them has to be 1.

In your case you have a 2x2 and 4x2 and 4 != 2 and neither 4 or 2 equals 1, so this doesn't work.

假設(shè)你有兩個不同維度的數(shù)組。一個是1x2x3,另一個是2x3,那么只需要比較后面的公共尺寸,在這種情況下為2x3。 但是,**如果兩個數(shù)組都是二維的,則它們的對應(yīng)大小必須相等或其中之一必須為1 **。

在兩個二維數(shù)組中2x2和4x2,4!= 2,并且4或2都不等于1,所以廣播行不通的。

這個解釋應(yīng)該比較清楚了。

如果不滿足此條件,則會引發(fā)異常,提示數(shù)組的形狀不兼容。 廣播操作創(chuàng)建的結(jié)果數(shù)組的大小是兩個數(shù)組中每個維度的最大大小。 請注意,該規(guī)則并未說明需要具有相同維數(shù)的兩個數(shù)組。 如果有一個256 x 256 x 3的RGB值數(shù)組,想要按不同的值縮放圖像中的每種顏色,則可以將圖像乘以具有3個值的一維數(shù)組。

Image (3d array) 256 x 256 x 3
Scale (1d array) 3
Result (3d array) 256 x 256 x 3

在下面的示例中,兩個數(shù)組都具有長度為1的軸,這些軸在廣播操作中被擴展為更大的大小。

A (4d array) 8 x 1 x 6 x 1
B (3d array) 7 x 1 x 5
Result (4d array) 8 x 7 x 6 x 5

下面,是幾個代碼例子和圖形表示,有助于使廣播規(guī)則直觀明了。例3將一個一維數(shù)組添加到一個二維數(shù)組。

Example 3

>>> from numpy import array
>>> a = array([[ 0.0,  0.0,  0.0],
...            [10.0, 10.0, 10.0],
...            [20.0, 20.0, 20.0],
...            [30.0, 30.0, 30.0]])
>>> b = array([1.0, 2.0, 3.0])
>>> a + b
array([[  1.,   2.,   3.],
       [ 11.,  12.,  13.],
       [ 21.,  22.,  23.],
       [ 31.,  32.,  33.]])

如下圖2所示,b將拓展維度大小和a一樣。在圖3中,當b的列維度大于a的時,由于形狀不兼容而引發(fā)異常。

如果一維數(shù)組元素的數(shù)量與二維數(shù)組列的數(shù)量匹配,則將二維數(shù)組乘以一維數(shù)組將導致廣播。

當數(shù)組的尾部不相等時,廣播將失敗,因為無法將第一個數(shù)組的行中的值與第二個數(shù)組的元素對齊進行逐元素加法。

廣播提供了一種獲取兩個數(shù)組的外部乘積(或任何其他外部操作)的便捷方法。 下面的示例顯示兩個1維數(shù)組的外部加法運算,其結(jié)果與示例3相同。

Example 4

>>> from numpy import array, newaxis
>>> a = array([0.0, 10.0, 20.0, 30.0])
>>> b = array([1.0, 2.0, 3.0])
>>> a[:,newaxis] + b
array([[  1.,   2.,   3.],
       [ 11.,  12.,  13.],
       [ 21.,  22.,  23.],
       [ 31.,  32.,  33.]])

在這里,newaxis索引運算符將一個新軸插入,使其成為二維4x1數(shù)組。 圖4說明了兩個陣列的拉伸以產(chǎn)生所需的4x3輸出陣列。

在這里例子里是b = array([1.0, 2.0, 3.0]),但是下圖中是0,1,2,emmmm…尊重原文吧!

在某些情況下,廣播會拉伸兩個陣列以形成一個比任何一個初始陣列都大的輸出陣列。

總結(jié)

以上是對官方文檔的翻譯,總的來說廣播機制主要是以下幾點:

  • 效率較快,性能較好
  • 廣播時,操作中兩個數(shù)組的尾軸的大小必須相同,或者其中之一必須是1
  • 如果兩個數(shù)組都是二維的,則它們的對應(yīng)大小必須相等或其中之一必須為1

通過這篇文章,你是否了解了NumPy的廣播機制呢?更多相關(guān)NumPy Broadcasting廣播機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Numpy數(shù)組的廣播機制的實現(xiàn)
  • numpy數(shù)組廣播的機制
  • 詳解Numpy中的廣播原則/機制

標簽:寧夏 云南 江蘇 定西 龍巖 酒泉 商丘 金融催收

巨人網(wǎng)絡(luò)通訊聲明:本文標題《深入解析NumPy中的Broadcasting廣播機制》,本文關(guān)鍵詞  深入,解析,NumPy,中的,Broadcasting,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入解析NumPy中的Broadcasting廣播機制》相關(guān)的同類信息!
  • 本頁收集關(guān)于深入解析NumPy中的Broadcasting廣播機制的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章