scipy.stats.

gmean#

scipy.stats.gmean(a, axis=0, dtype=None, weights=None, *, nan_policy='propagate', keepdims=False)[原始碼]#

計算沿指定軸的加權幾何平均數。

陣列 \(a_i\) 關聯於權重 \(w_i\) 的加權幾何平均數為

\[\exp \left( \frac{ \sum_{i=1}^n w_i \ln a_i }{ \sum_{i=1}^n w_i } \right) \, ,\]

且,在等權重下,其為

\[\sqrt[n]{ \prod_{i=1}^n a_i } \, .\]
參數:
aarray_like

輸入陣列或可轉換為陣列的物件。

axis整數或 None,預設值:0

若為整數,則為計算統計量的輸入軸。輸入的每個軸切片(例如,列)的統計量將出現在輸出的對應元素中。若為 None,則輸入將在計算統計量之前被展平。

dtypedtype,選用

在執行計算之前,輸入陣列將被轉換成的類型。

weightsarray_like,選用

weights 陣列必須可廣播為與 a 相同的形狀。預設值為 None,這會給予每個值權重 1.0。

nan_policy{‘propagate’, ‘omit’, ‘raise’}

定義如何處理輸入的 NaN。

  • propagate: 若在計算統計量的軸切片(例如,列)中存在 NaN,則輸出的對應條目將為 NaN。

  • omit: NaN 將在執行計算時被忽略。若在計算統計量的軸切片中剩餘的資料不足,則輸出的對應條目將為 NaN。

  • raise: 若存在 NaN,將引發 ValueError

keepdims布林值,預設值:False

若設定為 True,則縮減的軸將保留在結果中作為大小為一的維度。使用此選項,結果將針對輸入陣列正確廣播。

回傳值:
gmeanndarray

請參閱上方的 dtype 參數。

另請參閱

numpy.mean

算術平均數

numpy.average

加權平均數

hmean

調和平均數

說明

樣本幾何平均數是觀測值自然對數平均數的指數。負觀測值將在輸出中產生 NaN,因為自然對數(相對於複數對數)僅針對非負實數定義。

從 SciPy 1.9 開始,np.matrix 輸入(不建議用於新程式碼)會在執行計算之前轉換為 np.ndarray。在這種情況下,輸出將是純量或適當形狀的 np.ndarray,而不是 2D np.matrix。同樣地,雖然遮罩陣列的遮罩元素會被忽略,但輸出將是純量或 np.ndarray,而不是 mask=False 的遮罩陣列。

參考文獻

[1]

“加權幾何平均數”, 維基百科, https://en.wikipedia.org/wiki/Weighted_geometric_mean.

[2]

Grossman, J., Grossman, M., Katz, R., “Averages: A New Approach”, Archimedes Foundation, 1983

範例

>>> from scipy.stats import gmean
>>> gmean([1, 4])
2.0
>>> gmean([1, 2, 3, 4, 5, 6, 7])
3.3800151591412964
>>> gmean([1, 4, 7], weights=[3, 1, 3])
2.80668351922014