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
,而不是 2Dnp.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