bundles / scipy latest / scipy / stats / _stats_py / expectile
function
scipy.stats._stats_py:expectile
source: /scipy/stats/_stats_py.py :10100
Signature
def expectile ( a , alpha = 0.5 , * , weights = None ) Summary
Compute the expectile at the specified level.
Extended Summary
Expectiles are a generalization of the expectation in the same way as quantiles are a generalization of the median. The expectile at level alpha = 0.5 is the mean (average). See Notes for more details.
Parameters
a: array_likeArray containing numbers whose expectile is desired.
alpha: float, default: 0.5The level of the expectile; e.g.,
alpha=0.5gives the mean.weights: array_like, optionalAn array of weights associated with the values in
a. Theweightsmust be broadcastable to the same shape asa. Default is None, which gives each value a weight of 1.0. An integer valued weight element acts like repeating the corresponding observation inathat many times. See Notes for more details.
Returns
expectile: ndarrayThe empirical expectile at level
alpha.
Notes
In general, the expectile at level of a random variable with cumulative distribution function (CDF) is given by the unique solution of:
Here, is the positive part of . This equation can be equivalently written as:
The empirical expectile at level (alpha) of a sample (the array a) is defined by plugging in the empirical CDF of a. Given sample or case weights (the array weights), it reads with indicator function . This leads to the definition of the empirical expectile at level alpha as the unique solution of:
For , this simplifies to the weighted average. Furthermore, the larger , the larger the value of the expectile.
As a final remark, the expectile at level can also be written as a minimization problem. One often used choice is
Array API Standard Support
expectile has experimental support for Python Array API Standard compatible backends in addition to NumPy. Please consider testing these features by setting an environment variable SCIPY_ARRAY_API=1 and providing CuPy, PyTorch, JAX, or Dask arrays as array arguments. The following combinations of backend and device (or other capability) are supported.
==================== ==================== ==================== Library CPU GPU ==================== ==================== ==================== NumPy ✅ n/a CuPy n/a ⛔ PyTorch ⛔ ⛔ JAX ⛔ ⛔ Dask ⛔ n/a ==================== ==================== ====================
See
dev-arrayapifor more information.
Examples
import numpy as np from scipy.stats import expectile a = [1, 4, 2, -1]✓
expectile(a, alpha=0.5) == np.mean(a) expectile(a, alpha=0.2) expectile(a, alpha=0.8)✗
weights = [1, 3, 1, 1]
✓expectile(a, alpha=0.8, weights=weights)
✗See also
- numpy.mean
Arithmetic average
- numpy.quantile
Quantile
Aliases
-
scipy.stats.expectile