8#ifndef XGBOOST_COMMON_PROBABILITY_DISTRIBUTION_H_
9#define XGBOOST_COMMON_PROBABILITY_DISTRIBUTION_H_
26constexpr double kPI = 3.14159265358979323846;
28constexpr double kEulerMascheroni = 0.57721566490153286060651209008240243104215933593992;
32 kNormal = 0, kLogistic = 1, kExtreme = 2
37 return exp(-z * z / 2.0) / sqrt(2.0 *
kPI);
41 return 0.5 * (1 + erf(z / sqrt(2.0)));
49 return (z * z - 1.0) * PDF(z);
53 return ProbabilityDistributionType::kNormal;
59 const double w = exp(z);
60 const double sqrt_denominator = 1 + w;
61 if (isinf(w) || isinf(w * w)) {
64 return w / (sqrt_denominator * sqrt_denominator);
69 const double w = exp(z);
70 return isinf(w) ? 1.0 : (w / (1 + w));
74 const double w = exp(z);
75 return isinf(w) ? 0.0 : (PDF(z) * (1 - w) / (1 + w));
79 const double w = exp(z);
80 if (isinf(w) || isinf(w * w)) {
83 return PDF(z) * (w * w - 4 * w + 1) / ((1 + w) * (1 + w));
88 return ProbabilityDistributionType::kLogistic;
94 const double w = exp(z);
95 return isinf(w) ? 0.0 : (w * exp(-w));
99 const double w = exp(z);
104 const double w = exp(z);
105 return isinf(w) ? 0.0 : ((1 - w) * PDF(z));
109 const double w = exp(z);
110 if (isinf(w) || isinf(w * w)) {
113 return (w * w - 3 * w + 1) * PDF(z);
118 return ProbabilityDistributionType::kExtreme;
#define XGBOOST_DEVICE
Tag function as usable by device.
Definition base.h:64
ProbabilityDistributionType
Enum encoding possible choices of probability distribution.
Definition probability_distribution.h:31
constexpr double kEulerMascheroni
The Euler-Mascheroni_constant.
Definition probability_distribution.h:28
constexpr double kPI
Constant PI.
Definition probability_distribution.h:26
namespace of xgboost
Definition base.h:90
Definition probability_distribution.h:92
Definition probability_distribution.h:57
Definition probability_distribution.h:35