52#define ML_NEGINF std::numeric_limits<double>::min()
57#define ML_POSINF std::numeric_limits<double>::max()
61#define NAN std::numeric_limits<double>::quiet_NaN()
66#define R_D_Lval(p) (lower_tail ? (p) : (0.5 - (p) + 0.5))
72#define R_DT_qIv(p) (log_p ? (lower_tail ? exp(p) : - expm1(p)) \
88#ifndef R_Q_P01_boundaries
89#define R_Q_P01_boundaries(p, _LEFT_, _RIGHT_) \
94 return lower_tail ? _RIGHT_ : _LEFT_; \
96 return lower_tail ? _LEFT_ : _RIGHT_; \
102 return lower_tail ? _LEFT_ : _RIGHT_; \
104 return lower_tail ? _RIGHT_ : _LEFT_; \
108static double qnorm(
double p,
double mu,
double sigma,
int lower_tail,
int log_p){
109 double p_, q, r, val;
112 if (std::isnan(p) || std::isnan(mu) || std::isnan(sigma))
113 return p + mu + sigma;
118 if(sigma == 0)
return mu;
139 if (fabs(q) <= .425) {
142 q * (((((((r * 2509.0809287301226727 +
143 33430.575583588128105) * r + 67265.770927008700853) * r +
144 45921.953931549871457) * r + 13731.693765509461125) * r +
145 1971.5909503065514427) * r + 133.14166789178437745) * r +
146 3.387132872796366608)
147 / (((((((r * 5226.495278852854561 +
148 28729.085735721942674) * r + 39307.89580009271061) * r +
149 21213.794301586595867) * r + 5394.1960214247511077) * r +
150 687.1870074920579083) * r + 42.313330701600911252) * r + 1.);
155 if(log_p && ((lower_tail && q <= 0) || (!lower_tail && q > 0))) {
158 lp = log( (q > 0) ? R_DT_CIv(p) : p_ );
163 REprintf(
"\t close to 0 or 1: r = %7g\n", r);
167 val = (((((((r * 7.7454501427834140764e-4 +
168 .0227238449892691845833) * r + .24178072517745061177) *
169 r + 1.27045825245236838258) * r +
170 3.64784832476320460504) * r + 5.7694972214606914055) *
171 r + 4.6303378461565452959) * r +
172 1.42343711074968357734)
174 1.05075007164441684324e-9 + 5.475938084995344946e-4) *
175 r + .0151986665636164571966) * r +
176 .14810397642748007459) * r + .68976733498510000455) *
177 r + 1.6763848301838038494) * r +
178 2.05319162663775882187) * r + 1.);
187 val = (((((((r * 2.01033439929228813265e-7 +
188 2.71155556874348757815e-5) * r +
189 .0012426609473880784386) * r + .026532189526576123093) *
190 r + .29656057182850489123) * r +
191 1.7848265399172913358) * r + 5.4637849111641143699) *
192 r + 6.6579046435011037772)
194 2.04426310338993978564e-15 + 1.4215117583164458887e-7)*
195 r + 1.8463183175100546818e-5) * r +
196 7.868691311456132591e-4) * r + .0148753612908506148525)
197 * r + .13692988092273580531) * r +
198 .59983220655588793769) * r + 1.);
205 double s2 = -ldexp(lp, 1),
206 x2 = s2 - log(M_2PI * s2);
209 x2 = s2 - log(M_2PI * x2) - 2./(2. + x2);
211 x2 = s2 - log(M_2PI * x2) + 2*log1p(- (1 - 1/(4 + x2))/(2. + x2));
213 x2 = s2 - log(M_2PI * x2) +
214 2*log1p(- (1 - (1 - 5/(6 + x2))/(4. + x2))/(2. + x2));
216 x2 = s2 - log(M_2PI * x2) +
217 2*log1p(- (1 - (1 - (5 - 9/(8. + x2))/(6. + x2))/(4. + x2))/(2. + x2));
228 return mu + sigma * val;