溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

NumPy中的Broadcasting廣播機(jī)制是什么

發(fā)布時(shí)間:2021-05-31 09:51:15 來源:億速云 閱讀:131 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹NumPy中的Broadcasting廣播機(jī)制是什么,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

廣播機(jī)制概述

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

numpy操作通常是逐個(gè)元素完成的,這就需要兩個(gè)數(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.])

當(dāng)數(shù)組的形狀滿足某些條件時(shí),numpy的廣播規(guī)則將放寬這種數(shù)組限制。 將數(shù)組和標(biāo)量值在一起運(yùn)算時(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.])

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

NumPy中的Broadcasting廣播機(jī)制是什么

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

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

廣播機(jī)制規(guī)則

廣播規(guī)則

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

問題來了,尾軸是什么?

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

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

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

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

Image(3d array)256 x256 x3
Scale(1d array)

3
Result(3d array)256 x256 x3

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

A(4d array)8 x1 x6 x1
B(3d array)
7 x1 x5
Result(4d array)8 x7 x6 x5

下面,是幾個(gè)代碼例子和圖形表示,有助于使廣播規(guī)則直觀明了。例3將一個(gè)一維數(shù)組添加到一個(gè)二維數(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中,當(dāng)b的列維度大于a的時(shí),由于形狀不兼容而引發(fā)異常。

NumPy中的Broadcasting廣播機(jī)制是什么

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

當(dāng)數(shù)組的尾部不相等時(shí),廣播將失敗,因?yàn)闊o法將第一個(gè)數(shù)組的行中的值與第二個(gè)數(shù)組的元素對齊進(jìn)行逐元素加法。

NumPy中的Broadcasting廣播機(jī)制是什么

廣播提供了一種獲取兩個(gè)數(shù)組的外部乘積(或任何其他外部操作)的便捷方法。 下面的示例顯示兩個(gè)1維數(shù)組的外部加法運(yùn)算,其結(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索引運(yùn)算符將一個(gè)新軸插入,使其成為二維4x1數(shù)組。 圖4說明了兩個(gè)陣列的拉伸以產(chǎn)生所需的4x3輸出陣列。

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

NumPy中的Broadcasting廣播機(jī)制是什么

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

以上是“NumPy中的Broadcasting廣播機(jī)制是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI