You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
import numpy as np
import numpy.testing as npt
from scipy import stats
dist = stats.nbinom(5, 0.5)
supp = 6
cdf_supp = dist.cdf(supp) # ideally 0.7255859375
cdf_supp0 = cdf_supp - 10*np.spacing(cdf_supp) # 0.7255859374999989
npt.assert_array_equal(dist.ppf(cdf_supp0), supp) # both should be 6
Note in their code says:
In very rare cases, the finite precision calculation of ppf(cdf(supp))
can produce an array in which an element is off by one. We nudge the
CDF values down by 10 ULPs help to avoid this.