scipy.stats.Mixture.

ilogccdf#

Mixture.ilogccdf(p, /, *, method=None)[源代码]#

互补累积分布函数对数的反函数。

互补累积分布函数对数的反函数(“反向对数-CCDF”)是参数 \(x\),使得互补累积分布函数的对数 \(\log(G(x))\) 的计算结果为 \(\log(p)\)

在数学上,它等效于 \(G^{-1}(\exp(y))\),其中 \(y = \log(p)\),但与朴素实现(计算 \(p = \exp(y)\),然后 \(G^{-1}(p)\))相比,它在数值上可能更有利。

ilogccdf 接受 logp,其中 \(\log(p) ≤ 0\)

参数:
xarray_like

反向对数-CCDF 的参数。

method{None, ‘formula’, ‘complement’, ‘inversion’}

用于评估反向对数-CCDF 的策略。默认情况下(None),基础设施会从以下选项中进行选择,并按优先级排序。

  • 'formula':使用反向对数-CCDF 本身的公式

  • 'complement':在 x 的对数补码处评估反向对数-CDF(请参见注释)

  • 'inversion':数值求解使对数-CCDF 等于 x 的参数

并非所有分布都提供所有 method 选项。如果所选的 method 不可用,则会引发 NotImplementedError

返回:
outarray

在提供的参数处评估的反向对数-CCDF。

另请参阅

iccdf
ilogccdf

注释

假设一个连续概率分布具有支持 \([l, r]\)。反向对数-CCDF 在 \(\log(p) = \log(1) = 0\) 时返回其最小值 \(l\),在 \(\log(p) = \log(0) = -\infty\) 时返回其最大值 \(r\)。由于对数-CCDF 的范围为 \([-\infty, 0]\),因此反向对数-CDF 仅定义在负实数上;对于 \(\log(p) > 0\)ilogccdf 返回 nan

有时,需要查找 CCDF 的参数,使得结果概率非常接近 01 - 太接近而无法用浮点运算准确表示。然而,在许多情况下,这个结果概率的对数可以用浮点运算表示,在这种情况下,可以使用此函数查找 CCDF 的参数,使得结果概率的对数y = log(p)

数字 \(z\) 的“对数补码”在数学上等效于 \(\log(1-\exp(z))\),但在 \(\exp(z)\) 接近 \(0\)\(1\) 时,会进行计算以避免精度损失。

示例

使用所需参数实例化分布

>>> import numpy as np
>>> from scipy import stats
>>> X = stats.Uniform(a=-0.5, b=0.5)

在所需的参数处评估反向对数-CCDF

>>> X.ilogccdf(-0.25)
-0.2788007830714034
>>> np.allclose(X.ilogccdf(-0.25), X.iccdf(np.exp(-0.25)))
True