root / lab4 / .minix-src / include / c++ / random @ 13
History | View | Annotate | Download (220 KB)
1 |
// -*- C++ -*- |
---|---|
2 |
//===--------------------------- random -----------------------------------===// |
3 |
// |
4 |
// The LLVM Compiler Infrastructure |
5 |
// |
6 |
// This file is dual licensed under the MIT and the University of Illinois Open |
7 |
// Source Licenses. See LICENSE.TXT for details. |
8 |
// |
9 |
//===----------------------------------------------------------------------===// |
10 |
|
11 |
#ifndef _LIBCPP_RANDOM |
12 |
#define _LIBCPP_RANDOM |
13 |
|
14 |
/* |
15 |
random synopsis |
16 |
|
17 |
#include <initializer_list> |
18 |
|
19 |
namespace std |
20 |
{ |
21 |
|
22 |
// Engines |
23 |
|
24 |
template <class UIntType, UIntType a, UIntType c, UIntType m> |
25 |
class linear_congruential_engine |
26 |
{ |
27 |
public: |
28 |
// types |
29 |
typedef UIntType result_type; |
30 |
|
31 |
// engine characteristics |
32 |
static constexpr result_type multiplier = a; |
33 |
static constexpr result_type increment = c; |
34 |
static constexpr result_type modulus = m; |
35 |
static constexpr result_type min() { return c == 0u ? 1u: 0u;} |
36 |
static constexpr result_type max() { return m - 1u;} |
37 |
static constexpr result_type default_seed = 1u; |
38 |
|
39 |
// constructors and seeding functions |
40 |
explicit linear_congruential_engine(result_type s = default_seed); |
41 |
template<class Sseq> explicit linear_congruential_engine(Sseq& q); |
42 |
void seed(result_type s = default_seed); |
43 |
template<class Sseq> void seed(Sseq& q); |
44 |
|
45 |
// generating functions |
46 |
result_type operator()(); |
47 |
void discard(unsigned long long z); |
48 |
}; |
49 |
|
50 |
template <class UIntType, UIntType a, UIntType c, UIntType m> |
51 |
bool |
52 |
operator==(const linear_congruential_engine<UIntType, a, c, m>& x, |
53 |
const linear_congruential_engine<UIntType, a, c, m>& y); |
54 |
|
55 |
template <class UIntType, UIntType a, UIntType c, UIntType m> |
56 |
bool |
57 |
operator!=(const linear_congruential_engine<UIntType, a, c, m>& x, |
58 |
const linear_congruential_engine<UIntType, a, c, m>& y); |
59 |
|
60 |
template <class charT, class traits, |
61 |
class UIntType, UIntType a, UIntType c, UIntType m> |
62 |
basic_ostream<charT, traits>& |
63 |
operator<<(basic_ostream<charT, traits>& os, |
64 |
const linear_congruential_engine<UIntType, a, c, m>& x); |
65 |
|
66 |
template <class charT, class traits, |
67 |
class UIntType, UIntType a, UIntType c, UIntType m> |
68 |
basic_istream<charT, traits>& |
69 |
operator>>(basic_istream<charT, traits>& is, |
70 |
linear_congruential_engine<UIntType, a, c, m>& x); |
71 |
|
72 |
template <class UIntType, size_t w, size_t n, size_t m, size_t r, |
73 |
UIntType a, size_t u, UIntType d, size_t s, |
74 |
UIntType b, size_t t, UIntType c, size_t l, UIntType f> |
75 |
class mersenne_twister_engine |
76 |
{ |
77 |
public: |
78 |
// types |
79 |
typedef UIntType result_type; |
80 |
|
81 |
// engine characteristics |
82 |
static constexpr size_t word_size = w; |
83 |
static constexpr size_t state_size = n; |
84 |
static constexpr size_t shift_size = m; |
85 |
static constexpr size_t mask_bits = r; |
86 |
static constexpr result_type xor_mask = a; |
87 |
static constexpr size_t tempering_u = u; |
88 |
static constexpr result_type tempering_d = d; |
89 |
static constexpr size_t tempering_s = s; |
90 |
static constexpr result_type tempering_b = b; |
91 |
static constexpr size_t tempering_t = t; |
92 |
static constexpr result_type tempering_c = c; |
93 |
static constexpr size_t tempering_l = l; |
94 |
static constexpr result_type initialization_multiplier = f; |
95 |
static constexpr result_type min () { return 0; } |
96 |
static constexpr result_type max() { return 2^w - 1; } |
97 |
static constexpr result_type default_seed = 5489u; |
98 |
|
99 |
// constructors and seeding functions |
100 |
explicit mersenne_twister_engine(result_type value = default_seed); |
101 |
template<class Sseq> explicit mersenne_twister_engine(Sseq& q); |
102 |
void seed(result_type value = default_seed); |
103 |
template<class Sseq> void seed(Sseq& q); |
104 |
|
105 |
// generating functions |
106 |
result_type operator()(); |
107 |
void discard(unsigned long long z); |
108 |
}; |
109 |
|
110 |
template <class UIntType, size_t w, size_t n, size_t m, size_t r, |
111 |
UIntType a, size_t u, UIntType d, size_t s, |
112 |
UIntType b, size_t t, UIntType c, size_t l, UIntType f> |
113 |
bool |
114 |
operator==( |
115 |
const mersenne_twister_engine<UIntType, w, n, m, r, a, u, d, s, b, t, c, l, f>& x, |
116 |
const mersenne_twister_engine<UIntType, w, n, m, r, a, u, d, s, b, t, c, l, f>& y); |
117 |
|
118 |
template <class UIntType, size_t w, size_t n, size_t m, size_t r, |
119 |
UIntType a, size_t u, UIntType d, size_t s, |
120 |
UIntType b, size_t t, UIntType c, size_t l, UIntType f> |
121 |
bool |
122 |
operator!=( |
123 |
const mersenne_twister_engine<UIntType, w, n, m, r, a, u, d, s, b, t, c, l, f>& x, |
124 |
const mersenne_twister_engine<UIntType, w, n, m, r, a, u, d, s, b, t, c, l, f>& y); |
125 |
|
126 |
template <class charT, class traits, |
127 |
class UIntType, size_t w, size_t n, size_t m, size_t r, |
128 |
UIntType a, size_t u, UIntType d, size_t s, |
129 |
UIntType b, size_t t, UIntType c, size_t l, UIntType f> |
130 |
basic_ostream<charT, traits>& |
131 |
operator<<(basic_ostream<charT, traits>& os, |
132 |
const mersenne_twister_engine<UIntType, w, n, m, r, a, u, d, s, b, t, c, l, f>& x); |
133 |
|
134 |
template <class charT, class traits, |
135 |
class UIntType, size_t w, size_t n, size_t m, size_t r, |
136 |
UIntType a, size_t u, UIntType d, size_t s, |
137 |
UIntType b, size_t t, UIntType c, size_t l, UIntType f> |
138 |
basic_istream<charT, traits>& |
139 |
operator>>(basic_istream<charT, traits>& is, |
140 |
mersenne_twister_engine<UIntType, w, n, m, r, a, u, d, s, b, t, c, l, f>& x); |
141 |
|
142 |
template<class UIntType, size_t w, size_t s, size_t r> |
143 |
class subtract_with_carry_engine |
144 |
{ |
145 |
public: |
146 |
// types |
147 |
typedef UIntType result_type; |
148 |
|
149 |
// engine characteristics |
150 |
static constexpr size_t word_size = w; |
151 |
static constexpr size_t short_lag = s; |
152 |
static constexpr size_t long_lag = r; |
153 |
static constexpr result_type min() { return 0; } |
154 |
static constexpr result_type max() { return m-1; } |
155 |
static constexpr result_type default_seed = 19780503u; |
156 |
|
157 |
// constructors and seeding functions |
158 |
explicit subtract_with_carry_engine(result_type value = default_seed); |
159 |
template<class Sseq> explicit subtract_with_carry_engine(Sseq& q); |
160 |
void seed(result_type value = default_seed); |
161 |
template<class Sseq> void seed(Sseq& q); |
162 |
|
163 |
// generating functions |
164 |
result_type operator()(); |
165 |
void discard(unsigned long long z); |
166 |
}; |
167 |
|
168 |
template<class UIntType, size_t w, size_t s, size_t r> |
169 |
bool |
170 |
operator==( |
171 |
const subtract_with_carry_engine<UIntType, w, s, r>& x, |
172 |
const subtract_with_carry_engine<UIntType, w, s, r>& y); |
173 |
|
174 |
template<class UIntType, size_t w, size_t s, size_t r> |
175 |
bool |
176 |
operator!=( |
177 |
const subtract_with_carry_engine<UIntType, w, s, r>& x, |
178 |
const subtract_with_carry_engine<UIntType, w, s, r>& y); |
179 |
|
180 |
template <class charT, class traits, |
181 |
class UIntType, size_t w, size_t s, size_t r> |
182 |
basic_ostream<charT, traits>& |
183 |
operator<<(basic_ostream<charT, traits>& os, |
184 |
const subtract_with_carry_engine<UIntType, w, s, r>& x); |
185 |
|
186 |
template <class charT, class traits, |
187 |
class UIntType, size_t w, size_t s, size_t r> |
188 |
basic_istream<charT, traits>& |
189 |
operator>>(basic_istream<charT, traits>& is, |
190 |
subtract_with_carry_engine<UIntType, w, s, r>& x); |
191 |
|
192 |
template<class Engine, size_t p, size_t r> |
193 |
class discard_block_engine |
194 |
{ |
195 |
public: |
196 |
// types |
197 |
typedef typename Engine::result_type result_type; |
198 |
|
199 |
// engine characteristics |
200 |
static constexpr size_t block_size = p; |
201 |
static constexpr size_t used_block = r; |
202 |
static constexpr result_type min() { return Engine::min(); } |
203 |
static constexpr result_type max() { return Engine::max(); } |
204 |
|
205 |
// constructors and seeding functions |
206 |
discard_block_engine(); |
207 |
explicit discard_block_engine(const Engine& e); |
208 |
explicit discard_block_engine(Engine&& e); |
209 |
explicit discard_block_engine(result_type s); |
210 |
template<class Sseq> explicit discard_block_engine(Sseq& q); |
211 |
void seed(); |
212 |
void seed(result_type s); |
213 |
template<class Sseq> void seed(Sseq& q); |
214 |
|
215 |
// generating functions |
216 |
result_type operator()(); |
217 |
void discard(unsigned long long z); |
218 |
|
219 |
// property functions |
220 |
const Engine& base() const noexcept; |
221 |
}; |
222 |
|
223 |
template<class Engine, size_t p, size_t r> |
224 |
bool |
225 |
operator==( |
226 |
const discard_block_engine<Engine, p, r>& x, |
227 |
const discard_block_engine<Engine, p, r>& y); |
228 |
|
229 |
template<class Engine, size_t p, size_t r> |
230 |
bool |
231 |
operator!=( |
232 |
const discard_block_engine<Engine, p, r>& x, |
233 |
const discard_block_engine<Engine, p, r>& y); |
234 |
|
235 |
template <class charT, class traits, |
236 |
class Engine, size_t p, size_t r> |
237 |
basic_ostream<charT, traits>& |
238 |
operator<<(basic_ostream<charT, traits>& os, |
239 |
const discard_block_engine<Engine, p, r>& x); |
240 |
|
241 |
template <class charT, class traits, |
242 |
class Engine, size_t p, size_t r> |
243 |
basic_istream<charT, traits>& |
244 |
operator>>(basic_istream<charT, traits>& is, |
245 |
discard_block_engine<Engine, p, r>& x); |
246 |
|
247 |
template<class Engine, size_t w, class UIntType> |
248 |
class independent_bits_engine |
249 |
{ |
250 |
public: |
251 |
// types |
252 |
typedef UIntType result_type; |
253 |
|
254 |
// engine characteristics |
255 |
static constexpr result_type min() { return 0; } |
256 |
static constexpr result_type max() { return 2^w - 1; } |
257 |
|
258 |
// constructors and seeding functions |
259 |
independent_bits_engine(); |
260 |
explicit independent_bits_engine(const Engine& e); |
261 |
explicit independent_bits_engine(Engine&& e); |
262 |
explicit independent_bits_engine(result_type s); |
263 |
template<class Sseq> explicit independent_bits_engine(Sseq& q); |
264 |
void seed(); |
265 |
void seed(result_type s); |
266 |
template<class Sseq> void seed(Sseq& q); |
267 |
|
268 |
// generating functions |
269 |
result_type operator()(); void discard(unsigned long long z); |
270 |
|
271 |
// property functions |
272 |
const Engine& base() const noexcept; |
273 |
}; |
274 |
|
275 |
template<class Engine, size_t w, class UIntType> |
276 |
bool |
277 |
operator==( |
278 |
const independent_bits_engine<Engine, w, UIntType>& x, |
279 |
const independent_bits_engine<Engine, w, UIntType>& y); |
280 |
|
281 |
template<class Engine, size_t w, class UIntType> |
282 |
bool |
283 |
operator!=( |
284 |
const independent_bits_engine<Engine, w, UIntType>& x, |
285 |
const independent_bits_engine<Engine, w, UIntType>& y); |
286 |
|
287 |
template <class charT, class traits, |
288 |
class Engine, size_t w, class UIntType> |
289 |
basic_ostream<charT, traits>& |
290 |
operator<<(basic_ostream<charT, traits>& os, |
291 |
const independent_bits_engine<Engine, w, UIntType>& x); |
292 |
|
293 |
template <class charT, class traits, |
294 |
class Engine, size_t w, class UIntType> |
295 |
basic_istream<charT, traits>& |
296 |
operator>>(basic_istream<charT, traits>& is, |
297 |
independent_bits_engine<Engine, w, UIntType>& x); |
298 |
|
299 |
template<class Engine, size_t k> |
300 |
class shuffle_order_engine |
301 |
{ |
302 |
public: |
303 |
// types |
304 |
typedef typename Engine::result_type result_type; |
305 |
|
306 |
// engine characteristics |
307 |
static constexpr size_t table_size = k; |
308 |
static constexpr result_type min() { return Engine::min; } |
309 |
static constexpr result_type max() { return Engine::max; } |
310 |
|
311 |
// constructors and seeding functions |
312 |
shuffle_order_engine(); |
313 |
explicit shuffle_order_engine(const Engine& e); |
314 |
explicit shuffle_order_engine(Engine&& e); |
315 |
explicit shuffle_order_engine(result_type s); |
316 |
template<class Sseq> explicit shuffle_order_engine(Sseq& q); |
317 |
void seed(); |
318 |
void seed(result_type s); |
319 |
template<class Sseq> void seed(Sseq& q); |
320 |
|
321 |
// generating functions |
322 |
result_type operator()(); |
323 |
void discard(unsigned long long z); |
324 |
|
325 |
// property functions |
326 |
const Engine& base() const noexcept; |
327 |
}; |
328 |
|
329 |
template<class Engine, size_t k> |
330 |
bool |
331 |
operator==( |
332 |
const shuffle_order_engine<Engine, k>& x, |
333 |
const shuffle_order_engine<Engine, k>& y); |
334 |
|
335 |
template<class Engine, size_t k> |
336 |
bool |
337 |
operator!=( |
338 |
const shuffle_order_engine<Engine, k>& x, |
339 |
const shuffle_order_engine<Engine, k>& y); |
340 |
|
341 |
template <class charT, class traits, |
342 |
class Engine, size_t k> |
343 |
basic_ostream<charT, traits>& |
344 |
operator<<(basic_ostream<charT, traits>& os, |
345 |
const shuffle_order_engine<Engine, k>& x); |
346 |
|
347 |
template <class charT, class traits, |
348 |
class Engine, size_t k> |
349 |
basic_istream<charT, traits>& |
350 |
operator>>(basic_istream<charT, traits>& is, |
351 |
shuffle_order_engine<Engine, k>& x); |
352 |
|
353 |
typedef linear_congruential_engine<uint_fast32_t, 16807, 0, 2147483647> |
354 |
minstd_rand0; |
355 |
typedef linear_congruential_engine<uint_fast32_t, 48271, 0, 2147483647> |
356 |
minstd_rand; |
357 |
typedef mersenne_twister_engine<uint_fast32_t, 32, 624, 397, 31, |
358 |
0x9908b0df, |
359 |
11, 0xffffffff, |
360 |
7, 0x9d2c5680, |
361 |
15, 0xefc60000, |
362 |
18, 1812433253> mt19937; |
363 |
typedef mersenne_twister_engine<uint_fast64_t, 64, 312, 156, 31, |
364 |
0xb5026f5aa96619e9, |
365 |
29, 0x5555555555555555, |
366 |
17, 0x71d67fffeda60000, |
367 |
37, 0xfff7eee000000000, |
368 |
43, 6364136223846793005> mt19937_64; |
369 |
typedef subtract_with_carry_engine<uint_fast32_t, 24, 10, 24> ranlux24_base; |
370 |
typedef subtract_with_carry_engine<uint_fast64_t, 48, 5, 12> ranlux48_base; |
371 |
typedef discard_block_engine<ranlux24_base, 223, 23> ranlux24; |
372 |
typedef discard_block_engine<ranlux48_base, 389, 11> ranlux48; |
373 |
typedef shuffle_order_engine<minstd_rand0, 256> knuth_b; |
374 |
typedef minstd_rand default_random_engine; |
375 |
|
376 |
// Generators |
377 |
|
378 |
class random_device |
379 |
{ |
380 |
public: |
381 |
// types |
382 |
typedef unsigned int result_type; |
383 |
|
384 |
// generator characteristics |
385 |
static constexpr result_type min() { return numeric_limits<result_type>::min(); } |
386 |
static constexpr result_type max() { return numeric_limits<result_type>::max(); } |
387 |
|
388 |
// constructors |
389 |
explicit random_device(const string& token = "/dev/urandom"); |
390 |
|
391 |
// generating functions |
392 |
result_type operator()(); |
393 |
|
394 |
// property functions |
395 |
double entropy() const noexcept; |
396 |
|
397 |
// no copy functions |
398 |
random_device(const random_device& ) = delete; |
399 |
void operator=(const random_device& ) = delete; |
400 |
}; |
401 |
|
402 |
// Utilities |
403 |
|
404 |
class seed_seq |
405 |
{ |
406 |
public: |
407 |
// types |
408 |
typedef uint_least32_t result_type; |
409 |
|
410 |
// constructors |
411 |
seed_seq(); |
412 |
template<class T> |
413 |
seed_seq(initializer_list<T> il); |
414 |
template<class InputIterator> |
415 |
seed_seq(InputIterator begin, InputIterator end); |
416 |
|
417 |
// generating functions |
418 |
template<class RandomAccessIterator> |
419 |
void generate(RandomAccessIterator begin, RandomAccessIterator end); |
420 |
|
421 |
// property functions |
422 |
size_t size() const; |
423 |
template<class OutputIterator> |
424 |
void param(OutputIterator dest) const; |
425 |
|
426 |
// no copy functions |
427 |
seed_seq(const seed_seq&) = delete; |
428 |
void operator=(const seed_seq& ) = delete; |
429 |
}; |
430 |
|
431 |
template<class RealType, size_t bits, class URNG> |
432 |
RealType generate_canonical(URNG& g); |
433 |
|
434 |
// Distributions |
435 |
|
436 |
template<class IntType = int> |
437 |
class uniform_int_distribution |
438 |
{ |
439 |
public: |
440 |
// types |
441 |
typedef IntType result_type; |
442 |
|
443 |
class param_type |
444 |
{ |
445 |
public: |
446 |
typedef uniform_int_distribution distribution_type; |
447 |
|
448 |
explicit param_type(IntType a = 0, |
449 |
IntType b = numeric_limits<IntType>::max()); |
450 |
|
451 |
result_type a() const; |
452 |
result_type b() const; |
453 |
|
454 |
friend bool operator==(const param_type& x, const param_type& y); |
455 |
friend bool operator!=(const param_type& x, const param_type& y); |
456 |
}; |
457 |
|
458 |
// constructors and reset functions |
459 |
explicit uniform_int_distribution(IntType a = 0, |
460 |
IntType b = numeric_limits<IntType>::max()); |
461 |
explicit uniform_int_distribution(const param_type& parm); |
462 |
void reset(); |
463 |
|
464 |
// generating functions |
465 |
template<class URNG> result_type operator()(URNG& g); |
466 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
467 |
|
468 |
// property functions |
469 |
result_type a() const; |
470 |
result_type b() const; |
471 |
|
472 |
param_type param() const; |
473 |
void param(const param_type& parm); |
474 |
|
475 |
result_type min() const; |
476 |
result_type max() const; |
477 |
|
478 |
friend bool operator==(const uniform_int_distribution& x, |
479 |
const uniform_int_distribution& y); |
480 |
friend bool operator!=(const uniform_int_distribution& x, |
481 |
const uniform_int_distribution& y); |
482 |
|
483 |
template <class charT, class traits> |
484 |
friend |
485 |
basic_ostream<charT, traits>& |
486 |
operator<<(basic_ostream<charT, traits>& os, |
487 |
const uniform_int_distribution& x); |
488 |
|
489 |
template <class charT, class traits> |
490 |
friend |
491 |
basic_istream<charT, traits>& |
492 |
operator>>(basic_istream<charT, traits>& is, |
493 |
uniform_int_distribution& x); |
494 |
}; |
495 |
|
496 |
template<class RealType = double> |
497 |
class uniform_real_distribution |
498 |
{ |
499 |
public: |
500 |
// types |
501 |
typedef RealType result_type; |
502 |
|
503 |
class param_type |
504 |
{ |
505 |
public: |
506 |
typedef uniform_real_distribution distribution_type; |
507 |
|
508 |
explicit param_type(RealType a = 0, |
509 |
RealType b = 1); |
510 |
|
511 |
result_type a() const; |
512 |
result_type b() const; |
513 |
|
514 |
friend bool operator==(const param_type& x, const param_type& y); |
515 |
friend bool operator!=(const param_type& x, const param_type& y); |
516 |
}; |
517 |
|
518 |
// constructors and reset functions |
519 |
explicit uniform_real_distribution(RealType a = 0.0, RealType b = 1.0); |
520 |
explicit uniform_real_distribution(const param_type& parm); |
521 |
void reset(); |
522 |
|
523 |
// generating functions |
524 |
template<class URNG> result_type operator()(URNG& g); |
525 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
526 |
|
527 |
// property functions |
528 |
result_type a() const; |
529 |
result_type b() const; |
530 |
|
531 |
param_type param() const; |
532 |
void param(const param_type& parm); |
533 |
|
534 |
result_type min() const; |
535 |
result_type max() const; |
536 |
|
537 |
friend bool operator==(const uniform_real_distribution& x, |
538 |
const uniform_real_distribution& y); |
539 |
friend bool operator!=(const uniform_real_distribution& x, |
540 |
const uniform_real_distribution& y); |
541 |
|
542 |
template <class charT, class traits> |
543 |
friend |
544 |
basic_ostream<charT, traits>& |
545 |
operator<<(basic_ostream<charT, traits>& os, |
546 |
const uniform_real_distribution& x); |
547 |
|
548 |
template <class charT, class traits> |
549 |
friend |
550 |
basic_istream<charT, traits>& |
551 |
operator>>(basic_istream<charT, traits>& is, |
552 |
uniform_real_distribution& x); |
553 |
}; |
554 |
|
555 |
class bernoulli_distribution |
556 |
{ |
557 |
public: |
558 |
// types |
559 |
typedef bool result_type; |
560 |
|
561 |
class param_type |
562 |
{ |
563 |
public: |
564 |
typedef bernoulli_distribution distribution_type; |
565 |
|
566 |
explicit param_type(double p = 0.5); |
567 |
|
568 |
double p() const; |
569 |
|
570 |
friend bool operator==(const param_type& x, const param_type& y); |
571 |
friend bool operator!=(const param_type& x, const param_type& y); |
572 |
}; |
573 |
|
574 |
// constructors and reset functions |
575 |
explicit bernoulli_distribution(double p = 0.5); |
576 |
explicit bernoulli_distribution(const param_type& parm); |
577 |
void reset(); |
578 |
|
579 |
// generating functions |
580 |
template<class URNG> result_type operator()(URNG& g); |
581 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
582 |
|
583 |
// property functions |
584 |
double p() const; |
585 |
|
586 |
param_type param() const; |
587 |
void param(const param_type& parm); |
588 |
|
589 |
result_type min() const; |
590 |
result_type max() const; |
591 |
|
592 |
friend bool operator==(const bernoulli_distribution& x, |
593 |
const bernoulli_distribution& y); |
594 |
friend bool operator!=(const bernoulli_distribution& x, |
595 |
const bernoulli_distribution& y); |
596 |
|
597 |
template <class charT, class traits> |
598 |
friend |
599 |
basic_ostream<charT, traits>& |
600 |
operator<<(basic_ostream<charT, traits>& os, |
601 |
const bernoulli_distribution& x); |
602 |
|
603 |
template <class charT, class traits> |
604 |
friend |
605 |
basic_istream<charT, traits>& |
606 |
operator>>(basic_istream<charT, traits>& is, |
607 |
bernoulli_distribution& x); |
608 |
}; |
609 |
|
610 |
template<class IntType = int> |
611 |
class binomial_distribution |
612 |
{ |
613 |
public: |
614 |
// types |
615 |
typedef IntType result_type; |
616 |
|
617 |
class param_type |
618 |
{ |
619 |
public: |
620 |
typedef binomial_distribution distribution_type; |
621 |
|
622 |
explicit param_type(IntType t = 1, double p = 0.5); |
623 |
|
624 |
IntType t() const; |
625 |
double p() const; |
626 |
|
627 |
friend bool operator==(const param_type& x, const param_type& y); |
628 |
friend bool operator!=(const param_type& x, const param_type& y); |
629 |
}; |
630 |
|
631 |
// constructors and reset functions |
632 |
explicit binomial_distribution(IntType t = 1, double p = 0.5); |
633 |
explicit binomial_distribution(const param_type& parm); |
634 |
void reset(); |
635 |
|
636 |
// generating functions |
637 |
template<class URNG> result_type operator()(URNG& g); |
638 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
639 |
|
640 |
// property functions |
641 |
IntType t() const; |
642 |
double p() const; |
643 |
|
644 |
param_type param() const; |
645 |
void param(const param_type& parm); |
646 |
|
647 |
result_type min() const; |
648 |
result_type max() const; |
649 |
|
650 |
friend bool operator==(const binomial_distribution& x, |
651 |
const binomial_distribution& y); |
652 |
friend bool operator!=(const binomial_distribution& x, |
653 |
const binomial_distribution& y); |
654 |
|
655 |
template <class charT, class traits> |
656 |
friend |
657 |
basic_ostream<charT, traits>& |
658 |
operator<<(basic_ostream<charT, traits>& os, |
659 |
const binomial_distribution& x); |
660 |
|
661 |
template <class charT, class traits> |
662 |
friend |
663 |
basic_istream<charT, traits>& |
664 |
operator>>(basic_istream<charT, traits>& is, |
665 |
binomial_distribution& x); |
666 |
}; |
667 |
|
668 |
template<class IntType = int> |
669 |
class geometric_distribution |
670 |
{ |
671 |
public: |
672 |
// types |
673 |
typedef IntType result_type; |
674 |
|
675 |
class param_type |
676 |
{ |
677 |
public: |
678 |
typedef geometric_distribution distribution_type; |
679 |
|
680 |
explicit param_type(double p = 0.5); |
681 |
|
682 |
double p() const; |
683 |
|
684 |
friend bool operator==(const param_type& x, const param_type& y); |
685 |
friend bool operator!=(const param_type& x, const param_type& y); |
686 |
}; |
687 |
|
688 |
// constructors and reset functions |
689 |
explicit geometric_distribution(double p = 0.5); |
690 |
explicit geometric_distribution(const param_type& parm); |
691 |
void reset(); |
692 |
|
693 |
// generating functions |
694 |
template<class URNG> result_type operator()(URNG& g); |
695 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
696 |
|
697 |
// property functions |
698 |
double p() const; |
699 |
|
700 |
param_type param() const; |
701 |
void param(const param_type& parm); |
702 |
|
703 |
result_type min() const; |
704 |
result_type max() const; |
705 |
|
706 |
friend bool operator==(const geometric_distribution& x, |
707 |
const geometric_distribution& y); |
708 |
friend bool operator!=(const geometric_distribution& x, |
709 |
const geometric_distribution& y); |
710 |
|
711 |
template <class charT, class traits> |
712 |
friend |
713 |
basic_ostream<charT, traits>& |
714 |
operator<<(basic_ostream<charT, traits>& os, |
715 |
const geometric_distribution& x); |
716 |
|
717 |
template <class charT, class traits> |
718 |
friend |
719 |
basic_istream<charT, traits>& |
720 |
operator>>(basic_istream<charT, traits>& is, |
721 |
geometric_distribution& x); |
722 |
}; |
723 |
|
724 |
template<class IntType = int> |
725 |
class negative_binomial_distribution |
726 |
{ |
727 |
public: |
728 |
// types |
729 |
typedef IntType result_type; |
730 |
|
731 |
class param_type |
732 |
{ |
733 |
public: |
734 |
typedef negative_binomial_distribution distribution_type; |
735 |
|
736 |
explicit param_type(result_type k = 1, double p = 0.5); |
737 |
|
738 |
result_type k() const; |
739 |
double p() const; |
740 |
|
741 |
friend bool operator==(const param_type& x, const param_type& y); |
742 |
friend bool operator!=(const param_type& x, const param_type& y); |
743 |
}; |
744 |
|
745 |
// constructor and reset functions |
746 |
explicit negative_binomial_distribution(result_type k = 1, double p = 0.5); |
747 |
explicit negative_binomial_distribution(const param_type& parm); |
748 |
void reset(); |
749 |
|
750 |
// generating functions |
751 |
template<class URNG> result_type operator()(URNG& g); |
752 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
753 |
|
754 |
// property functions |
755 |
result_type k() const; |
756 |
double p() const; |
757 |
|
758 |
param_type param() const; |
759 |
void param(const param_type& parm); |
760 |
|
761 |
result_type min() const; |
762 |
result_type max() const; |
763 |
|
764 |
friend bool operator==(const negative_binomial_distribution& x, |
765 |
const negative_binomial_distribution& y); |
766 |
friend bool operator!=(const negative_binomial_distribution& x, |
767 |
const negative_binomial_distribution& y); |
768 |
|
769 |
template <class charT, class traits> |
770 |
friend |
771 |
basic_ostream<charT, traits>& |
772 |
operator<<(basic_ostream<charT, traits>& os, |
773 |
const negative_binomial_distribution& x); |
774 |
|
775 |
template <class charT, class traits> |
776 |
friend |
777 |
basic_istream<charT, traits>& |
778 |
operator>>(basic_istream<charT, traits>& is, |
779 |
negative_binomial_distribution& x); |
780 |
}; |
781 |
|
782 |
template<class IntType = int> |
783 |
class poisson_distribution |
784 |
{ |
785 |
public: |
786 |
// types |
787 |
typedef IntType result_type; |
788 |
|
789 |
class param_type |
790 |
{ |
791 |
public: |
792 |
typedef poisson_distribution distribution_type; |
793 |
|
794 |
explicit param_type(double mean = 1.0); |
795 |
|
796 |
double mean() const; |
797 |
|
798 |
friend bool operator==(const param_type& x, const param_type& y); |
799 |
friend bool operator!=(const param_type& x, const param_type& y); |
800 |
}; |
801 |
|
802 |
// constructors and reset functions |
803 |
explicit poisson_distribution(double mean = 1.0); |
804 |
explicit poisson_distribution(const param_type& parm); |
805 |
void reset(); |
806 |
|
807 |
// generating functions |
808 |
template<class URNG> result_type operator()(URNG& g); |
809 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
810 |
|
811 |
// property functions |
812 |
double mean() const; |
813 |
|
814 |
param_type param() const; |
815 |
void param(const param_type& parm); |
816 |
|
817 |
result_type min() const; |
818 |
result_type max() const; |
819 |
|
820 |
friend bool operator==(const poisson_distribution& x, |
821 |
const poisson_distribution& y); |
822 |
friend bool operator!=(const poisson_distribution& x, |
823 |
const poisson_distribution& y); |
824 |
|
825 |
template <class charT, class traits> |
826 |
friend |
827 |
basic_ostream<charT, traits>& |
828 |
operator<<(basic_ostream<charT, traits>& os, |
829 |
const poisson_distribution& x); |
830 |
|
831 |
template <class charT, class traits> |
832 |
friend |
833 |
basic_istream<charT, traits>& |
834 |
operator>>(basic_istream<charT, traits>& is, |
835 |
poisson_distribution& x); |
836 |
}; |
837 |
|
838 |
template<class RealType = double> |
839 |
class exponential_distribution |
840 |
{ |
841 |
public: |
842 |
// types |
843 |
typedef RealType result_type; |
844 |
|
845 |
class param_type |
846 |
{ |
847 |
public: |
848 |
typedef exponential_distribution distribution_type; |
849 |
|
850 |
explicit param_type(result_type lambda = 1.0); |
851 |
|
852 |
result_type lambda() const; |
853 |
|
854 |
friend bool operator==(const param_type& x, const param_type& y); |
855 |
friend bool operator!=(const param_type& x, const param_type& y); |
856 |
}; |
857 |
|
858 |
// constructors and reset functions |
859 |
explicit exponential_distribution(result_type lambda = 1.0); |
860 |
explicit exponential_distribution(const param_type& parm); |
861 |
void reset(); |
862 |
|
863 |
// generating functions |
864 |
template<class URNG> result_type operator()(URNG& g); |
865 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
866 |
|
867 |
// property functions |
868 |
result_type lambda() const; |
869 |
|
870 |
param_type param() const; |
871 |
void param(const param_type& parm); |
872 |
|
873 |
result_type min() const; |
874 |
result_type max() const; |
875 |
|
876 |
friend bool operator==(const exponential_distribution& x, |
877 |
const exponential_distribution& y); |
878 |
friend bool operator!=(const exponential_distribution& x, |
879 |
const exponential_distribution& y); |
880 |
|
881 |
template <class charT, class traits> |
882 |
friend |
883 |
basic_ostream<charT, traits>& |
884 |
operator<<(basic_ostream<charT, traits>& os, |
885 |
const exponential_distribution& x); |
886 |
|
887 |
template <class charT, class traits> |
888 |
friend |
889 |
basic_istream<charT, traits>& |
890 |
operator>>(basic_istream<charT, traits>& is, |
891 |
exponential_distribution& x); |
892 |
}; |
893 |
|
894 |
template<class RealType = double> |
895 |
class gamma_distribution |
896 |
{ |
897 |
public: |
898 |
// types |
899 |
typedef RealType result_type; |
900 |
|
901 |
class param_type |
902 |
{ |
903 |
public: |
904 |
typedef gamma_distribution distribution_type; |
905 |
|
906 |
explicit param_type(result_type alpha = 1, result_type beta = 1); |
907 |
|
908 |
result_type alpha() const; |
909 |
result_type beta() const; |
910 |
|
911 |
friend bool operator==(const param_type& x, const param_type& y); |
912 |
friend bool operator!=(const param_type& x, const param_type& y); |
913 |
}; |
914 |
|
915 |
// constructors and reset functions |
916 |
explicit gamma_distribution(result_type alpha = 1, result_type beta = 1); |
917 |
explicit gamma_distribution(const param_type& parm); |
918 |
void reset(); |
919 |
|
920 |
// generating functions |
921 |
template<class URNG> result_type operator()(URNG& g); |
922 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
923 |
|
924 |
// property functions |
925 |
result_type alpha() const; |
926 |
result_type beta() const; |
927 |
|
928 |
param_type param() const; |
929 |
void param(const param_type& parm); |
930 |
|
931 |
result_type min() const; |
932 |
result_type max() const; |
933 |
|
934 |
friend bool operator==(const gamma_distribution& x, |
935 |
const gamma_distribution& y); |
936 |
friend bool operator!=(const gamma_distribution& x, |
937 |
const gamma_distribution& y); |
938 |
|
939 |
template <class charT, class traits> |
940 |
friend |
941 |
basic_ostream<charT, traits>& |
942 |
operator<<(basic_ostream<charT, traits>& os, |
943 |
const gamma_distribution& x); |
944 |
|
945 |
template <class charT, class traits> |
946 |
friend |
947 |
basic_istream<charT, traits>& |
948 |
operator>>(basic_istream<charT, traits>& is, |
949 |
gamma_distribution& x); |
950 |
}; |
951 |
|
952 |
template<class RealType = double> |
953 |
class weibull_distribution |
954 |
{ |
955 |
public: |
956 |
// types |
957 |
typedef RealType result_type; |
958 |
|
959 |
class param_type |
960 |
{ |
961 |
public: |
962 |
typedef weibull_distribution distribution_type; |
963 |
|
964 |
explicit param_type(result_type alpha = 1, result_type beta = 1); |
965 |
|
966 |
result_type a() const; |
967 |
result_type b() const; |
968 |
|
969 |
friend bool operator==(const param_type& x, const param_type& y); |
970 |
friend bool operator!=(const param_type& x, const param_type& y); |
971 |
}; |
972 |
|
973 |
// constructor and reset functions |
974 |
explicit weibull_distribution(result_type a = 1, result_type b = 1); |
975 |
explicit weibull_distribution(const param_type& parm); |
976 |
void reset(); |
977 |
|
978 |
// generating functions |
979 |
template<class URNG> result_type operator()(URNG& g); |
980 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
981 |
|
982 |
// property functions |
983 |
result_type a() const; |
984 |
result_type b() const; |
985 |
|
986 |
param_type param() const; |
987 |
void param(const param_type& parm); |
988 |
|
989 |
result_type min() const; |
990 |
result_type max() const; |
991 |
|
992 |
friend bool operator==(const weibull_distribution& x, |
993 |
const weibull_distribution& y); |
994 |
friend bool operator!=(const weibull_distribution& x, |
995 |
const weibull_distribution& y); |
996 |
|
997 |
template <class charT, class traits> |
998 |
friend |
999 |
basic_ostream<charT, traits>& |
1000 |
operator<<(basic_ostream<charT, traits>& os, |
1001 |
const weibull_distribution& x); |
1002 |
|
1003 |
template <class charT, class traits> |
1004 |
friend |
1005 |
basic_istream<charT, traits>& |
1006 |
operator>>(basic_istream<charT, traits>& is, |
1007 |
weibull_distribution& x); |
1008 |
}; |
1009 |
|
1010 |
template<class RealType = double> |
1011 |
class extreme_value_distribution |
1012 |
{ |
1013 |
public: |
1014 |
// types |
1015 |
typedef RealType result_type; |
1016 |
|
1017 |
class param_type |
1018 |
{ |
1019 |
public: |
1020 |
typedef extreme_value_distribution distribution_type; |
1021 |
|
1022 |
explicit param_type(result_type a = 0, result_type b = 1); |
1023 |
|
1024 |
result_type a() const; |
1025 |
result_type b() const; |
1026 |
|
1027 |
friend bool operator==(const param_type& x, const param_type& y); |
1028 |
friend bool operator!=(const param_type& x, const param_type& y); |
1029 |
}; |
1030 |
|
1031 |
// constructor and reset functions |
1032 |
explicit extreme_value_distribution(result_type a = 0, result_type b = 1); |
1033 |
explicit extreme_value_distribution(const param_type& parm); |
1034 |
void reset(); |
1035 |
|
1036 |
// generating functions |
1037 |
template<class URNG> result_type operator()(URNG& g); |
1038 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1039 |
|
1040 |
// property functions |
1041 |
result_type a() const; |
1042 |
result_type b() const; |
1043 |
|
1044 |
param_type param() const; |
1045 |
void param(const param_type& parm); |
1046 |
|
1047 |
result_type min() const; |
1048 |
result_type max() const; |
1049 |
|
1050 |
friend bool operator==(const extreme_value_distribution& x, |
1051 |
const extreme_value_distribution& y); |
1052 |
friend bool operator!=(const extreme_value_distribution& x, |
1053 |
const extreme_value_distribution& y); |
1054 |
|
1055 |
template <class charT, class traits> |
1056 |
friend |
1057 |
basic_ostream<charT, traits>& |
1058 |
operator<<(basic_ostream<charT, traits>& os, |
1059 |
const extreme_value_distribution& x); |
1060 |
|
1061 |
template <class charT, class traits> |
1062 |
friend |
1063 |
basic_istream<charT, traits>& |
1064 |
operator>>(basic_istream<charT, traits>& is, |
1065 |
extreme_value_distribution& x); |
1066 |
}; |
1067 |
|
1068 |
template<class RealType = double> |
1069 |
class normal_distribution |
1070 |
{ |
1071 |
public: |
1072 |
// types |
1073 |
typedef RealType result_type; |
1074 |
|
1075 |
class param_type |
1076 |
{ |
1077 |
public: |
1078 |
typedef normal_distribution distribution_type; |
1079 |
|
1080 |
explicit param_type(result_type mean = 0, result_type stddev = 1); |
1081 |
|
1082 |
result_type mean() const; |
1083 |
result_type stddev() const; |
1084 |
|
1085 |
friend bool operator==(const param_type& x, const param_type& y); |
1086 |
friend bool operator!=(const param_type& x, const param_type& y); |
1087 |
}; |
1088 |
|
1089 |
// constructors and reset functions |
1090 |
explicit normal_distribution(result_type mean = 0, result_type stddev = 1); |
1091 |
explicit normal_distribution(const param_type& parm); |
1092 |
void reset(); |
1093 |
|
1094 |
// generating functions |
1095 |
template<class URNG> result_type operator()(URNG& g); |
1096 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1097 |
|
1098 |
// property functions |
1099 |
result_type mean() const; |
1100 |
result_type stddev() const; |
1101 |
|
1102 |
param_type param() const; |
1103 |
void param(const param_type& parm); |
1104 |
|
1105 |
result_type min() const; |
1106 |
result_type max() const; |
1107 |
|
1108 |
friend bool operator==(const normal_distribution& x, |
1109 |
const normal_distribution& y); |
1110 |
friend bool operator!=(const normal_distribution& x, |
1111 |
const normal_distribution& y); |
1112 |
|
1113 |
template <class charT, class traits> |
1114 |
friend |
1115 |
basic_ostream<charT, traits>& |
1116 |
operator<<(basic_ostream<charT, traits>& os, |
1117 |
const normal_distribution& x); |
1118 |
|
1119 |
template <class charT, class traits> |
1120 |
friend |
1121 |
basic_istream<charT, traits>& |
1122 |
operator>>(basic_istream<charT, traits>& is, |
1123 |
normal_distribution& x); |
1124 |
}; |
1125 |
|
1126 |
template<class RealType = double> |
1127 |
class lognormal_distribution |
1128 |
{ |
1129 |
public: |
1130 |
// types |
1131 |
typedef RealType result_type; |
1132 |
|
1133 |
class param_type |
1134 |
{ |
1135 |
public: |
1136 |
typedef lognormal_distribution distribution_type; |
1137 |
|
1138 |
explicit param_type(result_type m = 0, result_type s = 1); |
1139 |
|
1140 |
result_type m() const; |
1141 |
result_type s() const; |
1142 |
|
1143 |
friend bool operator==(const param_type& x, const param_type& y); |
1144 |
friend bool operator!=(const param_type& x, const param_type& y); |
1145 |
}; |
1146 |
|
1147 |
// constructor and reset functions |
1148 |
explicit lognormal_distribution(result_type m = 0, result_type s = 1); |
1149 |
explicit lognormal_distribution(const param_type& parm); |
1150 |
void reset(); |
1151 |
|
1152 |
// generating functions |
1153 |
template<class URNG> result_type operator()(URNG& g); |
1154 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1155 |
|
1156 |
// property functions |
1157 |
result_type m() const; |
1158 |
result_type s() const; |
1159 |
|
1160 |
param_type param() const; |
1161 |
void param(const param_type& parm); |
1162 |
|
1163 |
result_type min() const; |
1164 |
result_type max() const; |
1165 |
|
1166 |
friend bool operator==(const lognormal_distribution& x, |
1167 |
const lognormal_distribution& y); |
1168 |
friend bool operator!=(const lognormal_distribution& x, |
1169 |
const lognormal_distribution& y); |
1170 |
|
1171 |
template <class charT, class traits> |
1172 |
friend |
1173 |
basic_ostream<charT, traits>& |
1174 |
operator<<(basic_ostream<charT, traits>& os, |
1175 |
const lognormal_distribution& x); |
1176 |
|
1177 |
template <class charT, class traits> |
1178 |
friend |
1179 |
basic_istream<charT, traits>& |
1180 |
operator>>(basic_istream<charT, traits>& is, |
1181 |
lognormal_distribution& x); |
1182 |
}; |
1183 |
|
1184 |
template<class RealType = double> |
1185 |
class chi_squared_distribution |
1186 |
{ |
1187 |
public: |
1188 |
// types |
1189 |
typedef RealType result_type; |
1190 |
|
1191 |
class param_type |
1192 |
{ |
1193 |
public: |
1194 |
typedef chi_squared_distribution distribution_type; |
1195 |
|
1196 |
explicit param_type(result_type n = 1); |
1197 |
|
1198 |
result_type n() const; |
1199 |
|
1200 |
friend bool operator==(const param_type& x, const param_type& y); |
1201 |
friend bool operator!=(const param_type& x, const param_type& y); |
1202 |
}; |
1203 |
|
1204 |
// constructor and reset functions |
1205 |
explicit chi_squared_distribution(result_type n = 1); |
1206 |
explicit chi_squared_distribution(const param_type& parm); |
1207 |
void reset(); |
1208 |
|
1209 |
// generating functions |
1210 |
template<class URNG> result_type operator()(URNG& g); |
1211 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1212 |
|
1213 |
// property functions |
1214 |
result_type n() const; |
1215 |
|
1216 |
param_type param() const; |
1217 |
void param(const param_type& parm); |
1218 |
|
1219 |
result_type min() const; |
1220 |
result_type max() const; |
1221 |
|
1222 |
friend bool operator==(const chi_squared_distribution& x, |
1223 |
const chi_squared_distribution& y); |
1224 |
friend bool operator!=(const chi_squared_distribution& x, |
1225 |
const chi_squared_distribution& y); |
1226 |
|
1227 |
template <class charT, class traits> |
1228 |
friend |
1229 |
basic_ostream<charT, traits>& |
1230 |
operator<<(basic_ostream<charT, traits>& os, |
1231 |
const chi_squared_distribution& x); |
1232 |
|
1233 |
template <class charT, class traits> |
1234 |
friend |
1235 |
basic_istream<charT, traits>& |
1236 |
operator>>(basic_istream<charT, traits>& is, |
1237 |
chi_squared_distribution& x); |
1238 |
}; |
1239 |
|
1240 |
template<class RealType = double> |
1241 |
class cauchy_distribution |
1242 |
{ |
1243 |
public: |
1244 |
// types |
1245 |
typedef RealType result_type; |
1246 |
|
1247 |
class param_type |
1248 |
{ |
1249 |
public: |
1250 |
typedef cauchy_distribution distribution_type; |
1251 |
|
1252 |
explicit param_type(result_type a = 0, result_type b = 1); |
1253 |
|
1254 |
result_type a() const; |
1255 |
result_type b() const; |
1256 |
|
1257 |
friend bool operator==(const param_type& x, const param_type& y); |
1258 |
friend bool operator!=(const param_type& x, const param_type& y); |
1259 |
}; |
1260 |
|
1261 |
// constructor and reset functions |
1262 |
explicit cauchy_distribution(result_type a = 0, result_type b = 1); |
1263 |
explicit cauchy_distribution(const param_type& parm); |
1264 |
void reset(); |
1265 |
|
1266 |
// generating functions |
1267 |
template<class URNG> result_type operator()(URNG& g); |
1268 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1269 |
|
1270 |
// property functions |
1271 |
result_type a() const; |
1272 |
result_type b() const; |
1273 |
|
1274 |
param_type param() const; |
1275 |
void param(const param_type& parm); |
1276 |
|
1277 |
result_type min() const; |
1278 |
result_type max() const; |
1279 |
|
1280 |
friend bool operator==(const cauchy_distribution& x, |
1281 |
const cauchy_distribution& y); |
1282 |
friend bool operator!=(const cauchy_distribution& x, |
1283 |
const cauchy_distribution& y); |
1284 |
|
1285 |
template <class charT, class traits> |
1286 |
friend |
1287 |
basic_ostream<charT, traits>& |
1288 |
operator<<(basic_ostream<charT, traits>& os, |
1289 |
const cauchy_distribution& x); |
1290 |
|
1291 |
template <class charT, class traits> |
1292 |
friend |
1293 |
basic_istream<charT, traits>& |
1294 |
operator>>(basic_istream<charT, traits>& is, |
1295 |
cauchy_distribution& x); |
1296 |
}; |
1297 |
|
1298 |
template<class RealType = double> |
1299 |
class fisher_f_distribution |
1300 |
{ |
1301 |
public: |
1302 |
// types |
1303 |
typedef RealType result_type; |
1304 |
|
1305 |
class param_type |
1306 |
{ |
1307 |
public: |
1308 |
typedef fisher_f_distribution distribution_type; |
1309 |
|
1310 |
explicit param_type(result_type m = 1, result_type n = 1); |
1311 |
|
1312 |
result_type m() const; |
1313 |
result_type n() const; |
1314 |
|
1315 |
friend bool operator==(const param_type& x, const param_type& y); |
1316 |
friend bool operator!=(const param_type& x, const param_type& y); |
1317 |
}; |
1318 |
|
1319 |
// constructor and reset functions |
1320 |
explicit fisher_f_distribution(result_type m = 1, result_type n = 1); |
1321 |
explicit fisher_f_distribution(const param_type& parm); |
1322 |
void reset(); |
1323 |
|
1324 |
// generating functions |
1325 |
template<class URNG> result_type operator()(URNG& g); |
1326 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1327 |
|
1328 |
// property functions |
1329 |
result_type m() const; |
1330 |
result_type n() const; |
1331 |
|
1332 |
param_type param() const; |
1333 |
void param(const param_type& parm); |
1334 |
|
1335 |
result_type min() const; |
1336 |
result_type max() const; |
1337 |
|
1338 |
friend bool operator==(const fisher_f_distribution& x, |
1339 |
const fisher_f_distribution& y); |
1340 |
friend bool operator!=(const fisher_f_distribution& x, |
1341 |
const fisher_f_distribution& y); |
1342 |
|
1343 |
template <class charT, class traits> |
1344 |
friend |
1345 |
basic_ostream<charT, traits>& |
1346 |
operator<<(basic_ostream<charT, traits>& os, |
1347 |
const fisher_f_distribution& x); |
1348 |
|
1349 |
template <class charT, class traits> |
1350 |
friend |
1351 |
basic_istream<charT, traits>& |
1352 |
operator>>(basic_istream<charT, traits>& is, |
1353 |
fisher_f_distribution& x); |
1354 |
}; |
1355 |
|
1356 |
template<class RealType = double> |
1357 |
class student_t_distribution |
1358 |
{ |
1359 |
public: |
1360 |
// types |
1361 |
typedef RealType result_type; |
1362 |
|
1363 |
class param_type |
1364 |
{ |
1365 |
public: |
1366 |
typedef student_t_distribution distribution_type; |
1367 |
|
1368 |
explicit param_type(result_type n = 1); |
1369 |
|
1370 |
result_type n() const; |
1371 |
|
1372 |
friend bool operator==(const param_type& x, const param_type& y); |
1373 |
friend bool operator!=(const param_type& x, const param_type& y); |
1374 |
}; |
1375 |
|
1376 |
// constructor and reset functions |
1377 |
explicit student_t_distribution(result_type n = 1); |
1378 |
explicit student_t_distribution(const param_type& parm); |
1379 |
void reset(); |
1380 |
|
1381 |
// generating functions |
1382 |
template<class URNG> result_type operator()(URNG& g); |
1383 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1384 |
|
1385 |
// property functions |
1386 |
result_type n() const; |
1387 |
|
1388 |
param_type param() const; |
1389 |
void param(const param_type& parm); |
1390 |
|
1391 |
result_type min() const; |
1392 |
result_type max() const; |
1393 |
|
1394 |
friend bool operator==(const student_t_distribution& x, |
1395 |
const student_t_distribution& y); |
1396 |
friend bool operator!=(const student_t_distribution& x, |
1397 |
const student_t_distribution& y); |
1398 |
|
1399 |
template <class charT, class traits> |
1400 |
friend |
1401 |
basic_ostream<charT, traits>& |
1402 |
operator<<(basic_ostream<charT, traits>& os, |
1403 |
const student_t_distribution& x); |
1404 |
|
1405 |
template <class charT, class traits> |
1406 |
friend |
1407 |
basic_istream<charT, traits>& |
1408 |
operator>>(basic_istream<charT, traits>& is, |
1409 |
student_t_distribution& x); |
1410 |
}; |
1411 |
|
1412 |
template<class IntType = int> |
1413 |
class discrete_distribution |
1414 |
{ |
1415 |
public: |
1416 |
// types |
1417 |
typedef IntType result_type; |
1418 |
|
1419 |
class param_type |
1420 |
{ |
1421 |
public: |
1422 |
typedef discrete_distribution distribution_type; |
1423 |
|
1424 |
param_type(); |
1425 |
template<class InputIterator> |
1426 |
param_type(InputIterator firstW, InputIterator lastW); |
1427 |
param_type(initializer_list<double> wl); |
1428 |
template<class UnaryOperation> |
1429 |
param_type(size_t nw, double xmin, double xmax, UnaryOperation fw); |
1430 |
|
1431 |
vector<double> probabilities() const; |
1432 |
|
1433 |
friend bool operator==(const param_type& x, const param_type& y); |
1434 |
friend bool operator!=(const param_type& x, const param_type& y); |
1435 |
}; |
1436 |
|
1437 |
// constructor and reset functions |
1438 |
discrete_distribution(); |
1439 |
template<class InputIterator> |
1440 |
discrete_distribution(InputIterator firstW, InputIterator lastW); |
1441 |
discrete_distribution(initializer_list<double> wl); |
1442 |
template<class UnaryOperation> |
1443 |
discrete_distribution(size_t nw, double xmin, double xmax, |
1444 |
UnaryOperation fw); |
1445 |
explicit discrete_distribution(const param_type& parm); |
1446 |
void reset(); |
1447 |
|
1448 |
// generating functions |
1449 |
template<class URNG> result_type operator()(URNG& g); |
1450 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1451 |
|
1452 |
// property functions |
1453 |
vector<double> probabilities() const; |
1454 |
|
1455 |
param_type param() const; |
1456 |
void param(const param_type& parm); |
1457 |
|
1458 |
result_type min() const; |
1459 |
result_type max() const; |
1460 |
|
1461 |
friend bool operator==(const discrete_distribution& x, |
1462 |
const discrete_distribution& y); |
1463 |
friend bool operator!=(const discrete_distribution& x, |
1464 |
const discrete_distribution& y); |
1465 |
|
1466 |
template <class charT, class traits> |
1467 |
friend |
1468 |
basic_ostream<charT, traits>& |
1469 |
operator<<(basic_ostream<charT, traits>& os, |
1470 |
const discrete_distribution& x); |
1471 |
|
1472 |
template <class charT, class traits> |
1473 |
friend |
1474 |
basic_istream<charT, traits>& |
1475 |
operator>>(basic_istream<charT, traits>& is, |
1476 |
discrete_distribution& x); |
1477 |
}; |
1478 |
|
1479 |
template<class RealType = double> |
1480 |
class piecewise_constant_distribution |
1481 |
{ |
1482 |
// types |
1483 |
typedef RealType result_type; |
1484 |
|
1485 |
class param_type |
1486 |
{ |
1487 |
public: |
1488 |
typedef piecewise_constant_distribution distribution_type; |
1489 |
|
1490 |
param_type(); |
1491 |
template<class InputIteratorB, class InputIteratorW> |
1492 |
param_type(InputIteratorB firstB, InputIteratorB lastB, |
1493 |
InputIteratorW firstW); |
1494 |
template<class UnaryOperation> |
1495 |
param_type(initializer_list<result_type> bl, UnaryOperation fw); |
1496 |
template<class UnaryOperation> |
1497 |
param_type(size_t nw, result_type xmin, result_type xmax, |
1498 |
UnaryOperation fw); |
1499 |
|
1500 |
vector<result_type> intervals() const; |
1501 |
vector<result_type> densities() const; |
1502 |
|
1503 |
friend bool operator==(const param_type& x, const param_type& y); |
1504 |
friend bool operator!=(const param_type& x, const param_type& y); |
1505 |
}; |
1506 |
|
1507 |
// constructor and reset functions |
1508 |
piecewise_constant_distribution(); |
1509 |
template<class InputIteratorB, class InputIteratorW> |
1510 |
piecewise_constant_distribution(InputIteratorB firstB, |
1511 |
InputIteratorB lastB, |
1512 |
InputIteratorW firstW); |
1513 |
template<class UnaryOperation> |
1514 |
piecewise_constant_distribution(initializer_list<result_type> bl, |
1515 |
UnaryOperation fw); |
1516 |
template<class UnaryOperation> |
1517 |
piecewise_constant_distribution(size_t nw, result_type xmin, |
1518 |
result_type xmax, UnaryOperation fw); |
1519 |
explicit piecewise_constant_distribution(const param_type& parm); |
1520 |
void reset(); |
1521 |
|
1522 |
// generating functions |
1523 |
template<class URNG> result_type operator()(URNG& g); |
1524 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1525 |
|
1526 |
// property functions |
1527 |
vector<result_type> intervals() const; |
1528 |
vector<result_type> densities() const; |
1529 |
|
1530 |
param_type param() const; |
1531 |
void param(const param_type& parm); |
1532 |
|
1533 |
result_type min() const; |
1534 |
result_type max() const; |
1535 |
|
1536 |
friend bool operator==(const piecewise_constant_distribution& x, |
1537 |
const piecewise_constant_distribution& y); |
1538 |
friend bool operator!=(const piecewise_constant_distribution& x, |
1539 |
const piecewise_constant_distribution& y); |
1540 |
|
1541 |
template <class charT, class traits> |
1542 |
friend |
1543 |
basic_ostream<charT, traits>& |
1544 |
operator<<(basic_ostream<charT, traits>& os, |
1545 |
const piecewise_constant_distribution& x); |
1546 |
|
1547 |
template <class charT, class traits> |
1548 |
friend |
1549 |
basic_istream<charT, traits>& |
1550 |
operator>>(basic_istream<charT, traits>& is, |
1551 |
piecewise_constant_distribution& x); |
1552 |
}; |
1553 |
|
1554 |
template<class RealType = double> |
1555 |
class piecewise_linear_distribution |
1556 |
{ |
1557 |
// types |
1558 |
typedef RealType result_type; |
1559 |
|
1560 |
class param_type |
1561 |
{ |
1562 |
public: |
1563 |
typedef piecewise_linear_distribution distribution_type; |
1564 |
|
1565 |
param_type(); |
1566 |
template<class InputIteratorB, class InputIteratorW> |
1567 |
param_type(InputIteratorB firstB, InputIteratorB lastB, |
1568 |
InputIteratorW firstW); |
1569 |
template<class UnaryOperation> |
1570 |
param_type(initializer_list<result_type> bl, UnaryOperation fw); |
1571 |
template<class UnaryOperation> |
1572 |
param_type(size_t nw, result_type xmin, result_type xmax, |
1573 |
UnaryOperation fw); |
1574 |
|
1575 |
vector<result_type> intervals() const; |
1576 |
vector<result_type> densities() const; |
1577 |
|
1578 |
friend bool operator==(const param_type& x, const param_type& y); |
1579 |
friend bool operator!=(const param_type& x, const param_type& y); |
1580 |
}; |
1581 |
|
1582 |
// constructor and reset functions |
1583 |
piecewise_linear_distribution(); |
1584 |
template<class InputIteratorB, class InputIteratorW> |
1585 |
piecewise_linear_distribution(InputIteratorB firstB, |
1586 |
InputIteratorB lastB, |
1587 |
InputIteratorW firstW); |
1588 |
|
1589 |
template<class UnaryOperation> |
1590 |
piecewise_linear_distribution(initializer_list<result_type> bl, |
1591 |
UnaryOperation fw); |
1592 |
|
1593 |
template<class UnaryOperation> |
1594 |
piecewise_linear_distribution(size_t nw, result_type xmin, |
1595 |
result_type xmax, UnaryOperation fw); |
1596 |
|
1597 |
explicit piecewise_linear_distribution(const param_type& parm); |
1598 |
void reset(); |
1599 |
|
1600 |
// generating functions |
1601 |
template<class URNG> result_type operator()(URNG& g); |
1602 |
template<class URNG> result_type operator()(URNG& g, const param_type& parm); |
1603 |
|
1604 |
// property functions |
1605 |
vector<result_type> intervals() const; |
1606 |
vector<result_type> densities() const; |
1607 |
|
1608 |
param_type param() const; |
1609 |
void param(const param_type& parm); |
1610 |
|
1611 |
result_type min() const; |
1612 |
result_type max() const; |
1613 |
|
1614 |
friend bool operator==(const piecewise_linear_distribution& x, |
1615 |
const piecewise_linear_distribution& y); |
1616 |
friend bool operator!=(const piecewise_linear_distribution& x, |
1617 |
const piecewise_linear_distribution& y); |
1618 |
|
1619 |
template <class charT, class traits> |
1620 |
friend |
1621 |
basic_ostream<charT, traits>& |
1622 |
operator<<(basic_ostream<charT, traits>& os, |
1623 |
const piecewise_linear_distribution& x); |
1624 |
|
1625 |
template <class charT, class traits> |
1626 |
friend |
1627 |
basic_istream<charT, traits>& |
1628 |
operator>>(basic_istream<charT, traits>& is, |
1629 |
piecewise_linear_distribution& x); |
1630 |
}; |
1631 |
|
1632 |
} // std |
1633 |
*/ |
1634 |
|
1635 |
#include <__config> |
1636 |
#include <cstddef> |
1637 |
#include <cstdint> |
1638 |
#include <cmath> |
1639 |
#include <type_traits> |
1640 |
#include <initializer_list> |
1641 |
#include <limits> |
1642 |
#include <algorithm> |
1643 |
#include <numeric> |
1644 |
#include <vector> |
1645 |
#include <string> |
1646 |
#include <istream> |
1647 |
#include <ostream> |
1648 |
|
1649 |
#include <__undef_min_max> |
1650 |
|
1651 |
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) |
1652 |
#pragma GCC system_header |
1653 |
#endif |
1654 |
|
1655 |
_LIBCPP_BEGIN_NAMESPACE_STD |
1656 |
|
1657 |
// __is_seed_sequence |
1658 |
|
1659 |
template <class _Sseq, class _Engine> |
1660 |
struct __is_seed_sequence |
1661 |
{ |
1662 |
static _LIBCPP_CONSTEXPR const bool value = |
1663 |
!is_convertible<_Sseq, typename _Engine::result_type>::value && |
1664 |
!is_same<typename remove_cv<_Sseq>::type, _Engine>::value; |
1665 |
}; |
1666 |
|
1667 |
// linear_congruential_engine |
1668 |
|
1669 |
template <unsigned long long __a, unsigned long long __c, |
1670 |
unsigned long long __m, unsigned long long _Mp, |
1671 |
bool _MightOverflow = (__a != 0 && __m != 0 && __m-1 > (_Mp-__c)/__a)> |
1672 |
struct __lce_ta; |
1673 |
|
1674 |
// 64 |
1675 |
|
1676 |
template <unsigned long long __a, unsigned long long __c, unsigned long long __m> |
1677 |
struct __lce_ta<__a, __c, __m, (unsigned long long)(~0), true> |
1678 |
{ |
1679 |
typedef unsigned long long result_type; |
1680 |
_LIBCPP_INLINE_VISIBILITY |
1681 |
static result_type next(result_type __x) |
1682 |
{ |
1683 |
// Schrage's algorithm |
1684 |
const result_type __q = __m / __a; |
1685 |
const result_type __r = __m % __a; |
1686 |
const result_type __t0 = __a * (__x % __q); |
1687 |
const result_type __t1 = __r * (__x / __q); |
1688 |
__x = __t0 + (__t0 < __t1) * __m - __t1; |
1689 |
__x += __c - (__x >= __m - __c) * __m; |
1690 |
return __x; |
1691 |
} |
1692 |
}; |
1693 |
|
1694 |
template <unsigned long long __a, unsigned long long __m> |
1695 |
struct __lce_ta<__a, 0, __m, (unsigned long long)(~0), true> |
1696 |
{ |
1697 |
typedef unsigned long long result_type; |
1698 |
_LIBCPP_INLINE_VISIBILITY |
1699 |
static result_type next(result_type __x) |
1700 |
{ |
1701 |
// Schrage's algorithm |
1702 |
const result_type __q = __m / __a; |
1703 |
const result_type __r = __m % __a; |
1704 |
const result_type __t0 = __a * (__x % __q); |
1705 |
const result_type __t1 = __r * (__x / __q); |
1706 |
__x = __t0 + (__t0 < __t1) * __m - __t1; |
1707 |
return __x; |
1708 |
} |
1709 |
}; |
1710 |
|
1711 |
template <unsigned long long __a, unsigned long long __c, unsigned long long __m> |
1712 |
struct __lce_ta<__a, __c, __m, (unsigned long long)(~0), false> |
1713 |
{ |
1714 |
typedef unsigned long long result_type; |
1715 |
_LIBCPP_INLINE_VISIBILITY |
1716 |
static result_type next(result_type __x) |
1717 |
{ |
1718 |
return (__a * __x + __c) % __m; |
1719 |
} |
1720 |
}; |
1721 |
|
1722 |
template <unsigned long long __a, unsigned long long __c> |
1723 |
struct __lce_ta<__a, __c, 0, (unsigned long long)(~0), false> |
1724 |
{ |
1725 |
typedef unsigned long long result_type; |
1726 |
_LIBCPP_INLINE_VISIBILITY |
1727 |
static result_type next(result_type __x) |
1728 |
{ |
1729 |
return __a * __x + __c; |
1730 |
} |
1731 |
}; |
1732 |
|
1733 |
// 32 |
1734 |
|
1735 |
template <unsigned long long _Ap, unsigned long long _Cp, unsigned long long _Mp> |
1736 |
struct __lce_ta<_Ap, _Cp, _Mp, unsigned(~0), true> |
1737 |
{ |
1738 |
typedef unsigned result_type; |
1739 |
_LIBCPP_INLINE_VISIBILITY |
1740 |
static result_type next(result_type __x) |
1741 |
{ |
1742 |
const result_type __a = static_cast<result_type>(_Ap); |
1743 |
const result_type __c = static_cast<result_type>(_Cp); |
1744 |
const result_type __m = static_cast<result_type>(_Mp); |
1745 |
// Schrage's algorithm |
1746 |
const result_type __q = __m / __a; |
1747 |
const result_type __r = __m % __a; |
1748 |
const result_type __t0 = __a * (__x % __q); |
1749 |
const result_type __t1 = __r * (__x / __q); |
1750 |
__x = __t0 + (__t0 < __t1) * __m - __t1; |
1751 |
__x += __c - (__x >= __m - __c) * __m; |
1752 |
return __x; |
1753 |
} |
1754 |
}; |
1755 |
|
1756 |
template <unsigned long long _Ap, unsigned long long _Mp> |
1757 |
struct __lce_ta<_Ap, 0, _Mp, unsigned(~0), true> |
1758 |
{ |
1759 |
typedef unsigned result_type; |
1760 |
_LIBCPP_INLINE_VISIBILITY |
1761 |
static result_type next(result_type __x) |
1762 |
{ |
1763 |
const result_type __a = static_cast<result_type>(_Ap); |
1764 |
const result_type __m = static_cast<result_type>(_Mp); |
1765 |
// Schrage's algorithm |
1766 |
const result_type __q = __m / __a; |
1767 |
const result_type __r = __m % __a; |
1768 |
const result_type __t0 = __a * (__x % __q); |
1769 |
const result_type __t1 = __r * (__x / __q); |
1770 |
__x = __t0 + (__t0 < __t1) * __m - __t1; |
1771 |
return __x; |
1772 |
} |
1773 |
}; |
1774 |
|
1775 |
template <unsigned long long _Ap, unsigned long long _Cp, unsigned long long _Mp> |
1776 |
struct __lce_ta<_Ap, _Cp, _Mp, unsigned(~0), false> |
1777 |
{ |
1778 |
typedef unsigned result_type; |
1779 |
_LIBCPP_INLINE_VISIBILITY |
1780 |
static result_type next(result_type __x) |
1781 |
{ |
1782 |
const result_type __a = static_cast<result_type>(_Ap); |
1783 |
const result_type __c = static_cast<result_type>(_Cp); |
1784 |
const result_type __m = static_cast<result_type>(_Mp); |
1785 |
return (__a * __x + __c) % __m; |
1786 |
} |
1787 |
}; |
1788 |
|
1789 |
template <unsigned long long _Ap, unsigned long long _Cp> |
1790 |
struct __lce_ta<_Ap, _Cp, 0, unsigned(~0), false> |
1791 |
{ |
1792 |
typedef unsigned result_type; |
1793 |
_LIBCPP_INLINE_VISIBILITY |
1794 |
static result_type next(result_type __x) |
1795 |
{ |
1796 |
const result_type __a = static_cast<result_type>(_Ap); |
1797 |
const result_type __c = static_cast<result_type>(_Cp); |
1798 |
return __a * __x + __c; |
1799 |
} |
1800 |
}; |
1801 |
|
1802 |
// 16 |
1803 |
|
1804 |
template <unsigned long long __a, unsigned long long __c, unsigned long long __m, bool __b> |
1805 |
struct __lce_ta<__a, __c, __m, (unsigned short)(~0), __b> |
1806 |
{ |
1807 |
typedef unsigned short result_type; |
1808 |
_LIBCPP_INLINE_VISIBILITY |
1809 |
static result_type next(result_type __x) |
1810 |
{ |
1811 |
return static_cast<result_type>(__lce_ta<__a, __c, __m, unsigned(~0)>::next(__x)); |
1812 |
} |
1813 |
}; |
1814 |
|
1815 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1816 |
class _LIBCPP_TYPE_VIS_ONLY linear_congruential_engine; |
1817 |
|
1818 |
template <class _CharT, class _Traits, |
1819 |
class _Up, _Up _Ap, _Up _Cp, _Up _Np> |
1820 |
_LIBCPP_INLINE_VISIBILITY |
1821 |
basic_ostream<_CharT, _Traits>& |
1822 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
1823 |
const linear_congruential_engine<_Up, _Ap, _Cp, _Np>&); |
1824 |
|
1825 |
template <class _CharT, class _Traits, |
1826 |
class _Up, _Up _Ap, _Up _Cp, _Up _Np> |
1827 |
basic_istream<_CharT, _Traits>& |
1828 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
1829 |
linear_congruential_engine<_Up, _Ap, _Cp, _Np>& __x); |
1830 |
|
1831 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1832 |
class _LIBCPP_TYPE_VIS_ONLY linear_congruential_engine |
1833 |
{ |
1834 |
public: |
1835 |
// types |
1836 |
typedef _UIntType result_type; |
1837 |
|
1838 |
private: |
1839 |
result_type __x_; |
1840 |
|
1841 |
static _LIBCPP_CONSTEXPR const result_type _Mp = result_type(~0); |
1842 |
|
1843 |
static_assert(__m == 0 || __a < __m, "linear_congruential_engine invalid parameters"); |
1844 |
static_assert(__m == 0 || __c < __m, "linear_congruential_engine invalid parameters"); |
1845 |
public: |
1846 |
static _LIBCPP_CONSTEXPR const result_type _Min = __c == 0u ? 1u: 0u; |
1847 |
static _LIBCPP_CONSTEXPR const result_type _Max = __m - 1u; |
1848 |
static_assert(_Min < _Max, "linear_congruential_engine invalid parameters"); |
1849 |
|
1850 |
// engine characteristics |
1851 |
static _LIBCPP_CONSTEXPR const result_type multiplier = __a; |
1852 |
static _LIBCPP_CONSTEXPR const result_type increment = __c; |
1853 |
static _LIBCPP_CONSTEXPR const result_type modulus = __m; |
1854 |
_LIBCPP_INLINE_VISIBILITY |
1855 |
static _LIBCPP_CONSTEXPR result_type min() {return _Min;} |
1856 |
_LIBCPP_INLINE_VISIBILITY |
1857 |
static _LIBCPP_CONSTEXPR result_type max() {return _Max;} |
1858 |
static _LIBCPP_CONSTEXPR const result_type default_seed = 1u; |
1859 |
|
1860 |
// constructors and seeding functions |
1861 |
_LIBCPP_INLINE_VISIBILITY |
1862 |
explicit linear_congruential_engine(result_type __s = default_seed) |
1863 |
{seed(__s);} |
1864 |
template<class _Sseq> |
1865 |
_LIBCPP_INLINE_VISIBILITY |
1866 |
explicit linear_congruential_engine(_Sseq& __q, |
1867 |
typename enable_if<__is_seed_sequence<_Sseq, linear_congruential_engine>::value>::type* = 0) |
1868 |
{seed(__q);} |
1869 |
_LIBCPP_INLINE_VISIBILITY |
1870 |
void seed(result_type __s = default_seed) |
1871 |
{seed(integral_constant<bool, __m == 0>(), |
1872 |
integral_constant<bool, __c == 0>(), __s);} |
1873 |
template<class _Sseq> |
1874 |
_LIBCPP_INLINE_VISIBILITY |
1875 |
typename enable_if |
1876 |
< |
1877 |
__is_seed_sequence<_Sseq, linear_congruential_engine>::value, |
1878 |
void |
1879 |
>::type |
1880 |
seed(_Sseq& __q) |
1881 |
{__seed(__q, integral_constant<unsigned, |
1882 |
1 + (__m == 0 ? (sizeof(result_type) * __CHAR_BIT__ - 1)/32 |
1883 |
: (__m > 0x100000000ull))>());} |
1884 |
|
1885 |
// generating functions |
1886 |
_LIBCPP_INLINE_VISIBILITY |
1887 |
result_type operator()() |
1888 |
{return __x_ = static_cast<result_type>(__lce_ta<__a, __c, __m, _Mp>::next(__x_));} |
1889 |
_LIBCPP_INLINE_VISIBILITY |
1890 |
void discard(unsigned long long __z) {for (; __z; --__z) operator()();} |
1891 |
|
1892 |
friend _LIBCPP_INLINE_VISIBILITY |
1893 |
bool operator==(const linear_congruential_engine& __x, |
1894 |
const linear_congruential_engine& __y) |
1895 |
{return __x.__x_ == __y.__x_;} |
1896 |
friend _LIBCPP_INLINE_VISIBILITY |
1897 |
bool operator!=(const linear_congruential_engine& __x, |
1898 |
const linear_congruential_engine& __y) |
1899 |
{return !(__x == __y);} |
1900 |
|
1901 |
private: |
1902 |
|
1903 |
_LIBCPP_INLINE_VISIBILITY |
1904 |
void seed(true_type, true_type, result_type __s) {__x_ = __s == 0 ? 1 : __s;} |
1905 |
_LIBCPP_INLINE_VISIBILITY |
1906 |
void seed(true_type, false_type, result_type __s) {__x_ = __s;} |
1907 |
_LIBCPP_INLINE_VISIBILITY |
1908 |
void seed(false_type, true_type, result_type __s) {__x_ = __s % __m == 0 ? |
1909 |
1 : __s % __m;} |
1910 |
_LIBCPP_INLINE_VISIBILITY |
1911 |
void seed(false_type, false_type, result_type __s) {__x_ = __s % __m;} |
1912 |
|
1913 |
template<class _Sseq> |
1914 |
void __seed(_Sseq& __q, integral_constant<unsigned, 1>); |
1915 |
template<class _Sseq> |
1916 |
void __seed(_Sseq& __q, integral_constant<unsigned, 2>); |
1917 |
|
1918 |
template <class _CharT, class _Traits, |
1919 |
class _Up, _Up _Ap, _Up _Cp, _Up _Np> |
1920 |
friend |
1921 |
basic_ostream<_CharT, _Traits>& |
1922 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
1923 |
const linear_congruential_engine<_Up, _Ap, _Cp, _Np>&); |
1924 |
|
1925 |
template <class _CharT, class _Traits, |
1926 |
class _Up, _Up _Ap, _Up _Cp, _Up _Np> |
1927 |
friend |
1928 |
basic_istream<_CharT, _Traits>& |
1929 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
1930 |
linear_congruential_engine<_Up, _Ap, _Cp, _Np>& __x); |
1931 |
}; |
1932 |
|
1933 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1934 |
_LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type |
1935 |
linear_congruential_engine<_UIntType, __a, __c, __m>::multiplier; |
1936 |
|
1937 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1938 |
_LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type |
1939 |
linear_congruential_engine<_UIntType, __a, __c, __m>::increment; |
1940 |
|
1941 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1942 |
_LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type |
1943 |
linear_congruential_engine<_UIntType, __a, __c, __m>::modulus; |
1944 |
|
1945 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1946 |
_LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type |
1947 |
linear_congruential_engine<_UIntType, __a, __c, __m>::default_seed; |
1948 |
|
1949 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1950 |
template<class _Sseq> |
1951 |
void |
1952 |
linear_congruential_engine<_UIntType, __a, __c, __m>::__seed(_Sseq& __q, |
1953 |
integral_constant<unsigned, 1>) |
1954 |
{ |
1955 |
const unsigned __k = 1; |
1956 |
uint32_t __ar[__k+3]; |
1957 |
__q.generate(__ar, __ar + __k + 3); |
1958 |
result_type __s = static_cast<result_type>(__ar[3] % __m); |
1959 |
__x_ = __c == 0 && __s == 0 ? result_type(1) : __s; |
1960 |
} |
1961 |
|
1962 |
template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1963 |
template<class _Sseq> |
1964 |
void |
1965 |
linear_congruential_engine<_UIntType, __a, __c, __m>::__seed(_Sseq& __q, |
1966 |
integral_constant<unsigned, 2>) |
1967 |
{ |
1968 |
const unsigned __k = 2; |
1969 |
uint32_t __ar[__k+3]; |
1970 |
__q.generate(__ar, __ar + __k + 3); |
1971 |
result_type __s = static_cast<result_type>((__ar[3] + |
1972 |
((uint64_t)__ar[4] << 32)) % __m); |
1973 |
__x_ = __c == 0 && __s == 0 ? result_type(1) : __s; |
1974 |
} |
1975 |
|
1976 |
template <class _CharT, class _Traits, |
1977 |
class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1978 |
inline _LIBCPP_INLINE_VISIBILITY |
1979 |
basic_ostream<_CharT, _Traits>& |
1980 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
1981 |
const linear_congruential_engine<_UIntType, __a, __c, __m>& __x) |
1982 |
{ |
1983 |
__save_flags<_CharT, _Traits> __lx(__os); |
1984 |
__os.flags(ios_base::dec | ios_base::left); |
1985 |
__os.fill(__os.widen(' ')); |
1986 |
return __os << __x.__x_; |
1987 |
} |
1988 |
|
1989 |
template <class _CharT, class _Traits, |
1990 |
class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> |
1991 |
basic_istream<_CharT, _Traits>& |
1992 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
1993 |
linear_congruential_engine<_UIntType, __a, __c, __m>& __x) |
1994 |
{ |
1995 |
__save_flags<_CharT, _Traits> __lx(__is); |
1996 |
__is.flags(ios_base::dec | ios_base::skipws); |
1997 |
_UIntType __t; |
1998 |
__is >> __t; |
1999 |
if (!__is.fail()) |
2000 |
__x.__x_ = __t; |
2001 |
return __is; |
2002 |
} |
2003 |
|
2004 |
typedef linear_congruential_engine<uint_fast32_t, 16807, 0, 2147483647> |
2005 |
minstd_rand0; |
2006 |
typedef linear_congruential_engine<uint_fast32_t, 48271, 0, 2147483647> |
2007 |
minstd_rand; |
2008 |
typedef minstd_rand default_random_engine; |
2009 |
// mersenne_twister_engine |
2010 |
|
2011 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2012 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2013 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2014 |
class _LIBCPP_TYPE_VIS_ONLY mersenne_twister_engine; |
2015 |
|
2016 |
template <class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2017 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2018 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2019 |
bool |
2020 |
operator==(const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2021 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x, |
2022 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2023 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __y); |
2024 |
|
2025 |
template <class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2026 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2027 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2028 |
_LIBCPP_INLINE_VISIBILITY |
2029 |
bool |
2030 |
operator!=(const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2031 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x, |
2032 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2033 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __y); |
2034 |
|
2035 |
template <class _CharT, class _Traits, |
2036 |
class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2037 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2038 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2039 |
basic_ostream<_CharT, _Traits>& |
2040 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2041 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2042 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x); |
2043 |
|
2044 |
template <class _CharT, class _Traits, |
2045 |
class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2046 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2047 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2048 |
basic_istream<_CharT, _Traits>& |
2049 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2050 |
mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2051 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x); |
2052 |
|
2053 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2054 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2055 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2056 |
class _LIBCPP_TYPE_VIS_ONLY mersenne_twister_engine |
2057 |
{ |
2058 |
public: |
2059 |
// types |
2060 |
typedef _UIntType result_type; |
2061 |
|
2062 |
private: |
2063 |
result_type __x_[__n]; |
2064 |
size_t __i_; |
2065 |
|
2066 |
static_assert( 0 < __m, "mersenne_twister_engine invalid parameters"); |
2067 |
static_assert(__m <= __n, "mersenne_twister_engine invalid parameters"); |
2068 |
static _LIBCPP_CONSTEXPR const result_type _Dt = numeric_limits<result_type>::digits; |
2069 |
static_assert(__w <= _Dt, "mersenne_twister_engine invalid parameters"); |
2070 |
static_assert( 2 <= __w, "mersenne_twister_engine invalid parameters"); |
2071 |
static_assert(__r <= __w, "mersenne_twister_engine invalid parameters"); |
2072 |
static_assert(__u <= __w, "mersenne_twister_engine invalid parameters"); |
2073 |
static_assert(__s <= __w, "mersenne_twister_engine invalid parameters"); |
2074 |
static_assert(__t <= __w, "mersenne_twister_engine invalid parameters"); |
2075 |
static_assert(__l <= __w, "mersenne_twister_engine invalid parameters"); |
2076 |
public: |
2077 |
static _LIBCPP_CONSTEXPR const result_type _Min = 0; |
2078 |
static _LIBCPP_CONSTEXPR const result_type _Max = __w == _Dt ? result_type(~0) : |
2079 |
(result_type(1) << __w) - result_type(1); |
2080 |
static_assert(_Min < _Max, "mersenne_twister_engine invalid parameters"); |
2081 |
static_assert(__a <= _Max, "mersenne_twister_engine invalid parameters"); |
2082 |
static_assert(__b <= _Max, "mersenne_twister_engine invalid parameters"); |
2083 |
static_assert(__c <= _Max, "mersenne_twister_engine invalid parameters"); |
2084 |
static_assert(__d <= _Max, "mersenne_twister_engine invalid parameters"); |
2085 |
static_assert(__f <= _Max, "mersenne_twister_engine invalid parameters"); |
2086 |
|
2087 |
// engine characteristics |
2088 |
static _LIBCPP_CONSTEXPR const size_t word_size = __w; |
2089 |
static _LIBCPP_CONSTEXPR const size_t state_size = __n; |
2090 |
static _LIBCPP_CONSTEXPR const size_t shift_size = __m; |
2091 |
static _LIBCPP_CONSTEXPR const size_t mask_bits = __r; |
2092 |
static _LIBCPP_CONSTEXPR const result_type xor_mask = __a; |
2093 |
static _LIBCPP_CONSTEXPR const size_t tempering_u = __u; |
2094 |
static _LIBCPP_CONSTEXPR const result_type tempering_d = __d; |
2095 |
static _LIBCPP_CONSTEXPR const size_t tempering_s = __s; |
2096 |
static _LIBCPP_CONSTEXPR const result_type tempering_b = __b; |
2097 |
static _LIBCPP_CONSTEXPR const size_t tempering_t = __t; |
2098 |
static _LIBCPP_CONSTEXPR const result_type tempering_c = __c; |
2099 |
static _LIBCPP_CONSTEXPR const size_t tempering_l = __l; |
2100 |
static _LIBCPP_CONSTEXPR const result_type initialization_multiplier = __f; |
2101 |
_LIBCPP_INLINE_VISIBILITY |
2102 |
static _LIBCPP_CONSTEXPR result_type min() { return _Min; } |
2103 |
_LIBCPP_INLINE_VISIBILITY |
2104 |
static _LIBCPP_CONSTEXPR result_type max() { return _Max; } |
2105 |
static _LIBCPP_CONSTEXPR const result_type default_seed = 5489u; |
2106 |
|
2107 |
// constructors and seeding functions |
2108 |
_LIBCPP_INLINE_VISIBILITY |
2109 |
explicit mersenne_twister_engine(result_type __sd = default_seed) |
2110 |
{seed(__sd);} |
2111 |
template<class _Sseq> |
2112 |
_LIBCPP_INLINE_VISIBILITY |
2113 |
explicit mersenne_twister_engine(_Sseq& __q, |
2114 |
typename enable_if<__is_seed_sequence<_Sseq, mersenne_twister_engine>::value>::type* = 0) |
2115 |
{seed(__q);} |
2116 |
void seed(result_type __sd = default_seed); |
2117 |
template<class _Sseq> |
2118 |
_LIBCPP_INLINE_VISIBILITY |
2119 |
typename enable_if |
2120 |
< |
2121 |
__is_seed_sequence<_Sseq, mersenne_twister_engine>::value, |
2122 |
void |
2123 |
>::type |
2124 |
seed(_Sseq& __q) |
2125 |
{__seed(__q, integral_constant<unsigned, 1 + (__w - 1) / 32>());} |
2126 |
|
2127 |
// generating functions |
2128 |
result_type operator()(); |
2129 |
_LIBCPP_INLINE_VISIBILITY |
2130 |
void discard(unsigned long long __z) {for (; __z; --__z) operator()();} |
2131 |
|
2132 |
template <class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2133 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2134 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2135 |
friend |
2136 |
bool |
2137 |
operator==(const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2138 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x, |
2139 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2140 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __y); |
2141 |
|
2142 |
template <class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2143 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2144 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2145 |
friend |
2146 |
bool |
2147 |
operator!=(const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2148 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x, |
2149 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2150 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __y); |
2151 |
|
2152 |
template <class _CharT, class _Traits, |
2153 |
class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2154 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2155 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2156 |
friend |
2157 |
basic_ostream<_CharT, _Traits>& |
2158 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2159 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2160 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x); |
2161 |
|
2162 |
template <class _CharT, class _Traits, |
2163 |
class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2164 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2165 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2166 |
friend |
2167 |
basic_istream<_CharT, _Traits>& |
2168 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2169 |
mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2170 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x); |
2171 |
private: |
2172 |
|
2173 |
template<class _Sseq> |
2174 |
void __seed(_Sseq& __q, integral_constant<unsigned, 1>); |
2175 |
template<class _Sseq> |
2176 |
void __seed(_Sseq& __q, integral_constant<unsigned, 2>); |
2177 |
|
2178 |
template <size_t __count> |
2179 |
_LIBCPP_INLINE_VISIBILITY |
2180 |
static |
2181 |
typename enable_if |
2182 |
< |
2183 |
__count < __w, |
2184 |
result_type |
2185 |
>::type |
2186 |
__lshift(result_type __x) {return (__x << __count) & _Max;} |
2187 |
|
2188 |
template <size_t __count> |
2189 |
_LIBCPP_INLINE_VISIBILITY |
2190 |
static |
2191 |
typename enable_if |
2192 |
< |
2193 |
(__count >= __w), |
2194 |
result_type |
2195 |
>::type |
2196 |
__lshift(result_type) {return result_type(0);} |
2197 |
|
2198 |
template <size_t __count> |
2199 |
_LIBCPP_INLINE_VISIBILITY |
2200 |
static |
2201 |
typename enable_if |
2202 |
< |
2203 |
__count < _Dt, |
2204 |
result_type |
2205 |
>::type |
2206 |
__rshift(result_type __x) {return __x >> __count;} |
2207 |
|
2208 |
template <size_t __count> |
2209 |
_LIBCPP_INLINE_VISIBILITY |
2210 |
static |
2211 |
typename enable_if |
2212 |
< |
2213 |
(__count >= _Dt), |
2214 |
result_type |
2215 |
>::type |
2216 |
__rshift(result_type) {return result_type(0);} |
2217 |
}; |
2218 |
|
2219 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2220 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2221 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2222 |
_LIBCPP_CONSTEXPR const size_t |
2223 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::word_size; |
2224 |
|
2225 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2226 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2227 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2228 |
_LIBCPP_CONSTEXPR const size_t |
2229 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::state_size; |
2230 |
|
2231 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2232 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2233 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2234 |
_LIBCPP_CONSTEXPR const size_t |
2235 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::shift_size; |
2236 |
|
2237 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2238 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2239 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2240 |
_LIBCPP_CONSTEXPR const size_t |
2241 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::mask_bits; |
2242 |
|
2243 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2244 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2245 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2246 |
_LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type |
2247 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::xor_mask; |
2248 |
|
2249 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2250 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2251 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2252 |
_LIBCPP_CONSTEXPR const size_t |
2253 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_u; |
2254 |
|
2255 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2256 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2257 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2258 |
_LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type |
2259 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_d; |
2260 |
|
2261 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2262 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2263 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2264 |
_LIBCPP_CONSTEXPR const size_t |
2265 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_s; |
2266 |
|
2267 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2268 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2269 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2270 |
_LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type |
2271 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_b; |
2272 |
|
2273 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2274 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2275 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2276 |
_LIBCPP_CONSTEXPR const size_t |
2277 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_t; |
2278 |
|
2279 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2280 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2281 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2282 |
_LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type |
2283 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_c; |
2284 |
|
2285 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2286 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2287 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2288 |
_LIBCPP_CONSTEXPR const size_t |
2289 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_l; |
2290 |
|
2291 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2292 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2293 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2294 |
_LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type |
2295 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::initialization_multiplier; |
2296 |
|
2297 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2298 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2299 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2300 |
_LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type |
2301 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::default_seed; |
2302 |
|
2303 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2304 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2305 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2306 |
void |
2307 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, |
2308 |
__t, __c, __l, __f>::seed(result_type __sd) |
2309 |
{ // __w >= 2 |
2310 |
__x_[0] = __sd & _Max; |
2311 |
for (size_t __i = 1; __i < __n; ++__i) |
2312 |
__x_[__i] = (__f * (__x_[__i-1] ^ __rshift<__w - 2>(__x_[__i-1])) + __i) & _Max; |
2313 |
__i_ = 0; |
2314 |
} |
2315 |
|
2316 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2317 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2318 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2319 |
template<class _Sseq> |
2320 |
void |
2321 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, |
2322 |
__t, __c, __l, __f>::__seed(_Sseq& __q, integral_constant<unsigned, 1>) |
2323 |
{ |
2324 |
const unsigned __k = 1; |
2325 |
uint32_t __ar[__n * __k]; |
2326 |
__q.generate(__ar, __ar + __n * __k); |
2327 |
for (size_t __i = 0; __i < __n; ++__i) |
2328 |
__x_[__i] = static_cast<result_type>(__ar[__i] & _Max); |
2329 |
const result_type __mask = __r == _Dt ? result_type(~0) : |
2330 |
(result_type(1) << __r) - result_type(1); |
2331 |
__i_ = 0; |
2332 |
if ((__x_[0] & ~__mask) == 0) |
2333 |
{ |
2334 |
for (size_t __i = 1; __i < __n; ++__i) |
2335 |
if (__x_[__i] != 0) |
2336 |
return; |
2337 |
__x_[0] = _Max; |
2338 |
} |
2339 |
} |
2340 |
|
2341 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2342 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2343 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2344 |
template<class _Sseq> |
2345 |
void |
2346 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, |
2347 |
__t, __c, __l, __f>::__seed(_Sseq& __q, integral_constant<unsigned, 2>) |
2348 |
{ |
2349 |
const unsigned __k = 2; |
2350 |
uint32_t __ar[__n * __k]; |
2351 |
__q.generate(__ar, __ar + __n * __k); |
2352 |
for (size_t __i = 0; __i < __n; ++__i) |
2353 |
__x_[__i] = static_cast<result_type>( |
2354 |
(__ar[2 * __i] + ((uint64_t)__ar[2 * __i + 1] << 32)) & _Max); |
2355 |
const result_type __mask = __r == _Dt ? result_type(~0) : |
2356 |
(result_type(1) << __r) - result_type(1); |
2357 |
__i_ = 0; |
2358 |
if ((__x_[0] & ~__mask) == 0) |
2359 |
{ |
2360 |
for (size_t __i = 1; __i < __n; ++__i) |
2361 |
if (__x_[__i] != 0) |
2362 |
return; |
2363 |
__x_[0] = _Max; |
2364 |
} |
2365 |
} |
2366 |
|
2367 |
template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, |
2368 |
_UIntType __a, size_t __u, _UIntType __d, size_t __s, |
2369 |
_UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> |
2370 |
_UIntType |
2371 |
mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, |
2372 |
__t, __c, __l, __f>::operator()() |
2373 |
{ |
2374 |
const size_t __j = (__i_ + 1) % __n; |
2375 |
const result_type __mask = __r == _Dt ? result_type(~0) : |
2376 |
(result_type(1) << __r) - result_type(1); |
2377 |
const result_type _Yp = (__x_[__i_] & ~__mask) | (__x_[__j] & __mask); |
2378 |
const size_t __k = (__i_ + __m) % __n; |
2379 |
__x_[__i_] = __x_[__k] ^ __rshift<1>(_Yp) ^ (__a * (_Yp & 1)); |
2380 |
result_type __z = __x_[__i_] ^ (__rshift<__u>(__x_[__i_]) & __d); |
2381 |
__i_ = __j; |
2382 |
__z ^= __lshift<__s>(__z) & __b; |
2383 |
__z ^= __lshift<__t>(__z) & __c; |
2384 |
return __z ^ __rshift<__l>(__z); |
2385 |
} |
2386 |
|
2387 |
template <class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2388 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2389 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2390 |
bool |
2391 |
operator==(const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2392 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x, |
2393 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2394 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __y) |
2395 |
{ |
2396 |
if (__x.__i_ == __y.__i_) |
2397 |
return _VSTD::equal(__x.__x_, __x.__x_ + _Np, __y.__x_); |
2398 |
if (__x.__i_ == 0 || __y.__i_ == 0) |
2399 |
{ |
2400 |
size_t __j = _VSTD::min(_Np - __x.__i_, _Np - __y.__i_); |
2401 |
if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, |
2402 |
__y.__x_ + __y.__i_)) |
2403 |
return false; |
2404 |
if (__x.__i_ == 0) |
2405 |
return _VSTD::equal(__x.__x_ + __j, __x.__x_ + _Np, __y.__x_); |
2406 |
return _VSTD::equal(__x.__x_, __x.__x_ + (_Np - __j), __y.__x_ + __j); |
2407 |
} |
2408 |
if (__x.__i_ < __y.__i_) |
2409 |
{ |
2410 |
size_t __j = _Np - __y.__i_; |
2411 |
if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), |
2412 |
__y.__x_ + __y.__i_)) |
2413 |
return false; |
2414 |
if (!_VSTD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _Np, |
2415 |
__y.__x_)) |
2416 |
return false; |
2417 |
return _VSTD::equal(__x.__x_, __x.__x_ + __x.__i_, |
2418 |
__y.__x_ + (_Np - (__x.__i_ + __j))); |
2419 |
} |
2420 |
size_t __j = _Np - __x.__i_; |
2421 |
if (!_VSTD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), |
2422 |
__x.__x_ + __x.__i_)) |
2423 |
return false; |
2424 |
if (!_VSTD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _Np, |
2425 |
__x.__x_)) |
2426 |
return false; |
2427 |
return _VSTD::equal(__y.__x_, __y.__x_ + __y.__i_, |
2428 |
__x.__x_ + (_Np - (__y.__i_ + __j))); |
2429 |
} |
2430 |
|
2431 |
template <class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2432 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2433 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2434 |
inline _LIBCPP_INLINE_VISIBILITY |
2435 |
bool |
2436 |
operator!=(const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2437 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x, |
2438 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2439 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __y) |
2440 |
{ |
2441 |
return !(__x == __y); |
2442 |
} |
2443 |
|
2444 |
template <class _CharT, class _Traits, |
2445 |
class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2446 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2447 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2448 |
basic_ostream<_CharT, _Traits>& |
2449 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2450 |
const mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2451 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x) |
2452 |
{ |
2453 |
__save_flags<_CharT, _Traits> __lx(__os); |
2454 |
__os.flags(ios_base::dec | ios_base::left); |
2455 |
_CharT __sp = __os.widen(' '); |
2456 |
__os.fill(__sp); |
2457 |
__os << __x.__x_[__x.__i_]; |
2458 |
for (size_t __j = __x.__i_ + 1; __j < _Np; ++__j) |
2459 |
__os << __sp << __x.__x_[__j]; |
2460 |
for (size_t __j = 0; __j < __x.__i_; ++__j) |
2461 |
__os << __sp << __x.__x_[__j]; |
2462 |
return __os; |
2463 |
} |
2464 |
|
2465 |
template <class _CharT, class _Traits, |
2466 |
class _UI, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, |
2467 |
_UI _Ap, size_t _Up, _UI _Dp, size_t _Sp, |
2468 |
_UI _Bp, size_t _Tp, _UI _Cp, size_t _Lp, _UI _Fp> |
2469 |
basic_istream<_CharT, _Traits>& |
2470 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2471 |
mersenne_twister_engine<_UI, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, |
2472 |
_Bp, _Tp, _Cp, _Lp, _Fp>& __x) |
2473 |
{ |
2474 |
__save_flags<_CharT, _Traits> __lx(__is); |
2475 |
__is.flags(ios_base::dec | ios_base::skipws); |
2476 |
_UI __t[_Np]; |
2477 |
for (size_t __i = 0; __i < _Np; ++__i) |
2478 |
__is >> __t[__i]; |
2479 |
if (!__is.fail()) |
2480 |
{ |
2481 |
for (size_t __i = 0; __i < _Np; ++__i) |
2482 |
__x.__x_[__i] = __t[__i]; |
2483 |
__x.__i_ = 0; |
2484 |
} |
2485 |
return __is; |
2486 |
} |
2487 |
|
2488 |
typedef mersenne_twister_engine<uint_fast32_t, 32, 624, 397, 31, |
2489 |
0x9908b0df, 11, 0xffffffff, |
2490 |
7, 0x9d2c5680, |
2491 |
15, 0xefc60000, |
2492 |
18, 1812433253> mt19937; |
2493 |
typedef mersenne_twister_engine<uint_fast64_t, 64, 312, 156, 31, |
2494 |
0xb5026f5aa96619e9ULL, 29, 0x5555555555555555ULL, |
2495 |
17, 0x71d67fffeda60000ULL, |
2496 |
37, 0xfff7eee000000000ULL, |
2497 |
43, 6364136223846793005ULL> mt19937_64; |
2498 |
|
2499 |
// subtract_with_carry_engine |
2500 |
|
2501 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2502 |
class _LIBCPP_TYPE_VIS_ONLY subtract_with_carry_engine; |
2503 |
|
2504 |
template<class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2505 |
bool |
2506 |
operator==( |
2507 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x, |
2508 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __y); |
2509 |
|
2510 |
template<class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2511 |
_LIBCPP_INLINE_VISIBILITY |
2512 |
bool |
2513 |
operator!=( |
2514 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x, |
2515 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __y); |
2516 |
|
2517 |
template <class _CharT, class _Traits, |
2518 |
class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2519 |
basic_ostream<_CharT, _Traits>& |
2520 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2521 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x); |
2522 |
|
2523 |
template <class _CharT, class _Traits, |
2524 |
class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2525 |
basic_istream<_CharT, _Traits>& |
2526 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2527 |
subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x); |
2528 |
|
2529 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2530 |
class _LIBCPP_TYPE_VIS_ONLY subtract_with_carry_engine |
2531 |
{ |
2532 |
public: |
2533 |
// types |
2534 |
typedef _UIntType result_type; |
2535 |
|
2536 |
private: |
2537 |
result_type __x_[__r]; |
2538 |
result_type __c_; |
2539 |
size_t __i_; |
2540 |
|
2541 |
static _LIBCPP_CONSTEXPR const result_type _Dt = numeric_limits<result_type>::digits; |
2542 |
static_assert( 0 < __w, "subtract_with_carry_engine invalid parameters"); |
2543 |
static_assert(__w <= _Dt, "subtract_with_carry_engine invalid parameters"); |
2544 |
static_assert( 0 < __s, "subtract_with_carry_engine invalid parameters"); |
2545 |
static_assert(__s < __r, "subtract_with_carry_engine invalid parameters"); |
2546 |
public: |
2547 |
static _LIBCPP_CONSTEXPR const result_type _Min = 0; |
2548 |
static _LIBCPP_CONSTEXPR const result_type _Max = __w == _Dt ? result_type(~0) : |
2549 |
(result_type(1) << __w) - result_type(1); |
2550 |
static_assert(_Min < _Max, "subtract_with_carry_engine invalid parameters"); |
2551 |
|
2552 |
// engine characteristics |
2553 |
static _LIBCPP_CONSTEXPR const size_t word_size = __w; |
2554 |
static _LIBCPP_CONSTEXPR const size_t short_lag = __s; |
2555 |
static _LIBCPP_CONSTEXPR const size_t long_lag = __r; |
2556 |
_LIBCPP_INLINE_VISIBILITY |
2557 |
static _LIBCPP_CONSTEXPR result_type min() { return _Min; } |
2558 |
_LIBCPP_INLINE_VISIBILITY |
2559 |
static _LIBCPP_CONSTEXPR result_type max() { return _Max; } |
2560 |
static _LIBCPP_CONSTEXPR const result_type default_seed = 19780503u; |
2561 |
|
2562 |
// constructors and seeding functions |
2563 |
_LIBCPP_INLINE_VISIBILITY |
2564 |
explicit subtract_with_carry_engine(result_type __sd = default_seed) |
2565 |
{seed(__sd);} |
2566 |
template<class _Sseq> |
2567 |
_LIBCPP_INLINE_VISIBILITY |
2568 |
explicit subtract_with_carry_engine(_Sseq& __q, |
2569 |
typename enable_if<__is_seed_sequence<_Sseq, subtract_with_carry_engine>::value>::type* = 0) |
2570 |
{seed(__q);} |
2571 |
_LIBCPP_INLINE_VISIBILITY |
2572 |
void seed(result_type __sd = default_seed) |
2573 |
{seed(__sd, integral_constant<unsigned, 1 + (__w - 1) / 32>());} |
2574 |
template<class _Sseq> |
2575 |
_LIBCPP_INLINE_VISIBILITY |
2576 |
typename enable_if |
2577 |
< |
2578 |
__is_seed_sequence<_Sseq, subtract_with_carry_engine>::value, |
2579 |
void |
2580 |
>::type |
2581 |
seed(_Sseq& __q) |
2582 |
{__seed(__q, integral_constant<unsigned, 1 + (__w - 1) / 32>());} |
2583 |
|
2584 |
// generating functions |
2585 |
result_type operator()(); |
2586 |
_LIBCPP_INLINE_VISIBILITY |
2587 |
void discard(unsigned long long __z) {for (; __z; --__z) operator()();} |
2588 |
|
2589 |
template<class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2590 |
friend |
2591 |
bool |
2592 |
operator==( |
2593 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x, |
2594 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __y); |
2595 |
|
2596 |
template<class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2597 |
friend |
2598 |
bool |
2599 |
operator!=( |
2600 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x, |
2601 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __y); |
2602 |
|
2603 |
template <class _CharT, class _Traits, |
2604 |
class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2605 |
friend |
2606 |
basic_ostream<_CharT, _Traits>& |
2607 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2608 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x); |
2609 |
|
2610 |
template <class _CharT, class _Traits, |
2611 |
class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2612 |
friend |
2613 |
basic_istream<_CharT, _Traits>& |
2614 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2615 |
subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x); |
2616 |
|
2617 |
private: |
2618 |
|
2619 |
void seed(result_type __sd, integral_constant<unsigned, 1>); |
2620 |
void seed(result_type __sd, integral_constant<unsigned, 2>); |
2621 |
template<class _Sseq> |
2622 |
void __seed(_Sseq& __q, integral_constant<unsigned, 1>); |
2623 |
template<class _Sseq> |
2624 |
void __seed(_Sseq& __q, integral_constant<unsigned, 2>); |
2625 |
}; |
2626 |
|
2627 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2628 |
_LIBCPP_CONSTEXPR const size_t subtract_with_carry_engine<_UIntType, __w, __s, __r>::word_size; |
2629 |
|
2630 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2631 |
_LIBCPP_CONSTEXPR const size_t subtract_with_carry_engine<_UIntType, __w, __s, __r>::short_lag; |
2632 |
|
2633 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2634 |
_LIBCPP_CONSTEXPR const size_t subtract_with_carry_engine<_UIntType, __w, __s, __r>::long_lag; |
2635 |
|
2636 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2637 |
_LIBCPP_CONSTEXPR const typename subtract_with_carry_engine<_UIntType, __w, __s, __r>::result_type |
2638 |
subtract_with_carry_engine<_UIntType, __w, __s, __r>::default_seed; |
2639 |
|
2640 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2641 |
void |
2642 |
subtract_with_carry_engine<_UIntType, __w, __s, __r>::seed(result_type __sd, |
2643 |
integral_constant<unsigned, 1>) |
2644 |
{ |
2645 |
linear_congruential_engine<result_type, 40014u, 0u, 2147483563u> |
2646 |
__e(__sd == 0u ? default_seed : __sd); |
2647 |
for (size_t __i = 0; __i < __r; ++__i) |
2648 |
__x_[__i] = static_cast<result_type>(__e() & _Max); |
2649 |
__c_ = __x_[__r-1] == 0; |
2650 |
__i_ = 0; |
2651 |
} |
2652 |
|
2653 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2654 |
void |
2655 |
subtract_with_carry_engine<_UIntType, __w, __s, __r>::seed(result_type __sd, |
2656 |
integral_constant<unsigned, 2>) |
2657 |
{ |
2658 |
linear_congruential_engine<result_type, 40014u, 0u, 2147483563u> |
2659 |
__e(__sd == 0u ? default_seed : __sd); |
2660 |
for (size_t __i = 0; __i < __r; ++__i) |
2661 |
{ |
2662 |
result_type __e0 = __e(); |
2663 |
__x_[__i] = static_cast<result_type>( |
2664 |
(__e0 + ((uint64_t)__e() << 32)) & _Max); |
2665 |
} |
2666 |
__c_ = __x_[__r-1] == 0; |
2667 |
__i_ = 0; |
2668 |
} |
2669 |
|
2670 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2671 |
template<class _Sseq> |
2672 |
void |
2673 |
subtract_with_carry_engine<_UIntType, __w, __s, __r>::__seed(_Sseq& __q, |
2674 |
integral_constant<unsigned, 1>) |
2675 |
{ |
2676 |
const unsigned __k = 1; |
2677 |
uint32_t __ar[__r * __k]; |
2678 |
__q.generate(__ar, __ar + __r * __k); |
2679 |
for (size_t __i = 0; __i < __r; ++__i) |
2680 |
__x_[__i] = static_cast<result_type>(__ar[__i] & _Max); |
2681 |
__c_ = __x_[__r-1] == 0; |
2682 |
__i_ = 0; |
2683 |
} |
2684 |
|
2685 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2686 |
template<class _Sseq> |
2687 |
void |
2688 |
subtract_with_carry_engine<_UIntType, __w, __s, __r>::__seed(_Sseq& __q, |
2689 |
integral_constant<unsigned, 2>) |
2690 |
{ |
2691 |
const unsigned __k = 2; |
2692 |
uint32_t __ar[__r * __k]; |
2693 |
__q.generate(__ar, __ar + __r * __k); |
2694 |
for (size_t __i = 0; __i < __r; ++__i) |
2695 |
__x_[__i] = static_cast<result_type>( |
2696 |
(__ar[2 * __i] + ((uint64_t)__ar[2 * __i + 1] << 32)) & _Max); |
2697 |
__c_ = __x_[__r-1] == 0; |
2698 |
__i_ = 0; |
2699 |
} |
2700 |
|
2701 |
template<class _UIntType, size_t __w, size_t __s, size_t __r> |
2702 |
_UIntType |
2703 |
subtract_with_carry_engine<_UIntType, __w, __s, __r>::operator()() |
2704 |
{ |
2705 |
const result_type& __xs = __x_[(__i_ + (__r - __s)) % __r]; |
2706 |
result_type& __xr = __x_[__i_]; |
2707 |
result_type __new_c = __c_ == 0 ? __xs < __xr : __xs != 0 ? __xs <= __xr : 1; |
2708 |
__xr = (__xs - __xr - __c_) & _Max; |
2709 |
__c_ = __new_c; |
2710 |
__i_ = (__i_ + 1) % __r; |
2711 |
return __xr; |
2712 |
} |
2713 |
|
2714 |
template<class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2715 |
bool |
2716 |
operator==( |
2717 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x, |
2718 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __y) |
2719 |
{ |
2720 |
if (__x.__c_ != __y.__c_) |
2721 |
return false; |
2722 |
if (__x.__i_ == __y.__i_) |
2723 |
return _VSTD::equal(__x.__x_, __x.__x_ + _Rp, __y.__x_); |
2724 |
if (__x.__i_ == 0 || __y.__i_ == 0) |
2725 |
{ |
2726 |
size_t __j = _VSTD::min(_Rp - __x.__i_, _Rp - __y.__i_); |
2727 |
if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, |
2728 |
__y.__x_ + __y.__i_)) |
2729 |
return false; |
2730 |
if (__x.__i_ == 0) |
2731 |
return _VSTD::equal(__x.__x_ + __j, __x.__x_ + _Rp, __y.__x_); |
2732 |
return _VSTD::equal(__x.__x_, __x.__x_ + (_Rp - __j), __y.__x_ + __j); |
2733 |
} |
2734 |
if (__x.__i_ < __y.__i_) |
2735 |
{ |
2736 |
size_t __j = _Rp - __y.__i_; |
2737 |
if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), |
2738 |
__y.__x_ + __y.__i_)) |
2739 |
return false; |
2740 |
if (!_VSTD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _Rp, |
2741 |
__y.__x_)) |
2742 |
return false; |
2743 |
return _VSTD::equal(__x.__x_, __x.__x_ + __x.__i_, |
2744 |
__y.__x_ + (_Rp - (__x.__i_ + __j))); |
2745 |
} |
2746 |
size_t __j = _Rp - __x.__i_; |
2747 |
if (!_VSTD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), |
2748 |
__x.__x_ + __x.__i_)) |
2749 |
return false; |
2750 |
if (!_VSTD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _Rp, |
2751 |
__x.__x_)) |
2752 |
return false; |
2753 |
return _VSTD::equal(__y.__x_, __y.__x_ + __y.__i_, |
2754 |
__x.__x_ + (_Rp - (__y.__i_ + __j))); |
2755 |
} |
2756 |
|
2757 |
template<class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2758 |
inline _LIBCPP_INLINE_VISIBILITY |
2759 |
bool |
2760 |
operator!=( |
2761 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x, |
2762 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __y) |
2763 |
{ |
2764 |
return !(__x == __y); |
2765 |
} |
2766 |
|
2767 |
template <class _CharT, class _Traits, |
2768 |
class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2769 |
basic_ostream<_CharT, _Traits>& |
2770 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2771 |
const subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x) |
2772 |
{ |
2773 |
__save_flags<_CharT, _Traits> __lx(__os); |
2774 |
__os.flags(ios_base::dec | ios_base::left); |
2775 |
_CharT __sp = __os.widen(' '); |
2776 |
__os.fill(__sp); |
2777 |
__os << __x.__x_[__x.__i_]; |
2778 |
for (size_t __j = __x.__i_ + 1; __j < _Rp; ++__j) |
2779 |
__os << __sp << __x.__x_[__j]; |
2780 |
for (size_t __j = 0; __j < __x.__i_; ++__j) |
2781 |
__os << __sp << __x.__x_[__j]; |
2782 |
__os << __sp << __x.__c_; |
2783 |
return __os; |
2784 |
} |
2785 |
|
2786 |
template <class _CharT, class _Traits, |
2787 |
class _UI, size_t _Wp, size_t _Sp, size_t _Rp> |
2788 |
basic_istream<_CharT, _Traits>& |
2789 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2790 |
subtract_with_carry_engine<_UI, _Wp, _Sp, _Rp>& __x) |
2791 |
{ |
2792 |
__save_flags<_CharT, _Traits> __lx(__is); |
2793 |
__is.flags(ios_base::dec | ios_base::skipws); |
2794 |
_UI __t[_Rp+1]; |
2795 |
for (size_t __i = 0; __i < _Rp+1; ++__i) |
2796 |
__is >> __t[__i]; |
2797 |
if (!__is.fail()) |
2798 |
{ |
2799 |
for (size_t __i = 0; __i < _Rp; ++__i) |
2800 |
__x.__x_[__i] = __t[__i]; |
2801 |
__x.__c_ = __t[_Rp]; |
2802 |
__x.__i_ = 0; |
2803 |
} |
2804 |
return __is; |
2805 |
} |
2806 |
|
2807 |
typedef subtract_with_carry_engine<uint_fast32_t, 24, 10, 24> ranlux24_base; |
2808 |
typedef subtract_with_carry_engine<uint_fast64_t, 48, 5, 12> ranlux48_base; |
2809 |
|
2810 |
// discard_block_engine |
2811 |
|
2812 |
template<class _Engine, size_t __p, size_t __r> |
2813 |
class _LIBCPP_TYPE_VIS_ONLY discard_block_engine |
2814 |
{ |
2815 |
_Engine __e_; |
2816 |
int __n_; |
2817 |
|
2818 |
static_assert( 0 < __r, "discard_block_engine invalid parameters"); |
2819 |
static_assert(__r <= __p, "discard_block_engine invalid parameters"); |
2820 |
public: |
2821 |
// types |
2822 |
typedef typename _Engine::result_type result_type; |
2823 |
|
2824 |
// engine characteristics |
2825 |
static _LIBCPP_CONSTEXPR const size_t block_size = __p; |
2826 |
static _LIBCPP_CONSTEXPR const size_t used_block = __r; |
2827 |
|
2828 |
#ifdef _LIBCPP_HAS_NO_CONSTEXPR |
2829 |
static const result_type _Min = _Engine::_Min; |
2830 |
static const result_type _Max = _Engine::_Max; |
2831 |
#else |
2832 |
static _LIBCPP_CONSTEXPR const result_type _Min = _Engine::min(); |
2833 |
static _LIBCPP_CONSTEXPR const result_type _Max = _Engine::max(); |
2834 |
#endif |
2835 |
|
2836 |
_LIBCPP_INLINE_VISIBILITY |
2837 |
static _LIBCPP_CONSTEXPR result_type min() { return _Engine::min(); } |
2838 |
_LIBCPP_INLINE_VISIBILITY |
2839 |
static _LIBCPP_CONSTEXPR result_type max() { return _Engine::max(); } |
2840 |
|
2841 |
// constructors and seeding functions |
2842 |
_LIBCPP_INLINE_VISIBILITY |
2843 |
discard_block_engine() : __n_(0) {} |
2844 |
_LIBCPP_INLINE_VISIBILITY |
2845 |
explicit discard_block_engine(const _Engine& __e) |
2846 |
: __e_(__e), __n_(0) {} |
2847 |
#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES |
2848 |
_LIBCPP_INLINE_VISIBILITY |
2849 |
explicit discard_block_engine(_Engine&& __e) |
2850 |
: __e_(_VSTD::move(__e)), __n_(0) {} |
2851 |
#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES |
2852 |
_LIBCPP_INLINE_VISIBILITY |
2853 |
explicit discard_block_engine(result_type __sd) : __e_(__sd), __n_(0) {} |
2854 |
template<class _Sseq> |
2855 |
_LIBCPP_INLINE_VISIBILITY |
2856 |
explicit discard_block_engine(_Sseq& __q, |
2857 |
typename enable_if<__is_seed_sequence<_Sseq, discard_block_engine>::value && |
2858 |
!is_convertible<_Sseq, _Engine>::value>::type* = 0) |
2859 |
: __e_(__q), __n_(0) {} |
2860 |
_LIBCPP_INLINE_VISIBILITY |
2861 |
void seed() {__e_.seed(); __n_ = 0;} |
2862 |
_LIBCPP_INLINE_VISIBILITY |
2863 |
void seed(result_type __sd) {__e_.seed(__sd); __n_ = 0;} |
2864 |
template<class _Sseq> |
2865 |
_LIBCPP_INLINE_VISIBILITY |
2866 |
typename enable_if |
2867 |
< |
2868 |
__is_seed_sequence<_Sseq, discard_block_engine>::value, |
2869 |
void |
2870 |
>::type |
2871 |
seed(_Sseq& __q) {__e_.seed(__q); __n_ = 0;} |
2872 |
|
2873 |
// generating functions |
2874 |
result_type operator()(); |
2875 |
_LIBCPP_INLINE_VISIBILITY |
2876 |
void discard(unsigned long long __z) {for (; __z; --__z) operator()();} |
2877 |
|
2878 |
// property functions |
2879 |
_LIBCPP_INLINE_VISIBILITY |
2880 |
const _Engine& base() const _NOEXCEPT {return __e_;} |
2881 |
|
2882 |
template<class _Eng, size_t _Pp, size_t _Rp> |
2883 |
friend |
2884 |
bool |
2885 |
operator==( |
2886 |
const discard_block_engine<_Eng, _Pp, _Rp>& __x, |
2887 |
const discard_block_engine<_Eng, _Pp, _Rp>& __y); |
2888 |
|
2889 |
template<class _Eng, size_t _Pp, size_t _Rp> |
2890 |
friend |
2891 |
bool |
2892 |
operator!=( |
2893 |
const discard_block_engine<_Eng, _Pp, _Rp>& __x, |
2894 |
const discard_block_engine<_Eng, _Pp, _Rp>& __y); |
2895 |
|
2896 |
template <class _CharT, class _Traits, |
2897 |
class _Eng, size_t _Pp, size_t _Rp> |
2898 |
friend |
2899 |
basic_ostream<_CharT, _Traits>& |
2900 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2901 |
const discard_block_engine<_Eng, _Pp, _Rp>& __x); |
2902 |
|
2903 |
template <class _CharT, class _Traits, |
2904 |
class _Eng, size_t _Pp, size_t _Rp> |
2905 |
friend |
2906 |
basic_istream<_CharT, _Traits>& |
2907 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2908 |
discard_block_engine<_Eng, _Pp, _Rp>& __x); |
2909 |
}; |
2910 |
|
2911 |
template<class _Engine, size_t __p, size_t __r> |
2912 |
_LIBCPP_CONSTEXPR const size_t discard_block_engine<_Engine, __p, __r>::block_size; |
2913 |
|
2914 |
template<class _Engine, size_t __p, size_t __r> |
2915 |
_LIBCPP_CONSTEXPR const size_t discard_block_engine<_Engine, __p, __r>::used_block; |
2916 |
|
2917 |
template<class _Engine, size_t __p, size_t __r> |
2918 |
typename discard_block_engine<_Engine, __p, __r>::result_type |
2919 |
discard_block_engine<_Engine, __p, __r>::operator()() |
2920 |
{ |
2921 |
if (__n_ >= __r) |
2922 |
{ |
2923 |
__e_.discard(__p - __r); |
2924 |
__n_ = 0; |
2925 |
} |
2926 |
++__n_; |
2927 |
return __e_(); |
2928 |
} |
2929 |
|
2930 |
template<class _Eng, size_t _Pp, size_t _Rp> |
2931 |
inline _LIBCPP_INLINE_VISIBILITY |
2932 |
bool |
2933 |
operator==(const discard_block_engine<_Eng, _Pp, _Rp>& __x, |
2934 |
const discard_block_engine<_Eng, _Pp, _Rp>& __y) |
2935 |
{ |
2936 |
return __x.__n_ == __y.__n_ && __x.__e_ == __y.__e_; |
2937 |
} |
2938 |
|
2939 |
template<class _Eng, size_t _Pp, size_t _Rp> |
2940 |
inline _LIBCPP_INLINE_VISIBILITY |
2941 |
bool |
2942 |
operator!=(const discard_block_engine<_Eng, _Pp, _Rp>& __x, |
2943 |
const discard_block_engine<_Eng, _Pp, _Rp>& __y) |
2944 |
{ |
2945 |
return !(__x == __y); |
2946 |
} |
2947 |
|
2948 |
template <class _CharT, class _Traits, |
2949 |
class _Eng, size_t _Pp, size_t _Rp> |
2950 |
basic_ostream<_CharT, _Traits>& |
2951 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
2952 |
const discard_block_engine<_Eng, _Pp, _Rp>& __x) |
2953 |
{ |
2954 |
__save_flags<_CharT, _Traits> __lx(__os); |
2955 |
__os.flags(ios_base::dec | ios_base::left); |
2956 |
_CharT __sp = __os.widen(' '); |
2957 |
__os.fill(__sp); |
2958 |
return __os << __x.__e_ << __sp << __x.__n_; |
2959 |
} |
2960 |
|
2961 |
template <class _CharT, class _Traits, |
2962 |
class _Eng, size_t _Pp, size_t _Rp> |
2963 |
basic_istream<_CharT, _Traits>& |
2964 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
2965 |
discard_block_engine<_Eng, _Pp, _Rp>& __x) |
2966 |
{ |
2967 |
__save_flags<_CharT, _Traits> __lx(__is); |
2968 |
__is.flags(ios_base::dec | ios_base::skipws); |
2969 |
_Eng __e; |
2970 |
int __n; |
2971 |
__is >> __e >> __n; |
2972 |
if (!__is.fail()) |
2973 |
{ |
2974 |
__x.__e_ = __e; |
2975 |
__x.__n_ = __n; |
2976 |
} |
2977 |
return __is; |
2978 |
} |
2979 |
|
2980 |
typedef discard_block_engine<ranlux24_base, 223, 23> ranlux24; |
2981 |
typedef discard_block_engine<ranlux48_base, 389, 11> ranlux48; |
2982 |
|
2983 |
// independent_bits_engine |
2984 |
|
2985 |
template<class _Engine, size_t __w, class _UIntType> |
2986 |
class _LIBCPP_TYPE_VIS_ONLY independent_bits_engine |
2987 |
{ |
2988 |
template <class _UI, _UI _R0, size_t _Wp, size_t _Mp> |
2989 |
class __get_n |
2990 |
{ |
2991 |
static _LIBCPP_CONSTEXPR const size_t _Dt = numeric_limits<_UI>::digits; |
2992 |
static _LIBCPP_CONSTEXPR const size_t _Np = _Wp / _Mp + (_Wp % _Mp != 0); |
2993 |
static _LIBCPP_CONSTEXPR const size_t _W0 = _Wp / _Np; |
2994 |
static _LIBCPP_CONSTEXPR const _UI _Y0 = _W0 >= _Dt ? 0 : (_R0 >> _W0) << _W0; |
2995 |
public: |
2996 |
static _LIBCPP_CONSTEXPR const size_t value = _R0 - _Y0 > _Y0 / _Np ? _Np + 1 : _Np; |
2997 |
}; |
2998 |
public: |
2999 |
// types |
3000 |
typedef _UIntType result_type; |
3001 |
|
3002 |
private: |
3003 |
_Engine __e_; |
3004 |
|
3005 |
static _LIBCPP_CONSTEXPR const result_type _Dt = numeric_limits<result_type>::digits; |
3006 |
static_assert( 0 < __w, "independent_bits_engine invalid parameters"); |
3007 |
static_assert(__w <= _Dt, "independent_bits_engine invalid parameters"); |
3008 |
|
3009 |
typedef typename _Engine::result_type _Engine_result_type; |
3010 |
typedef typename conditional |
3011 |
< |
3012 |
sizeof(_Engine_result_type) <= sizeof(result_type), |
3013 |
result_type, |
3014 |
_Engine_result_type |
3015 |
>::type _Working_result_type; |
3016 |
#ifdef _LIBCPP_HAS_NO_CONSTEXPR |
3017 |
static const _Working_result_type _Rp = _Engine::_Max - _Engine::_Min |
3018 |
+ _Working_result_type(1); |
3019 |
#else |
3020 |
static _LIBCPP_CONSTEXPR const _Working_result_type _Rp = _Engine::max() - _Engine::min() |
3021 |
+ _Working_result_type(1); |
3022 |
#endif |
3023 |
static _LIBCPP_CONSTEXPR const size_t __m = __log2<_Working_result_type, _Rp>::value; |
3024 |
static _LIBCPP_CONSTEXPR const size_t __n = __get_n<_Working_result_type, _Rp, __w, __m>::value; |
3025 |
static _LIBCPP_CONSTEXPR const size_t __w0 = __w / __n; |
3026 |
static _LIBCPP_CONSTEXPR const size_t __n0 = __n - __w % __n; |
3027 |
static _LIBCPP_CONSTEXPR const size_t _WDt = numeric_limits<_Working_result_type>::digits; |
3028 |
static _LIBCPP_CONSTEXPR const size_t _EDt = numeric_limits<_Engine_result_type>::digits; |
3029 |
static _LIBCPP_CONSTEXPR const _Working_result_type __y0 = __w0 >= _WDt ? 0 : |
3030 |
(_Rp >> __w0) << __w0; |
3031 |
static _LIBCPP_CONSTEXPR const _Working_result_type __y1 = __w0 >= _WDt - 1 ? 0 : |
3032 |
(_Rp >> (__w0+1)) << (__w0+1); |
3033 |
static _LIBCPP_CONSTEXPR const _Engine_result_type __mask0 = __w0 > 0 ? |
3034 |
_Engine_result_type(~0) >> (_EDt - __w0) : |
3035 |
_Engine_result_type(0); |
3036 |
static _LIBCPP_CONSTEXPR const _Engine_result_type __mask1 = __w0 < _EDt - 1 ? |
3037 |
_Engine_result_type(~0) >> (_EDt - (__w0 + 1)) : |
3038 |
_Engine_result_type(~0); |
3039 |
public: |
3040 |
static _LIBCPP_CONSTEXPR const result_type _Min = 0; |
3041 |
static _LIBCPP_CONSTEXPR const result_type _Max = __w == _Dt ? result_type(~0) : |
3042 |
(result_type(1) << __w) - result_type(1); |
3043 |
static_assert(_Min < _Max, "independent_bits_engine invalid parameters"); |
3044 |
|
3045 |
// engine characteristics |
3046 |
_LIBCPP_INLINE_VISIBILITY |
3047 |
static _LIBCPP_CONSTEXPR result_type min() { return _Min; } |
3048 |
_LIBCPP_INLINE_VISIBILITY |
3049 |
static _LIBCPP_CONSTEXPR result_type max() { return _Max; } |
3050 |
|
3051 |
// constructors and seeding functions |
3052 |
_LIBCPP_INLINE_VISIBILITY |
3053 |
independent_bits_engine() {} |
3054 |
_LIBCPP_INLINE_VISIBILITY |
3055 |
explicit independent_bits_engine(const _Engine& __e) |
3056 |
: __e_(__e) {} |
3057 |
#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES |
3058 |
_LIBCPP_INLINE_VISIBILITY |
3059 |
explicit independent_bits_engine(_Engine&& __e) |
3060 |
: __e_(_VSTD::move(__e)) {} |
3061 |
#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES |
3062 |
_LIBCPP_INLINE_VISIBILITY |
3063 |
explicit independent_bits_engine(result_type __sd) : __e_(__sd) {} |
3064 |
template<class _Sseq> |
3065 |
_LIBCPP_INLINE_VISIBILITY |
3066 |
explicit independent_bits_engine(_Sseq& __q, |
3067 |
typename enable_if<__is_seed_sequence<_Sseq, independent_bits_engine>::value && |
3068 |
!is_convertible<_Sseq, _Engine>::value>::type* = 0) |
3069 |
: __e_(__q) {} |
3070 |
_LIBCPP_INLINE_VISIBILITY |
3071 |
void seed() {__e_.seed();} |
3072 |
_LIBCPP_INLINE_VISIBILITY |
3073 |
void seed(result_type __sd) {__e_.seed(__sd);} |
3074 |
template<class _Sseq> |
3075 |
_LIBCPP_INLINE_VISIBILITY |
3076 |
typename enable_if |
3077 |
< |
3078 |
__is_seed_sequence<_Sseq, independent_bits_engine>::value, |
3079 |
void |
3080 |
>::type |
3081 |
seed(_Sseq& __q) {__e_.seed(__q);} |
3082 |
|
3083 |
// generating functions |
3084 |
_LIBCPP_INLINE_VISIBILITY |
3085 |
result_type operator()() {return __eval(integral_constant<bool, _Rp != 0>());} |
3086 |
_LIBCPP_INLINE_VISIBILITY |
3087 |
void discard(unsigned long long __z) {for (; __z; --__z) operator()();} |
3088 |
|
3089 |
// property functions |
3090 |
_LIBCPP_INLINE_VISIBILITY |
3091 |
const _Engine& base() const _NOEXCEPT {return __e_;} |
3092 |
|
3093 |
template<class _Eng, size_t _Wp, class _UI> |
3094 |
friend |
3095 |
bool |
3096 |
operator==( |
3097 |
const independent_bits_engine<_Eng, _Wp, _UI>& __x, |
3098 |
const independent_bits_engine<_Eng, _Wp, _UI>& __y); |
3099 |
|
3100 |
template<class _Eng, size_t _Wp, class _UI> |
3101 |
friend |
3102 |
bool |
3103 |
operator!=( |
3104 |
const independent_bits_engine<_Eng, _Wp, _UI>& __x, |
3105 |
const independent_bits_engine<_Eng, _Wp, _UI>& __y); |
3106 |
|
3107 |
template <class _CharT, class _Traits, |
3108 |
class _Eng, size_t _Wp, class _UI> |
3109 |
friend |
3110 |
basic_ostream<_CharT, _Traits>& |
3111 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
3112 |
const independent_bits_engine<_Eng, _Wp, _UI>& __x); |
3113 |
|
3114 |
template <class _CharT, class _Traits, |
3115 |
class _Eng, size_t _Wp, class _UI> |
3116 |
friend |
3117 |
basic_istream<_CharT, _Traits>& |
3118 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
3119 |
independent_bits_engine<_Eng, _Wp, _UI>& __x); |
3120 |
|
3121 |
private: |
3122 |
result_type __eval(false_type); |
3123 |
result_type __eval(true_type); |
3124 |
|
3125 |
template <size_t __count> |
3126 |
_LIBCPP_INLINE_VISIBILITY |
3127 |
static |
3128 |
typename enable_if |
3129 |
< |
3130 |
__count < _Dt, |
3131 |
result_type |
3132 |
>::type |
3133 |
__lshift(result_type __x) {return __x << __count;} |
3134 |
|
3135 |
template <size_t __count> |
3136 |
_LIBCPP_INLINE_VISIBILITY |
3137 |
static |
3138 |
typename enable_if |
3139 |
< |
3140 |
(__count >= _Dt), |
3141 |
result_type |
3142 |
>::type |
3143 |
__lshift(result_type) {return result_type(0);} |
3144 |
}; |
3145 |
|
3146 |
template<class _Engine, size_t __w, class _UIntType> |
3147 |
inline _LIBCPP_INLINE_VISIBILITY |
3148 |
_UIntType |
3149 |
independent_bits_engine<_Engine, __w, _UIntType>::__eval(false_type) |
3150 |
{ |
3151 |
return static_cast<result_type>(__e_() & __mask0); |
3152 |
} |
3153 |
|
3154 |
template<class _Engine, size_t __w, class _UIntType> |
3155 |
_UIntType |
3156 |
independent_bits_engine<_Engine, __w, _UIntType>::__eval(true_type) |
3157 |
{ |
3158 |
result_type _Sp = 0; |
3159 |
for (size_t __k = 0; __k < __n0; ++__k) |
3160 |
{ |
3161 |
_Engine_result_type __u; |
3162 |
do |
3163 |
{ |
3164 |
__u = __e_() - _Engine::min(); |
3165 |
} while (__u >= __y0); |
3166 |
_Sp = static_cast<result_type>(__lshift<__w0>(_Sp) + (__u & __mask0)); |
3167 |
} |
3168 |
for (size_t __k = __n0; __k < __n; ++__k) |
3169 |
{ |
3170 |
_Engine_result_type __u; |
3171 |
do |
3172 |
{ |
3173 |
__u = __e_() - _Engine::min(); |
3174 |
} while (__u >= __y1); |
3175 |
_Sp = static_cast<result_type>(__lshift<__w0+1>(_Sp) + (__u & __mask1)); |
3176 |
} |
3177 |
return _Sp; |
3178 |
} |
3179 |
|
3180 |
template<class _Eng, size_t _Wp, class _UI> |
3181 |
inline _LIBCPP_INLINE_VISIBILITY |
3182 |
bool |
3183 |
operator==( |
3184 |
const independent_bits_engine<_Eng, _Wp, _UI>& __x, |
3185 |
const independent_bits_engine<_Eng, _Wp, _UI>& __y) |
3186 |
{ |
3187 |
return __x.base() == __y.base(); |
3188 |
} |
3189 |
|
3190 |
template<class _Eng, size_t _Wp, class _UI> |
3191 |
inline _LIBCPP_INLINE_VISIBILITY |
3192 |
bool |
3193 |
operator!=( |
3194 |
const independent_bits_engine<_Eng, _Wp, _UI>& __x, |
3195 |
const independent_bits_engine<_Eng, _Wp, _UI>& __y) |
3196 |
{ |
3197 |
return !(__x == __y); |
3198 |
} |
3199 |
|
3200 |
template <class _CharT, class _Traits, |
3201 |
class _Eng, size_t _Wp, class _UI> |
3202 |
basic_ostream<_CharT, _Traits>& |
3203 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
3204 |
const independent_bits_engine<_Eng, _Wp, _UI>& __x) |
3205 |
{ |
3206 |
return __os << __x.base(); |
3207 |
} |
3208 |
|
3209 |
template <class _CharT, class _Traits, |
3210 |
class _Eng, size_t _Wp, class _UI> |
3211 |
basic_istream<_CharT, _Traits>& |
3212 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
3213 |
independent_bits_engine<_Eng, _Wp, _UI>& __x) |
3214 |
{ |
3215 |
_Eng __e; |
3216 |
__is >> __e; |
3217 |
if (!__is.fail()) |
3218 |
__x.__e_ = __e; |
3219 |
return __is; |
3220 |
} |
3221 |
|
3222 |
// shuffle_order_engine |
3223 |
|
3224 |
template <uint64_t _Xp, uint64_t _Yp> |
3225 |
struct __ugcd |
3226 |
{ |
3227 |
static _LIBCPP_CONSTEXPR const uint64_t value = __ugcd<_Yp, _Xp % _Yp>::value; |
3228 |
}; |
3229 |
|
3230 |
template <uint64_t _Xp> |
3231 |
struct __ugcd<_Xp, 0> |
3232 |
{ |
3233 |
static _LIBCPP_CONSTEXPR const uint64_t value = _Xp; |
3234 |
}; |
3235 |
|
3236 |
template <uint64_t _Np, uint64_t _Dp> |
3237 |
class __uratio |
3238 |
{ |
3239 |
static_assert(_Dp != 0, "__uratio divide by 0"); |
3240 |
static _LIBCPP_CONSTEXPR const uint64_t __gcd = __ugcd<_Np, _Dp>::value; |
3241 |
public: |
3242 |
static _LIBCPP_CONSTEXPR const uint64_t num = _Np / __gcd; |
3243 |
static _LIBCPP_CONSTEXPR const uint64_t den = _Dp / __gcd; |
3244 |
|
3245 |
typedef __uratio<num, den> type; |
3246 |
}; |
3247 |
|
3248 |
template<class _Engine, size_t __k> |
3249 |
class _LIBCPP_TYPE_VIS_ONLY shuffle_order_engine |
3250 |
{ |
3251 |
static_assert(0 < __k, "shuffle_order_engine invalid parameters"); |
3252 |
public: |
3253 |
// types |
3254 |
typedef typename _Engine::result_type result_type; |
3255 |
|
3256 |
private: |
3257 |
_Engine __e_; |
3258 |
result_type _V_[__k]; |
3259 |
result_type _Y_; |
3260 |
|
3261 |
public: |
3262 |
// engine characteristics |
3263 |
static _LIBCPP_CONSTEXPR const size_t table_size = __k; |
3264 |
|
3265 |
#ifdef _LIBCPP_HAS_NO_CONSTEXPR |
3266 |
static const result_type _Min = _Engine::_Min; |
3267 |
static const result_type _Max = _Engine::_Max; |
3268 |
#else |
3269 |
static _LIBCPP_CONSTEXPR const result_type _Min = _Engine::min(); |
3270 |
static _LIBCPP_CONSTEXPR const result_type _Max = _Engine::max(); |
3271 |
#endif |
3272 |
static_assert(_Min < _Max, "shuffle_order_engine invalid parameters"); |
3273 |
_LIBCPP_INLINE_VISIBILITY |
3274 |
static _LIBCPP_CONSTEXPR result_type min() { return _Min; } |
3275 |
_LIBCPP_INLINE_VISIBILITY |
3276 |
static _LIBCPP_CONSTEXPR result_type max() { return _Max; } |
3277 |
|
3278 |
static _LIBCPP_CONSTEXPR const unsigned long long _Rp = _Max - _Min + 1ull; |
3279 |
|
3280 |
// constructors and seeding functions |
3281 |
_LIBCPP_INLINE_VISIBILITY |
3282 |
shuffle_order_engine() {__init();} |
3283 |
_LIBCPP_INLINE_VISIBILITY |
3284 |
explicit shuffle_order_engine(const _Engine& __e) |
3285 |
: __e_(__e) {__init();} |
3286 |
#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES |
3287 |
_LIBCPP_INLINE_VISIBILITY |
3288 |
explicit shuffle_order_engine(_Engine&& __e) |
3289 |
: __e_(_VSTD::move(__e)) {__init();} |
3290 |
#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES |
3291 |
_LIBCPP_INLINE_VISIBILITY |
3292 |
explicit shuffle_order_engine(result_type __sd) : __e_(__sd) {__init();} |
3293 |
template<class _Sseq> |
3294 |
_LIBCPP_INLINE_VISIBILITY |
3295 |
explicit shuffle_order_engine(_Sseq& __q, |
3296 |
typename enable_if<__is_seed_sequence<_Sseq, shuffle_order_engine>::value && |
3297 |
!is_convertible<_Sseq, _Engine>::value>::type* = 0) |
3298 |
: __e_(__q) {__init();} |
3299 |
_LIBCPP_INLINE_VISIBILITY |
3300 |
void seed() {__e_.seed(); __init();} |
3301 |
_LIBCPP_INLINE_VISIBILITY |
3302 |
void seed(result_type __sd) {__e_.seed(__sd); __init();} |
3303 |
template<class _Sseq> |
3304 |
_LIBCPP_INLINE_VISIBILITY |
3305 |
typename enable_if |
3306 |
< |
3307 |
__is_seed_sequence<_Sseq, shuffle_order_engine>::value, |
3308 |
void |
3309 |
>::type |
3310 |
seed(_Sseq& __q) {__e_.seed(__q); __init();} |
3311 |
|
3312 |
// generating functions |
3313 |
_LIBCPP_INLINE_VISIBILITY |
3314 |
result_type operator()() {return __eval(integral_constant<bool, _Rp != 0>());} |
3315 |
_LIBCPP_INLINE_VISIBILITY |
3316 |
void discard(unsigned long long __z) {for (; __z; --__z) operator()();} |
3317 |
|
3318 |
// property functions |
3319 |
_LIBCPP_INLINE_VISIBILITY |
3320 |
const _Engine& base() const _NOEXCEPT {return __e_;} |
3321 |
|
3322 |
private: |
3323 |
template<class _Eng, size_t _Kp> |
3324 |
friend |
3325 |
bool |
3326 |
operator==( |
3327 |
const shuffle_order_engine<_Eng, _Kp>& __x, |
3328 |
const shuffle_order_engine<_Eng, _Kp>& __y); |
3329 |
|
3330 |
template<class _Eng, size_t _Kp> |
3331 |
friend |
3332 |
bool |
3333 |
operator!=( |
3334 |
const shuffle_order_engine<_Eng, _Kp>& __x, |
3335 |
const shuffle_order_engine<_Eng, _Kp>& __y); |
3336 |
|
3337 |
template <class _CharT, class _Traits, |
3338 |
class _Eng, size_t _Kp> |
3339 |
friend |
3340 |
basic_ostream<_CharT, _Traits>& |
3341 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
3342 |
const shuffle_order_engine<_Eng, _Kp>& __x); |
3343 |
|
3344 |
template <class _CharT, class _Traits, |
3345 |
class _Eng, size_t _Kp> |
3346 |
friend |
3347 |
basic_istream<_CharT, _Traits>& |
3348 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
3349 |
shuffle_order_engine<_Eng, _Kp>& __x); |
3350 |
|
3351 |
_LIBCPP_INLINE_VISIBILITY |
3352 |
void __init() |
3353 |
{ |
3354 |
for (size_t __i = 0; __i < __k; ++__i) |
3355 |
_V_[__i] = __e_(); |
3356 |
_Y_ = __e_(); |
3357 |
} |
3358 |
|
3359 |
_LIBCPP_INLINE_VISIBILITY |
3360 |
result_type __eval(false_type) {return __eval2(integral_constant<bool, __k & 1>());} |
3361 |
_LIBCPP_INLINE_VISIBILITY |
3362 |
result_type __eval(true_type) {return __eval(__uratio<__k, _Rp>());} |
3363 |
|
3364 |
_LIBCPP_INLINE_VISIBILITY |
3365 |
result_type __eval2(false_type) {return __eval(__uratio<__k/2, 0x8000000000000000ull>());} |
3366 |
_LIBCPP_INLINE_VISIBILITY |
3367 |
result_type __eval2(true_type) {return __evalf<__k, 0>();} |
3368 |
|
3369 |
template <uint64_t _Np, uint64_t _Dp> |
3370 |
_LIBCPP_INLINE_VISIBILITY |
3371 |
typename enable_if |
3372 |
< |
3373 |
(__uratio<_Np, _Dp>::num > 0xFFFFFFFFFFFFFFFFull / (_Max - _Min)), |
3374 |
result_type |
3375 |
>::type |
3376 |
__eval(__uratio<_Np, _Dp>) |
3377 |
{return __evalf<__uratio<_Np, _Dp>::num, __uratio<_Np, _Dp>::den>();} |
3378 |
|
3379 |
template <uint64_t _Np, uint64_t _Dp> |
3380 |
_LIBCPP_INLINE_VISIBILITY |
3381 |
typename enable_if |
3382 |
< |
3383 |
__uratio<_Np, _Dp>::num <= 0xFFFFFFFFFFFFFFFFull / (_Max - _Min), |
3384 |
result_type |
3385 |
>::type |
3386 |
__eval(__uratio<_Np, _Dp>) |
3387 |
{ |
3388 |
const size_t __j = static_cast<size_t>(__uratio<_Np, _Dp>::num * (_Y_ - _Min) |
3389 |
/ __uratio<_Np, _Dp>::den); |
3390 |
_Y_ = _V_[__j]; |
3391 |
_V_[__j] = __e_(); |
3392 |
return _Y_; |
3393 |
} |
3394 |
|
3395 |
template <uint64_t __n, uint64_t __d> |
3396 |
_LIBCPP_INLINE_VISIBILITY |
3397 |
result_type __evalf() |
3398 |
{ |
3399 |
const double _Fp = __d == 0 ? |
3400 |
__n / (2. * 0x8000000000000000ull) : |
3401 |
__n / (double)__d; |
3402 |
const size_t __j = static_cast<size_t>(_Fp * (_Y_ - _Min)); |
3403 |
_Y_ = _V_[__j]; |
3404 |
_V_[__j] = __e_(); |
3405 |
return _Y_; |
3406 |
} |
3407 |
}; |
3408 |
|
3409 |
template<class _Engine, size_t __k> |
3410 |
_LIBCPP_CONSTEXPR const size_t shuffle_order_engine<_Engine, __k>::table_size; |
3411 |
|
3412 |
template<class _Eng, size_t _Kp> |
3413 |
bool |
3414 |
operator==( |
3415 |
const shuffle_order_engine<_Eng, _Kp>& __x, |
3416 |
const shuffle_order_engine<_Eng, _Kp>& __y) |
3417 |
{ |
3418 |
return __x._Y_ == __y._Y_ && _VSTD::equal(__x._V_, __x._V_ + _Kp, __y._V_) && |
3419 |
__x.__e_ == __y.__e_; |
3420 |
} |
3421 |
|
3422 |
template<class _Eng, size_t _Kp> |
3423 |
inline _LIBCPP_INLINE_VISIBILITY |
3424 |
bool |
3425 |
operator!=( |
3426 |
const shuffle_order_engine<_Eng, _Kp>& __x, |
3427 |
const shuffle_order_engine<_Eng, _Kp>& __y) |
3428 |
{ |
3429 |
return !(__x == __y); |
3430 |
} |
3431 |
|
3432 |
template <class _CharT, class _Traits, |
3433 |
class _Eng, size_t _Kp> |
3434 |
basic_ostream<_CharT, _Traits>& |
3435 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
3436 |
const shuffle_order_engine<_Eng, _Kp>& __x) |
3437 |
{ |
3438 |
__save_flags<_CharT, _Traits> __lx(__os); |
3439 |
__os.flags(ios_base::dec | ios_base::left); |
3440 |
_CharT __sp = __os.widen(' '); |
3441 |
__os.fill(__sp); |
3442 |
__os << __x.__e_ << __sp << __x._V_[0]; |
3443 |
for (size_t __i = 1; __i < _Kp; ++__i) |
3444 |
__os << __sp << __x._V_[__i]; |
3445 |
return __os << __sp << __x._Y_; |
3446 |
} |
3447 |
|
3448 |
template <class _CharT, class _Traits, |
3449 |
class _Eng, size_t _Kp> |
3450 |
basic_istream<_CharT, _Traits>& |
3451 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
3452 |
shuffle_order_engine<_Eng, _Kp>& __x) |
3453 |
{ |
3454 |
typedef typename shuffle_order_engine<_Eng, _Kp>::result_type result_type; |
3455 |
__save_flags<_CharT, _Traits> __lx(__is); |
3456 |
__is.flags(ios_base::dec | ios_base::skipws); |
3457 |
_Eng __e; |
3458 |
result_type _Vp[_Kp+1]; |
3459 |
__is >> __e; |
3460 |
for (size_t __i = 0; __i < _Kp+1; ++__i) |
3461 |
__is >> _Vp[__i]; |
3462 |
if (!__is.fail()) |
3463 |
{ |
3464 |
__x.__e_ = __e; |
3465 |
for (size_t __i = 0; __i < _Kp; ++__i) |
3466 |
__x._V_[__i] = _Vp[__i]; |
3467 |
__x._Y_ = _Vp[_Kp]; |
3468 |
} |
3469 |
return __is; |
3470 |
} |
3471 |
|
3472 |
typedef shuffle_order_engine<minstd_rand0, 256> knuth_b; |
3473 |
|
3474 |
// random_device |
3475 |
|
3476 |
class _LIBCPP_TYPE_VIS random_device |
3477 |
{ |
3478 |
#ifdef _LIBCPP_USING_DEV_RANDOM |
3479 |
int __f_; |
3480 |
#endif // defined(_LIBCPP_USING_DEV_RANDOM) |
3481 |
public: |
3482 |
// types |
3483 |
typedef unsigned result_type; |
3484 |
|
3485 |
// generator characteristics |
3486 |
static _LIBCPP_CONSTEXPR const result_type _Min = 0; |
3487 |
static _LIBCPP_CONSTEXPR const result_type _Max = 0xFFFFFFFFu; |
3488 |
|
3489 |
_LIBCPP_INLINE_VISIBILITY |
3490 |
static _LIBCPP_CONSTEXPR result_type min() { return _Min;} |
3491 |
_LIBCPP_INLINE_VISIBILITY |
3492 |
static _LIBCPP_CONSTEXPR result_type max() { return _Max;} |
3493 |
|
3494 |
// constructors |
3495 |
explicit random_device(const string& __token = "/dev/urandom"); |
3496 |
~random_device(); |
3497 |
|
3498 |
// generating functions |
3499 |
result_type operator()(); |
3500 |
|
3501 |
// property functions |
3502 |
double entropy() const _NOEXCEPT; |
3503 |
|
3504 |
private: |
3505 |
// no copy functions |
3506 |
random_device(const random_device&); // = delete; |
3507 |
random_device& operator=(const random_device&); // = delete; |
3508 |
}; |
3509 |
|
3510 |
// seed_seq |
3511 |
|
3512 |
class _LIBCPP_TYPE_VIS_ONLY seed_seq |
3513 |
{ |
3514 |
public: |
3515 |
// types |
3516 |
typedef uint32_t result_type; |
3517 |
|
3518 |
private: |
3519 |
vector<result_type> __v_; |
3520 |
|
3521 |
template<class _InputIterator> |
3522 |
void init(_InputIterator __first, _InputIterator __last); |
3523 |
public: |
3524 |
// constructors |
3525 |
_LIBCPP_INLINE_VISIBILITY |
3526 |
seed_seq() _NOEXCEPT {} |
3527 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
3528 |
template<class _Tp> |
3529 |
_LIBCPP_INLINE_VISIBILITY |
3530 |
seed_seq(initializer_list<_Tp> __il) {init(__il.begin(), __il.end());} |
3531 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
3532 |
|
3533 |
template<class _InputIterator> |
3534 |
_LIBCPP_INLINE_VISIBILITY |
3535 |
seed_seq(_InputIterator __first, _InputIterator __last) |
3536 |
{init(__first, __last);} |
3537 |
|
3538 |
// generating functions |
3539 |
template<class _RandomAccessIterator> |
3540 |
void generate(_RandomAccessIterator __first, _RandomAccessIterator __last); |
3541 |
|
3542 |
// property functions |
3543 |
_LIBCPP_INLINE_VISIBILITY |
3544 |
size_t size() const _NOEXCEPT {return __v_.size();} |
3545 |
template<class _OutputIterator> |
3546 |
_LIBCPP_INLINE_VISIBILITY |
3547 |
void param(_OutputIterator __dest) const |
3548 |
{_VSTD::copy(__v_.begin(), __v_.end(), __dest);} |
3549 |
|
3550 |
private: |
3551 |
// no copy functions |
3552 |
seed_seq(const seed_seq&); // = delete; |
3553 |
void operator=(const seed_seq&); // = delete; |
3554 |
|
3555 |
_LIBCPP_INLINE_VISIBILITY |
3556 |
static result_type _Tp(result_type __x) {return __x ^ (__x >> 27);} |
3557 |
}; |
3558 |
|
3559 |
template<class _InputIterator> |
3560 |
void |
3561 |
seed_seq::init(_InputIterator __first, _InputIterator __last) |
3562 |
{ |
3563 |
for (_InputIterator __s = __first; __s != __last; ++__s) |
3564 |
__v_.push_back(*__s & 0xFFFFFFFF); |
3565 |
} |
3566 |
|
3567 |
template<class _RandomAccessIterator> |
3568 |
void |
3569 |
seed_seq::generate(_RandomAccessIterator __first, _RandomAccessIterator __last) |
3570 |
{ |
3571 |
if (__first != __last) |
3572 |
{ |
3573 |
_VSTD::fill(__first, __last, 0x8b8b8b8b); |
3574 |
const size_t __n = static_cast<size_t>(__last - __first); |
3575 |
const size_t __s = __v_.size(); |
3576 |
const size_t __t = (__n >= 623) ? 11 |
3577 |
: (__n >= 68) ? 7 |
3578 |
: (__n >= 39) ? 5 |
3579 |
: (__n >= 7) ? 3 |
3580 |
: (__n - 1) / 2; |
3581 |
const size_t __p = (__n - __t) / 2; |
3582 |
const size_t __q = __p + __t; |
3583 |
const size_t __m = _VSTD::max(__s + 1, __n); |
3584 |
// __k = 0; |
3585 |
{ |
3586 |
result_type __r = 1664525 * _Tp(__first[0] ^ __first[__p] |
3587 |
^ __first[__n - 1]); |
3588 |
__first[__p] += __r; |
3589 |
__r += __s; |
3590 |
__first[__q] += __r; |
3591 |
__first[0] = __r; |
3592 |
} |
3593 |
for (size_t __k = 1; __k <= __s; ++__k) |
3594 |
{ |
3595 |
const size_t __kmodn = __k % __n; |
3596 |
const size_t __kpmodn = (__k + __p) % __n; |
3597 |
result_type __r = 1664525 * _Tp(__first[__kmodn] ^ __first[__kpmodn] |
3598 |
^ __first[(__k - 1) % __n]); |
3599 |
__first[__kpmodn] += __r; |
3600 |
__r += __kmodn + __v_[__k-1]; |
3601 |
__first[(__k + __q) % __n] += __r; |
3602 |
__first[__kmodn] = __r; |
3603 |
} |
3604 |
for (size_t __k = __s + 1; __k < __m; ++__k) |
3605 |
{ |
3606 |
const size_t __kmodn = __k % __n; |
3607 |
const size_t __kpmodn = (__k + __p) % __n; |
3608 |
result_type __r = 1664525 * _Tp(__first[__kmodn] ^ __first[__kpmodn] |
3609 |
^ __first[(__k - 1) % __n]); |
3610 |
__first[__kpmodn] += __r; |
3611 |
__r += __kmodn; |
3612 |
__first[(__k + __q) % __n] += __r; |
3613 |
__first[__kmodn] = __r; |
3614 |
} |
3615 |
for (size_t __k = __m; __k < __m + __n; ++__k) |
3616 |
{ |
3617 |
const size_t __kmodn = __k % __n; |
3618 |
const size_t __kpmodn = (__k + __p) % __n; |
3619 |
result_type __r = 1566083941 * _Tp(__first[__kmodn] + |
3620 |
__first[__kpmodn] + |
3621 |
__first[(__k - 1) % __n]); |
3622 |
__first[__kpmodn] ^= __r; |
3623 |
__r -= __kmodn; |
3624 |
__first[(__k + __q) % __n] ^= __r; |
3625 |
__first[__kmodn] = __r; |
3626 |
} |
3627 |
} |
3628 |
} |
3629 |
|
3630 |
// generate_canonical |
3631 |
|
3632 |
template<class _RealType, size_t __bits, class _URNG> |
3633 |
_RealType |
3634 |
generate_canonical(_URNG& __g) |
3635 |
{ |
3636 |
const size_t _Dt = numeric_limits<_RealType>::digits; |
3637 |
const size_t __b = _Dt < __bits ? _Dt : __bits; |
3638 |
#ifdef _LIBCPP_HAS_NO_CONSTEXPR |
3639 |
const size_t __logR = __log2<uint64_t, _URNG::_Max - _URNG::_Min + uint64_t(1)>::value; |
3640 |
#else |
3641 |
const size_t __logR = __log2<uint64_t, _URNG::max() - _URNG::min() + uint64_t(1)>::value; |
3642 |
#endif |
3643 |
const size_t __k = __b / __logR + (__b % __logR != 0) + (__b == 0); |
3644 |
const _RealType _Rp = _URNG::max() - _URNG::min() + _RealType(1); |
3645 |
_RealType __base = _Rp; |
3646 |
_RealType _Sp = __g() - _URNG::min(); |
3647 |
for (size_t __i = 1; __i < __k; ++__i, __base *= _Rp) |
3648 |
_Sp += (__g() - _URNG::min()) * __base; |
3649 |
return _Sp / __base; |
3650 |
} |
3651 |
|
3652 |
// uniform_int_distribution |
3653 |
|
3654 |
// in <algorithm> |
3655 |
|
3656 |
template <class _CharT, class _Traits, class _IT> |
3657 |
basic_ostream<_CharT, _Traits>& |
3658 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
3659 |
const uniform_int_distribution<_IT>& __x) |
3660 |
{ |
3661 |
__save_flags<_CharT, _Traits> __lx(__os); |
3662 |
__os.flags(ios_base::dec | ios_base::left); |
3663 |
_CharT __sp = __os.widen(' '); |
3664 |
__os.fill(__sp); |
3665 |
return __os << __x.a() << __sp << __x.b(); |
3666 |
} |
3667 |
|
3668 |
template <class _CharT, class _Traits, class _IT> |
3669 |
basic_istream<_CharT, _Traits>& |
3670 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
3671 |
uniform_int_distribution<_IT>& __x) |
3672 |
{ |
3673 |
typedef uniform_int_distribution<_IT> _Eng; |
3674 |
typedef typename _Eng::result_type result_type; |
3675 |
typedef typename _Eng::param_type param_type; |
3676 |
__save_flags<_CharT, _Traits> __lx(__is); |
3677 |
__is.flags(ios_base::dec | ios_base::skipws); |
3678 |
result_type __a; |
3679 |
result_type __b; |
3680 |
__is >> __a >> __b; |
3681 |
if (!__is.fail()) |
3682 |
__x.param(param_type(__a, __b)); |
3683 |
return __is; |
3684 |
} |
3685 |
|
3686 |
// uniform_real_distribution |
3687 |
|
3688 |
template<class _RealType = double> |
3689 |
class _LIBCPP_TYPE_VIS_ONLY uniform_real_distribution |
3690 |
{ |
3691 |
public: |
3692 |
// types |
3693 |
typedef _RealType result_type; |
3694 |
|
3695 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
3696 |
{ |
3697 |
result_type __a_; |
3698 |
result_type __b_; |
3699 |
public: |
3700 |
typedef uniform_real_distribution distribution_type; |
3701 |
|
3702 |
_LIBCPP_INLINE_VISIBILITY |
3703 |
explicit param_type(result_type __a = 0, |
3704 |
result_type __b = 1) |
3705 |
: __a_(__a), __b_(__b) {} |
3706 |
|
3707 |
_LIBCPP_INLINE_VISIBILITY |
3708 |
result_type a() const {return __a_;} |
3709 |
_LIBCPP_INLINE_VISIBILITY |
3710 |
result_type b() const {return __b_;} |
3711 |
|
3712 |
friend _LIBCPP_INLINE_VISIBILITY |
3713 |
bool operator==(const param_type& __x, const param_type& __y) |
3714 |
{return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} |
3715 |
friend _LIBCPP_INLINE_VISIBILITY |
3716 |
bool operator!=(const param_type& __x, const param_type& __y) |
3717 |
{return !(__x == __y);} |
3718 |
}; |
3719 |
|
3720 |
private: |
3721 |
param_type __p_; |
3722 |
|
3723 |
public: |
3724 |
// constructors and reset functions |
3725 |
_LIBCPP_INLINE_VISIBILITY |
3726 |
explicit uniform_real_distribution(result_type __a = 0, result_type __b = 1) |
3727 |
: __p_(param_type(__a, __b)) {} |
3728 |
_LIBCPP_INLINE_VISIBILITY |
3729 |
explicit uniform_real_distribution(const param_type& __p) : __p_(__p) {} |
3730 |
_LIBCPP_INLINE_VISIBILITY |
3731 |
void reset() {} |
3732 |
|
3733 |
// generating functions |
3734 |
template<class _URNG> |
3735 |
_LIBCPP_INLINE_VISIBILITY |
3736 |
result_type operator()(_URNG& __g) |
3737 |
{return (*this)(__g, __p_);} |
3738 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
3739 |
|
3740 |
// property functions |
3741 |
_LIBCPP_INLINE_VISIBILITY |
3742 |
result_type a() const {return __p_.a();} |
3743 |
_LIBCPP_INLINE_VISIBILITY |
3744 |
result_type b() const {return __p_.b();} |
3745 |
|
3746 |
_LIBCPP_INLINE_VISIBILITY |
3747 |
param_type param() const {return __p_;} |
3748 |
_LIBCPP_INLINE_VISIBILITY |
3749 |
void param(const param_type& __p) {__p_ = __p;} |
3750 |
|
3751 |
_LIBCPP_INLINE_VISIBILITY |
3752 |
result_type min() const {return a();} |
3753 |
_LIBCPP_INLINE_VISIBILITY |
3754 |
result_type max() const {return b();} |
3755 |
|
3756 |
friend _LIBCPP_INLINE_VISIBILITY |
3757 |
bool operator==(const uniform_real_distribution& __x, |
3758 |
const uniform_real_distribution& __y) |
3759 |
{return __x.__p_ == __y.__p_;} |
3760 |
friend _LIBCPP_INLINE_VISIBILITY |
3761 |
bool operator!=(const uniform_real_distribution& __x, |
3762 |
const uniform_real_distribution& __y) |
3763 |
{return !(__x == __y);} |
3764 |
}; |
3765 |
|
3766 |
template<class _RealType> |
3767 |
template<class _URNG> |
3768 |
inline _LIBCPP_INLINE_VISIBILITY |
3769 |
typename uniform_real_distribution<_RealType>::result_type |
3770 |
uniform_real_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
3771 |
{ |
3772 |
return (__p.b() - __p.a()) |
3773 |
* _VSTD::generate_canonical<_RealType, numeric_limits<_RealType>::digits>(__g) |
3774 |
+ __p.a(); |
3775 |
} |
3776 |
|
3777 |
template <class _CharT, class _Traits, class _RT> |
3778 |
basic_ostream<_CharT, _Traits>& |
3779 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
3780 |
const uniform_real_distribution<_RT>& __x) |
3781 |
{ |
3782 |
__save_flags<_CharT, _Traits> __lx(__os); |
3783 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
3784 |
ios_base::scientific); |
3785 |
_CharT __sp = __os.widen(' '); |
3786 |
__os.fill(__sp); |
3787 |
return __os << __x.a() << __sp << __x.b(); |
3788 |
} |
3789 |
|
3790 |
template <class _CharT, class _Traits, class _RT> |
3791 |
basic_istream<_CharT, _Traits>& |
3792 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
3793 |
uniform_real_distribution<_RT>& __x) |
3794 |
{ |
3795 |
typedef uniform_real_distribution<_RT> _Eng; |
3796 |
typedef typename _Eng::result_type result_type; |
3797 |
typedef typename _Eng::param_type param_type; |
3798 |
__save_flags<_CharT, _Traits> __lx(__is); |
3799 |
__is.flags(ios_base::dec | ios_base::skipws); |
3800 |
result_type __a; |
3801 |
result_type __b; |
3802 |
__is >> __a >> __b; |
3803 |
if (!__is.fail()) |
3804 |
__x.param(param_type(__a, __b)); |
3805 |
return __is; |
3806 |
} |
3807 |
|
3808 |
// bernoulli_distribution |
3809 |
|
3810 |
class _LIBCPP_TYPE_VIS_ONLY bernoulli_distribution |
3811 |
{ |
3812 |
public: |
3813 |
// types |
3814 |
typedef bool result_type; |
3815 |
|
3816 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
3817 |
{ |
3818 |
double __p_; |
3819 |
public: |
3820 |
typedef bernoulli_distribution distribution_type; |
3821 |
|
3822 |
_LIBCPP_INLINE_VISIBILITY |
3823 |
explicit param_type(double __p = 0.5) : __p_(__p) {} |
3824 |
|
3825 |
_LIBCPP_INLINE_VISIBILITY |
3826 |
double p() const {return __p_;} |
3827 |
|
3828 |
friend _LIBCPP_INLINE_VISIBILITY |
3829 |
bool operator==(const param_type& __x, const param_type& __y) |
3830 |
{return __x.__p_ == __y.__p_;} |
3831 |
friend _LIBCPP_INLINE_VISIBILITY |
3832 |
bool operator!=(const param_type& __x, const param_type& __y) |
3833 |
{return !(__x == __y);} |
3834 |
}; |
3835 |
|
3836 |
private: |
3837 |
param_type __p_; |
3838 |
|
3839 |
public: |
3840 |
// constructors and reset functions |
3841 |
_LIBCPP_INLINE_VISIBILITY |
3842 |
explicit bernoulli_distribution(double __p = 0.5) |
3843 |
: __p_(param_type(__p)) {} |
3844 |
_LIBCPP_INLINE_VISIBILITY |
3845 |
explicit bernoulli_distribution(const param_type& __p) : __p_(__p) {} |
3846 |
_LIBCPP_INLINE_VISIBILITY |
3847 |
void reset() {} |
3848 |
|
3849 |
// generating functions |
3850 |
template<class _URNG> |
3851 |
_LIBCPP_INLINE_VISIBILITY |
3852 |
result_type operator()(_URNG& __g) |
3853 |
{return (*this)(__g, __p_);} |
3854 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
3855 |
|
3856 |
// property functions |
3857 |
_LIBCPP_INLINE_VISIBILITY |
3858 |
double p() const {return __p_.p();} |
3859 |
|
3860 |
_LIBCPP_INLINE_VISIBILITY |
3861 |
param_type param() const {return __p_;} |
3862 |
_LIBCPP_INLINE_VISIBILITY |
3863 |
void param(const param_type& __p) {__p_ = __p;} |
3864 |
|
3865 |
_LIBCPP_INLINE_VISIBILITY |
3866 |
result_type min() const {return false;} |
3867 |
_LIBCPP_INLINE_VISIBILITY |
3868 |
result_type max() const {return true;} |
3869 |
|
3870 |
friend _LIBCPP_INLINE_VISIBILITY |
3871 |
bool operator==(const bernoulli_distribution& __x, |
3872 |
const bernoulli_distribution& __y) |
3873 |
{return __x.__p_ == __y.__p_;} |
3874 |
friend _LIBCPP_INLINE_VISIBILITY |
3875 |
bool operator!=(const bernoulli_distribution& __x, |
3876 |
const bernoulli_distribution& __y) |
3877 |
{return !(__x == __y);} |
3878 |
}; |
3879 |
|
3880 |
template<class _URNG> |
3881 |
inline _LIBCPP_INLINE_VISIBILITY |
3882 |
bernoulli_distribution::result_type |
3883 |
bernoulli_distribution::operator()(_URNG& __g, const param_type& __p) |
3884 |
{ |
3885 |
uniform_real_distribution<double> __gen; |
3886 |
return __gen(__g) < __p.p(); |
3887 |
} |
3888 |
|
3889 |
template <class _CharT, class _Traits> |
3890 |
basic_ostream<_CharT, _Traits>& |
3891 |
operator<<(basic_ostream<_CharT, _Traits>& __os, const bernoulli_distribution& __x) |
3892 |
{ |
3893 |
__save_flags<_CharT, _Traits> __lx(__os); |
3894 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
3895 |
ios_base::scientific); |
3896 |
_CharT __sp = __os.widen(' '); |
3897 |
__os.fill(__sp); |
3898 |
return __os << __x.p(); |
3899 |
} |
3900 |
|
3901 |
template <class _CharT, class _Traits> |
3902 |
basic_istream<_CharT, _Traits>& |
3903 |
operator>>(basic_istream<_CharT, _Traits>& __is, bernoulli_distribution& __x) |
3904 |
{ |
3905 |
typedef bernoulli_distribution _Eng; |
3906 |
typedef typename _Eng::param_type param_type; |
3907 |
__save_flags<_CharT, _Traits> __lx(__is); |
3908 |
__is.flags(ios_base::dec | ios_base::skipws); |
3909 |
double __p; |
3910 |
__is >> __p; |
3911 |
if (!__is.fail()) |
3912 |
__x.param(param_type(__p)); |
3913 |
return __is; |
3914 |
} |
3915 |
|
3916 |
// binomial_distribution |
3917 |
|
3918 |
template<class _IntType = int> |
3919 |
class _LIBCPP_TYPE_VIS_ONLY binomial_distribution |
3920 |
{ |
3921 |
public: |
3922 |
// types |
3923 |
typedef _IntType result_type; |
3924 |
|
3925 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
3926 |
{ |
3927 |
result_type __t_; |
3928 |
double __p_; |
3929 |
double __pr_; |
3930 |
double __odds_ratio_; |
3931 |
result_type __r0_; |
3932 |
public: |
3933 |
typedef binomial_distribution distribution_type; |
3934 |
|
3935 |
explicit param_type(result_type __t = 1, double __p = 0.5); |
3936 |
|
3937 |
_LIBCPP_INLINE_VISIBILITY |
3938 |
result_type t() const {return __t_;} |
3939 |
_LIBCPP_INLINE_VISIBILITY |
3940 |
double p() const {return __p_;} |
3941 |
|
3942 |
friend _LIBCPP_INLINE_VISIBILITY |
3943 |
bool operator==(const param_type& __x, const param_type& __y) |
3944 |
{return __x.__t_ == __y.__t_ && __x.__p_ == __y.__p_;} |
3945 |
friend _LIBCPP_INLINE_VISIBILITY |
3946 |
bool operator!=(const param_type& __x, const param_type& __y) |
3947 |
{return !(__x == __y);} |
3948 |
|
3949 |
friend class binomial_distribution; |
3950 |
}; |
3951 |
|
3952 |
private: |
3953 |
param_type __p_; |
3954 |
|
3955 |
public: |
3956 |
// constructors and reset functions |
3957 |
_LIBCPP_INLINE_VISIBILITY |
3958 |
explicit binomial_distribution(result_type __t = 1, double __p = 0.5) |
3959 |
: __p_(param_type(__t, __p)) {} |
3960 |
_LIBCPP_INLINE_VISIBILITY |
3961 |
explicit binomial_distribution(const param_type& __p) : __p_(__p) {} |
3962 |
_LIBCPP_INLINE_VISIBILITY |
3963 |
void reset() {} |
3964 |
|
3965 |
// generating functions |
3966 |
template<class _URNG> |
3967 |
_LIBCPP_INLINE_VISIBILITY |
3968 |
result_type operator()(_URNG& __g) |
3969 |
{return (*this)(__g, __p_);} |
3970 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
3971 |
|
3972 |
// property functions |
3973 |
_LIBCPP_INLINE_VISIBILITY |
3974 |
result_type t() const {return __p_.t();} |
3975 |
_LIBCPP_INLINE_VISIBILITY |
3976 |
double p() const {return __p_.p();} |
3977 |
|
3978 |
_LIBCPP_INLINE_VISIBILITY |
3979 |
param_type param() const {return __p_;} |
3980 |
_LIBCPP_INLINE_VISIBILITY |
3981 |
void param(const param_type& __p) {__p_ = __p;} |
3982 |
|
3983 |
_LIBCPP_INLINE_VISIBILITY |
3984 |
result_type min() const {return 0;} |
3985 |
_LIBCPP_INLINE_VISIBILITY |
3986 |
result_type max() const {return t();} |
3987 |
|
3988 |
friend _LIBCPP_INLINE_VISIBILITY |
3989 |
bool operator==(const binomial_distribution& __x, |
3990 |
const binomial_distribution& __y) |
3991 |
{return __x.__p_ == __y.__p_;} |
3992 |
friend _LIBCPP_INLINE_VISIBILITY |
3993 |
bool operator!=(const binomial_distribution& __x, |
3994 |
const binomial_distribution& __y) |
3995 |
{return !(__x == __y);} |
3996 |
}; |
3997 |
|
3998 |
template<class _IntType> |
3999 |
binomial_distribution<_IntType>::param_type::param_type(result_type __t, double __p) |
4000 |
: __t_(__t), __p_(__p) |
4001 |
{ |
4002 |
if (0 < __p_ && __p_ < 1) |
4003 |
{ |
4004 |
__r0_ = static_cast<result_type>((__t_ + 1) * __p_); |
4005 |
__pr_ = _VSTD::exp(_VSTD::lgamma(__t_ + 1.) - _VSTD::lgamma(__r0_ + 1.) - |
4006 |
_VSTD::lgamma(__t_ - __r0_ + 1.) + __r0_ * _VSTD::log(__p_) + |
4007 |
(__t_ - __r0_) * _VSTD::log(1 - __p_)); |
4008 |
__odds_ratio_ = __p_ / (1 - __p_); |
4009 |
} |
4010 |
} |
4011 |
|
4012 |
// Reference: Kemp, C.D. (1986). `A modal method for generating binomial |
4013 |
// variables', Commun. Statist. - Theor. Meth. 15(3), 805-813. |
4014 |
template<class _IntType> |
4015 |
template<class _URNG> |
4016 |
_IntType |
4017 |
binomial_distribution<_IntType>::operator()(_URNG& __g, const param_type& __pr) |
4018 |
{ |
4019 |
if (__pr.__t_ == 0 || __pr.__p_ == 0) |
4020 |
return 0; |
4021 |
if (__pr.__p_ == 1) |
4022 |
return __pr.__t_; |
4023 |
uniform_real_distribution<double> __gen; |
4024 |
double __u = __gen(__g) - __pr.__pr_; |
4025 |
if (__u < 0) |
4026 |
return __pr.__r0_; |
4027 |
double __pu = __pr.__pr_; |
4028 |
double __pd = __pu; |
4029 |
result_type __ru = __pr.__r0_; |
4030 |
result_type __rd = __ru; |
4031 |
while (true) |
4032 |
{ |
4033 |
if (__rd >= 1) |
4034 |
{ |
4035 |
__pd *= __rd / (__pr.__odds_ratio_ * (__pr.__t_ - __rd + 1)); |
4036 |
__u -= __pd; |
4037 |
if (__u < 0) |
4038 |
return __rd - 1; |
4039 |
} |
4040 |
if ( __rd != 0 ) |
4041 |
--__rd; |
4042 |
++__ru; |
4043 |
if (__ru <= __pr.__t_) |
4044 |
{ |
4045 |
__pu *= (__pr.__t_ - __ru + 1) * __pr.__odds_ratio_ / __ru; |
4046 |
__u -= __pu; |
4047 |
if (__u < 0) |
4048 |
return __ru; |
4049 |
} |
4050 |
} |
4051 |
} |
4052 |
|
4053 |
template <class _CharT, class _Traits, class _IntType> |
4054 |
basic_ostream<_CharT, _Traits>& |
4055 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4056 |
const binomial_distribution<_IntType>& __x) |
4057 |
{ |
4058 |
__save_flags<_CharT, _Traits> __lx(__os); |
4059 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
4060 |
ios_base::scientific); |
4061 |
_CharT __sp = __os.widen(' '); |
4062 |
__os.fill(__sp); |
4063 |
return __os << __x.t() << __sp << __x.p(); |
4064 |
} |
4065 |
|
4066 |
template <class _CharT, class _Traits, class _IntType> |
4067 |
basic_istream<_CharT, _Traits>& |
4068 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4069 |
binomial_distribution<_IntType>& __x) |
4070 |
{ |
4071 |
typedef binomial_distribution<_IntType> _Eng; |
4072 |
typedef typename _Eng::result_type result_type; |
4073 |
typedef typename _Eng::param_type param_type; |
4074 |
__save_flags<_CharT, _Traits> __lx(__is); |
4075 |
__is.flags(ios_base::dec | ios_base::skipws); |
4076 |
result_type __t; |
4077 |
double __p; |
4078 |
__is >> __t >> __p; |
4079 |
if (!__is.fail()) |
4080 |
__x.param(param_type(__t, __p)); |
4081 |
return __is; |
4082 |
} |
4083 |
|
4084 |
// exponential_distribution |
4085 |
|
4086 |
template<class _RealType = double> |
4087 |
class _LIBCPP_TYPE_VIS_ONLY exponential_distribution |
4088 |
{ |
4089 |
public: |
4090 |
// types |
4091 |
typedef _RealType result_type; |
4092 |
|
4093 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4094 |
{ |
4095 |
result_type __lambda_; |
4096 |
public: |
4097 |
typedef exponential_distribution distribution_type; |
4098 |
|
4099 |
_LIBCPP_INLINE_VISIBILITY |
4100 |
explicit param_type(result_type __lambda = 1) : __lambda_(__lambda) {} |
4101 |
|
4102 |
_LIBCPP_INLINE_VISIBILITY |
4103 |
result_type lambda() const {return __lambda_;} |
4104 |
|
4105 |
friend _LIBCPP_INLINE_VISIBILITY |
4106 |
bool operator==(const param_type& __x, const param_type& __y) |
4107 |
{return __x.__lambda_ == __y.__lambda_;} |
4108 |
friend _LIBCPP_INLINE_VISIBILITY |
4109 |
bool operator!=(const param_type& __x, const param_type& __y) |
4110 |
{return !(__x == __y);} |
4111 |
}; |
4112 |
|
4113 |
private: |
4114 |
param_type __p_; |
4115 |
|
4116 |
public: |
4117 |
// constructors and reset functions |
4118 |
_LIBCPP_INLINE_VISIBILITY |
4119 |
explicit exponential_distribution(result_type __lambda = 1) |
4120 |
: __p_(param_type(__lambda)) {} |
4121 |
_LIBCPP_INLINE_VISIBILITY |
4122 |
explicit exponential_distribution(const param_type& __p) : __p_(__p) {} |
4123 |
_LIBCPP_INLINE_VISIBILITY |
4124 |
void reset() {} |
4125 |
|
4126 |
// generating functions |
4127 |
template<class _URNG> |
4128 |
_LIBCPP_INLINE_VISIBILITY |
4129 |
result_type operator()(_URNG& __g) |
4130 |
{return (*this)(__g, __p_);} |
4131 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
4132 |
|
4133 |
// property functions |
4134 |
_LIBCPP_INLINE_VISIBILITY |
4135 |
result_type lambda() const {return __p_.lambda();} |
4136 |
|
4137 |
_LIBCPP_INLINE_VISIBILITY |
4138 |
param_type param() const {return __p_;} |
4139 |
_LIBCPP_INLINE_VISIBILITY |
4140 |
void param(const param_type& __p) {__p_ = __p;} |
4141 |
|
4142 |
_LIBCPP_INLINE_VISIBILITY |
4143 |
result_type min() const {return 0;} |
4144 |
_LIBCPP_INLINE_VISIBILITY |
4145 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
4146 |
|
4147 |
friend _LIBCPP_INLINE_VISIBILITY |
4148 |
bool operator==(const exponential_distribution& __x, |
4149 |
const exponential_distribution& __y) |
4150 |
{return __x.__p_ == __y.__p_;} |
4151 |
friend _LIBCPP_INLINE_VISIBILITY |
4152 |
bool operator!=(const exponential_distribution& __x, |
4153 |
const exponential_distribution& __y) |
4154 |
{return !(__x == __y);} |
4155 |
}; |
4156 |
|
4157 |
template <class _RealType> |
4158 |
template<class _URNG> |
4159 |
_RealType |
4160 |
exponential_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
4161 |
{ |
4162 |
return -_VSTD::log |
4163 |
( |
4164 |
result_type(1) - |
4165 |
_VSTD::generate_canonical<result_type, |
4166 |
numeric_limits<result_type>::digits>(__g) |
4167 |
) |
4168 |
/ __p.lambda(); |
4169 |
} |
4170 |
|
4171 |
template <class _CharT, class _Traits, class _RealType> |
4172 |
basic_ostream<_CharT, _Traits>& |
4173 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4174 |
const exponential_distribution<_RealType>& __x) |
4175 |
{ |
4176 |
__save_flags<_CharT, _Traits> __lx(__os); |
4177 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
4178 |
ios_base::scientific); |
4179 |
return __os << __x.lambda(); |
4180 |
} |
4181 |
|
4182 |
template <class _CharT, class _Traits, class _RealType> |
4183 |
basic_istream<_CharT, _Traits>& |
4184 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4185 |
exponential_distribution<_RealType>& __x) |
4186 |
{ |
4187 |
typedef exponential_distribution<_RealType> _Eng; |
4188 |
typedef typename _Eng::result_type result_type; |
4189 |
typedef typename _Eng::param_type param_type; |
4190 |
__save_flags<_CharT, _Traits> __lx(__is); |
4191 |
__is.flags(ios_base::dec | ios_base::skipws); |
4192 |
result_type __lambda; |
4193 |
__is >> __lambda; |
4194 |
if (!__is.fail()) |
4195 |
__x.param(param_type(__lambda)); |
4196 |
return __is; |
4197 |
} |
4198 |
|
4199 |
// normal_distribution |
4200 |
|
4201 |
template<class _RealType = double> |
4202 |
class _LIBCPP_TYPE_VIS_ONLY normal_distribution |
4203 |
{ |
4204 |
public: |
4205 |
// types |
4206 |
typedef _RealType result_type; |
4207 |
|
4208 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4209 |
{ |
4210 |
result_type __mean_; |
4211 |
result_type __stddev_; |
4212 |
public: |
4213 |
typedef normal_distribution distribution_type; |
4214 |
|
4215 |
_LIBCPP_INLINE_VISIBILITY |
4216 |
explicit param_type(result_type __mean = 0, result_type __stddev = 1) |
4217 |
: __mean_(__mean), __stddev_(__stddev) {} |
4218 |
|
4219 |
_LIBCPP_INLINE_VISIBILITY |
4220 |
result_type mean() const {return __mean_;} |
4221 |
_LIBCPP_INLINE_VISIBILITY |
4222 |
result_type stddev() const {return __stddev_;} |
4223 |
|
4224 |
friend _LIBCPP_INLINE_VISIBILITY |
4225 |
bool operator==(const param_type& __x, const param_type& __y) |
4226 |
{return __x.__mean_ == __y.__mean_ && __x.__stddev_ == __y.__stddev_;} |
4227 |
friend _LIBCPP_INLINE_VISIBILITY |
4228 |
bool operator!=(const param_type& __x, const param_type& __y) |
4229 |
{return !(__x == __y);} |
4230 |
}; |
4231 |
|
4232 |
private: |
4233 |
param_type __p_; |
4234 |
result_type _V_; |
4235 |
bool _V_hot_; |
4236 |
|
4237 |
public: |
4238 |
// constructors and reset functions |
4239 |
_LIBCPP_INLINE_VISIBILITY |
4240 |
explicit normal_distribution(result_type __mean = 0, result_type __stddev = 1) |
4241 |
: __p_(param_type(__mean, __stddev)), _V_hot_(false) {} |
4242 |
_LIBCPP_INLINE_VISIBILITY |
4243 |
explicit normal_distribution(const param_type& __p) |
4244 |
: __p_(__p), _V_hot_(false) {} |
4245 |
_LIBCPP_INLINE_VISIBILITY |
4246 |
void reset() {_V_hot_ = false;} |
4247 |
|
4248 |
// generating functions |
4249 |
template<class _URNG> |
4250 |
_LIBCPP_INLINE_VISIBILITY |
4251 |
result_type operator()(_URNG& __g) |
4252 |
{return (*this)(__g, __p_);} |
4253 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
4254 |
|
4255 |
// property functions |
4256 |
_LIBCPP_INLINE_VISIBILITY |
4257 |
result_type mean() const {return __p_.mean();} |
4258 |
_LIBCPP_INLINE_VISIBILITY |
4259 |
result_type stddev() const {return __p_.stddev();} |
4260 |
|
4261 |
_LIBCPP_INLINE_VISIBILITY |
4262 |
param_type param() const {return __p_;} |
4263 |
_LIBCPP_INLINE_VISIBILITY |
4264 |
void param(const param_type& __p) {__p_ = __p;} |
4265 |
|
4266 |
_LIBCPP_INLINE_VISIBILITY |
4267 |
result_type min() const {return -numeric_limits<result_type>::infinity();} |
4268 |
_LIBCPP_INLINE_VISIBILITY |
4269 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
4270 |
|
4271 |
friend _LIBCPP_INLINE_VISIBILITY |
4272 |
bool operator==(const normal_distribution& __x, |
4273 |
const normal_distribution& __y) |
4274 |
{return __x.__p_ == __y.__p_ && __x._V_hot_ == __y._V_hot_ && |
4275 |
(!__x._V_hot_ || __x._V_ == __y._V_);} |
4276 |
friend _LIBCPP_INLINE_VISIBILITY |
4277 |
bool operator!=(const normal_distribution& __x, |
4278 |
const normal_distribution& __y) |
4279 |
{return !(__x == __y);} |
4280 |
|
4281 |
template <class _CharT, class _Traits, class _RT> |
4282 |
friend |
4283 |
basic_ostream<_CharT, _Traits>& |
4284 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4285 |
const normal_distribution<_RT>& __x); |
4286 |
|
4287 |
template <class _CharT, class _Traits, class _RT> |
4288 |
friend |
4289 |
basic_istream<_CharT, _Traits>& |
4290 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4291 |
normal_distribution<_RT>& __x); |
4292 |
}; |
4293 |
|
4294 |
template <class _RealType> |
4295 |
template<class _URNG> |
4296 |
_RealType |
4297 |
normal_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
4298 |
{ |
4299 |
result_type _Up; |
4300 |
if (_V_hot_) |
4301 |
{ |
4302 |
_V_hot_ = false; |
4303 |
_Up = _V_; |
4304 |
} |
4305 |
else |
4306 |
{ |
4307 |
uniform_real_distribution<result_type> _Uni(-1, 1); |
4308 |
result_type __u; |
4309 |
result_type __v; |
4310 |
result_type __s; |
4311 |
do |
4312 |
{ |
4313 |
__u = _Uni(__g); |
4314 |
__v = _Uni(__g); |
4315 |
__s = __u * __u + __v * __v; |
4316 |
} while (__s > 1 || __s == 0); |
4317 |
result_type _Fp = _VSTD::sqrt(-2 * _VSTD::log(__s) / __s); |
4318 |
_V_ = __v * _Fp; |
4319 |
_V_hot_ = true; |
4320 |
_Up = __u * _Fp; |
4321 |
} |
4322 |
return _Up * __p.stddev() + __p.mean(); |
4323 |
} |
4324 |
|
4325 |
template <class _CharT, class _Traits, class _RT> |
4326 |
basic_ostream<_CharT, _Traits>& |
4327 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4328 |
const normal_distribution<_RT>& __x) |
4329 |
{ |
4330 |
__save_flags<_CharT, _Traits> __lx(__os); |
4331 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
4332 |
ios_base::scientific); |
4333 |
_CharT __sp = __os.widen(' '); |
4334 |
__os.fill(__sp); |
4335 |
__os << __x.mean() << __sp << __x.stddev() << __sp << __x._V_hot_; |
4336 |
if (__x._V_hot_) |
4337 |
__os << __sp << __x._V_; |
4338 |
return __os; |
4339 |
} |
4340 |
|
4341 |
template <class _CharT, class _Traits, class _RT> |
4342 |
basic_istream<_CharT, _Traits>& |
4343 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4344 |
normal_distribution<_RT>& __x) |
4345 |
{ |
4346 |
typedef normal_distribution<_RT> _Eng; |
4347 |
typedef typename _Eng::result_type result_type; |
4348 |
typedef typename _Eng::param_type param_type; |
4349 |
__save_flags<_CharT, _Traits> __lx(__is); |
4350 |
__is.flags(ios_base::dec | ios_base::skipws); |
4351 |
result_type __mean; |
4352 |
result_type __stddev; |
4353 |
result_type _Vp = 0; |
4354 |
bool _V_hot = false; |
4355 |
__is >> __mean >> __stddev >> _V_hot; |
4356 |
if (_V_hot) |
4357 |
__is >> _Vp; |
4358 |
if (!__is.fail()) |
4359 |
{ |
4360 |
__x.param(param_type(__mean, __stddev)); |
4361 |
__x._V_hot_ = _V_hot; |
4362 |
__x._V_ = _Vp; |
4363 |
} |
4364 |
return __is; |
4365 |
} |
4366 |
|
4367 |
// lognormal_distribution |
4368 |
|
4369 |
template<class _RealType = double> |
4370 |
class _LIBCPP_TYPE_VIS_ONLY lognormal_distribution |
4371 |
{ |
4372 |
public: |
4373 |
// types |
4374 |
typedef _RealType result_type; |
4375 |
|
4376 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4377 |
{ |
4378 |
normal_distribution<result_type> __nd_; |
4379 |
public: |
4380 |
typedef lognormal_distribution distribution_type; |
4381 |
|
4382 |
_LIBCPP_INLINE_VISIBILITY |
4383 |
explicit param_type(result_type __m = 0, result_type __s = 1) |
4384 |
: __nd_(__m, __s) {} |
4385 |
|
4386 |
_LIBCPP_INLINE_VISIBILITY |
4387 |
result_type m() const {return __nd_.mean();} |
4388 |
_LIBCPP_INLINE_VISIBILITY |
4389 |
result_type s() const {return __nd_.stddev();} |
4390 |
|
4391 |
friend _LIBCPP_INLINE_VISIBILITY |
4392 |
bool operator==(const param_type& __x, const param_type& __y) |
4393 |
{return __x.__nd_ == __y.__nd_;} |
4394 |
friend _LIBCPP_INLINE_VISIBILITY |
4395 |
bool operator!=(const param_type& __x, const param_type& __y) |
4396 |
{return !(__x == __y);} |
4397 |
friend class lognormal_distribution; |
4398 |
|
4399 |
template <class _CharT, class _Traits, class _RT> |
4400 |
friend |
4401 |
basic_ostream<_CharT, _Traits>& |
4402 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4403 |
const lognormal_distribution<_RT>& __x); |
4404 |
|
4405 |
template <class _CharT, class _Traits, class _RT> |
4406 |
friend |
4407 |
basic_istream<_CharT, _Traits>& |
4408 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4409 |
lognormal_distribution<_RT>& __x); |
4410 |
}; |
4411 |
|
4412 |
private: |
4413 |
param_type __p_; |
4414 |
|
4415 |
public: |
4416 |
// constructor and reset functions |
4417 |
_LIBCPP_INLINE_VISIBILITY |
4418 |
explicit lognormal_distribution(result_type __m = 0, result_type __s = 1) |
4419 |
: __p_(param_type(__m, __s)) {} |
4420 |
_LIBCPP_INLINE_VISIBILITY |
4421 |
explicit lognormal_distribution(const param_type& __p) |
4422 |
: __p_(__p) {} |
4423 |
_LIBCPP_INLINE_VISIBILITY |
4424 |
void reset() {__p_.__nd_.reset();} |
4425 |
|
4426 |
// generating functions |
4427 |
template<class _URNG> |
4428 |
_LIBCPP_INLINE_VISIBILITY |
4429 |
result_type operator()(_URNG& __g) |
4430 |
{return (*this)(__g, __p_);} |
4431 |
template<class _URNG> |
4432 |
_LIBCPP_INLINE_VISIBILITY |
4433 |
result_type operator()(_URNG& __g, const param_type& __p) |
4434 |
{return _VSTD::exp(const_cast<normal_distribution<result_type>&>(__p.__nd_)(__g));} |
4435 |
|
4436 |
// property functions |
4437 |
_LIBCPP_INLINE_VISIBILITY |
4438 |
result_type m() const {return __p_.m();} |
4439 |
_LIBCPP_INLINE_VISIBILITY |
4440 |
result_type s() const {return __p_.s();} |
4441 |
|
4442 |
_LIBCPP_INLINE_VISIBILITY |
4443 |
param_type param() const {return __p_;} |
4444 |
_LIBCPP_INLINE_VISIBILITY |
4445 |
void param(const param_type& __p) {__p_ = __p;} |
4446 |
|
4447 |
_LIBCPP_INLINE_VISIBILITY |
4448 |
result_type min() const {return 0;} |
4449 |
_LIBCPP_INLINE_VISIBILITY |
4450 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
4451 |
|
4452 |
friend _LIBCPP_INLINE_VISIBILITY |
4453 |
bool operator==(const lognormal_distribution& __x, |
4454 |
const lognormal_distribution& __y) |
4455 |
{return __x.__p_ == __y.__p_;} |
4456 |
friend _LIBCPP_INLINE_VISIBILITY |
4457 |
bool operator!=(const lognormal_distribution& __x, |
4458 |
const lognormal_distribution& __y) |
4459 |
{return !(__x == __y);} |
4460 |
|
4461 |
template <class _CharT, class _Traits, class _RT> |
4462 |
friend |
4463 |
basic_ostream<_CharT, _Traits>& |
4464 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4465 |
const lognormal_distribution<_RT>& __x); |
4466 |
|
4467 |
template <class _CharT, class _Traits, class _RT> |
4468 |
friend |
4469 |
basic_istream<_CharT, _Traits>& |
4470 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4471 |
lognormal_distribution<_RT>& __x); |
4472 |
}; |
4473 |
|
4474 |
template <class _CharT, class _Traits, class _RT> |
4475 |
inline _LIBCPP_INLINE_VISIBILITY |
4476 |
basic_ostream<_CharT, _Traits>& |
4477 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4478 |
const lognormal_distribution<_RT>& __x) |
4479 |
{ |
4480 |
return __os << __x.__p_.__nd_; |
4481 |
} |
4482 |
|
4483 |
template <class _CharT, class _Traits, class _RT> |
4484 |
inline _LIBCPP_INLINE_VISIBILITY |
4485 |
basic_istream<_CharT, _Traits>& |
4486 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4487 |
lognormal_distribution<_RT>& __x) |
4488 |
{ |
4489 |
return __is >> __x.__p_.__nd_; |
4490 |
} |
4491 |
|
4492 |
// poisson_distribution |
4493 |
|
4494 |
template<class _IntType = int> |
4495 |
class _LIBCPP_TYPE_VIS_ONLY poisson_distribution |
4496 |
{ |
4497 |
public: |
4498 |
// types |
4499 |
typedef _IntType result_type; |
4500 |
|
4501 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4502 |
{ |
4503 |
double __mean_; |
4504 |
double __s_; |
4505 |
double __d_; |
4506 |
double __l_; |
4507 |
double __omega_; |
4508 |
double __c0_; |
4509 |
double __c1_; |
4510 |
double __c2_; |
4511 |
double __c3_; |
4512 |
double __c_; |
4513 |
|
4514 |
public: |
4515 |
typedef poisson_distribution distribution_type; |
4516 |
|
4517 |
explicit param_type(double __mean = 1.0); |
4518 |
|
4519 |
_LIBCPP_INLINE_VISIBILITY |
4520 |
double mean() const {return __mean_;} |
4521 |
|
4522 |
friend _LIBCPP_INLINE_VISIBILITY |
4523 |
bool operator==(const param_type& __x, const param_type& __y) |
4524 |
{return __x.__mean_ == __y.__mean_;} |
4525 |
friend _LIBCPP_INLINE_VISIBILITY |
4526 |
bool operator!=(const param_type& __x, const param_type& __y) |
4527 |
{return !(__x == __y);} |
4528 |
|
4529 |
friend class poisson_distribution; |
4530 |
}; |
4531 |
|
4532 |
private: |
4533 |
param_type __p_; |
4534 |
|
4535 |
public: |
4536 |
// constructors and reset functions |
4537 |
_LIBCPP_INLINE_VISIBILITY |
4538 |
explicit poisson_distribution(double __mean = 1.0) : __p_(__mean) {} |
4539 |
_LIBCPP_INLINE_VISIBILITY |
4540 |
explicit poisson_distribution(const param_type& __p) : __p_(__p) {} |
4541 |
_LIBCPP_INLINE_VISIBILITY |
4542 |
void reset() {} |
4543 |
|
4544 |
// generating functions |
4545 |
template<class _URNG> |
4546 |
_LIBCPP_INLINE_VISIBILITY |
4547 |
result_type operator()(_URNG& __g) |
4548 |
{return (*this)(__g, __p_);} |
4549 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
4550 |
|
4551 |
// property functions |
4552 |
_LIBCPP_INLINE_VISIBILITY |
4553 |
double mean() const {return __p_.mean();} |
4554 |
|
4555 |
_LIBCPP_INLINE_VISIBILITY |
4556 |
param_type param() const {return __p_;} |
4557 |
_LIBCPP_INLINE_VISIBILITY |
4558 |
void param(const param_type& __p) {__p_ = __p;} |
4559 |
|
4560 |
_LIBCPP_INLINE_VISIBILITY |
4561 |
result_type min() const {return 0;} |
4562 |
_LIBCPP_INLINE_VISIBILITY |
4563 |
result_type max() const {return numeric_limits<result_type>::max();} |
4564 |
|
4565 |
friend _LIBCPP_INLINE_VISIBILITY |
4566 |
bool operator==(const poisson_distribution& __x, |
4567 |
const poisson_distribution& __y) |
4568 |
{return __x.__p_ == __y.__p_;} |
4569 |
friend _LIBCPP_INLINE_VISIBILITY |
4570 |
bool operator!=(const poisson_distribution& __x, |
4571 |
const poisson_distribution& __y) |
4572 |
{return !(__x == __y);} |
4573 |
}; |
4574 |
|
4575 |
template<class _IntType> |
4576 |
poisson_distribution<_IntType>::param_type::param_type(double __mean) |
4577 |
: __mean_(__mean) |
4578 |
{ |
4579 |
if (__mean_ < 10) |
4580 |
{ |
4581 |
__s_ = 0; |
4582 |
__d_ = 0; |
4583 |
__l_ = _VSTD::exp(-__mean_); |
4584 |
__omega_ = 0; |
4585 |
__c3_ = 0; |
4586 |
__c2_ = 0; |
4587 |
__c1_ = 0; |
4588 |
__c0_ = 0; |
4589 |
__c_ = 0; |
4590 |
} |
4591 |
else |
4592 |
{ |
4593 |
__s_ = _VSTD::sqrt(__mean_); |
4594 |
__d_ = 6 * __mean_ * __mean_; |
4595 |
__l_ = static_cast<result_type>(__mean_ - 1.1484); |
4596 |
__omega_ = .3989423 / __s_; |
4597 |
double __b1_ = .4166667E-1 / __mean_; |
4598 |
double __b2_ = .3 * __b1_ * __b1_; |
4599 |
__c3_ = .1428571 * __b1_ * __b2_; |
4600 |
__c2_ = __b2_ - 15. * __c3_; |
4601 |
__c1_ = __b1_ - 6. * __b2_ + 45. * __c3_; |
4602 |
__c0_ = 1. - __b1_ + 3. * __b2_ - 15. * __c3_; |
4603 |
__c_ = .1069 / __mean_; |
4604 |
} |
4605 |
} |
4606 |
|
4607 |
template <class _IntType> |
4608 |
template<class _URNG> |
4609 |
_IntType |
4610 |
poisson_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr) |
4611 |
{ |
4612 |
result_type __x; |
4613 |
uniform_real_distribution<double> __urd; |
4614 |
if (__pr.__mean_ < 10) |
4615 |
{ |
4616 |
__x = 0; |
4617 |
for (double __p = __urd(__urng); __p > __pr.__l_; ++__x) |
4618 |
__p *= __urd(__urng); |
4619 |
} |
4620 |
else |
4621 |
{ |
4622 |
double __difmuk; |
4623 |
double __g = __pr.__mean_ + __pr.__s_ * normal_distribution<double>()(__urng); |
4624 |
double __u; |
4625 |
if (__g > 0) |
4626 |
{ |
4627 |
__x = static_cast<result_type>(__g); |
4628 |
if (__x >= __pr.__l_) |
4629 |
return __x; |
4630 |
__difmuk = __pr.__mean_ - __x; |
4631 |
__u = __urd(__urng); |
4632 |
if (__pr.__d_ * __u >= __difmuk * __difmuk * __difmuk) |
4633 |
return __x; |
4634 |
} |
4635 |
exponential_distribution<double> __edist; |
4636 |
for (bool __using_exp_dist = false; true; __using_exp_dist = true) |
4637 |
{ |
4638 |
double __e; |
4639 |
if (__using_exp_dist || __g < 0) |
4640 |
{ |
4641 |
double __t; |
4642 |
do |
4643 |
{ |
4644 |
__e = __edist(__urng); |
4645 |
__u = __urd(__urng); |
4646 |
__u += __u - 1; |
4647 |
__t = 1.8 + (__u < 0 ? -__e : __e); |
4648 |
} while (__t <= -.6744); |
4649 |
__x = __pr.__mean_ + __pr.__s_ * __t; |
4650 |
__difmuk = __pr.__mean_ - __x; |
4651 |
__using_exp_dist = true; |
4652 |
} |
4653 |
double __px; |
4654 |
double __py; |
4655 |
if (__x < 10) |
4656 |
{ |
4657 |
const result_type __fac[] = {1, 1, 2, 6, 24, 120, 720, 5040, |
4658 |
40320, 362880}; |
4659 |
__px = -__pr.__mean_; |
4660 |
__py = _VSTD::pow(__pr.__mean_, (double)__x) / __fac[__x]; |
4661 |
} |
4662 |
else |
4663 |
{ |
4664 |
double __del = .8333333E-1 / __x; |
4665 |
__del -= 4.8 * __del * __del * __del; |
4666 |
double __v = __difmuk / __x; |
4667 |
if (_VSTD::abs(__v) > 0.25) |
4668 |
__px = __x * _VSTD::log(1 + __v) - __difmuk - __del; |
4669 |
else |
4670 |
__px = __x * __v * __v * (((((((.1250060 * __v + -.1384794) * |
4671 |
__v + .1421878) * __v + -.1661269) * __v + .2000118) * |
4672 |
__v + -.2500068) * __v + .3333333) * __v + -.5) - __del; |
4673 |
__py = .3989423 / _VSTD::sqrt(__x); |
4674 |
} |
4675 |
double __r = (0.5 - __difmuk) / __pr.__s_; |
4676 |
double __r2 = __r * __r; |
4677 |
double __fx = -0.5 * __r2; |
4678 |
double __fy = __pr.__omega_ * (((__pr.__c3_ * __r2 + __pr.__c2_) * |
4679 |
__r2 + __pr.__c1_) * __r2 + __pr.__c0_); |
4680 |
if (__using_exp_dist) |
4681 |
{ |
4682 |
if (__pr.__c_ * _VSTD::abs(__u) <= __py * _VSTD::exp(__px + __e) - |
4683 |
__fy * _VSTD::exp(__fx + __e)) |
4684 |
break; |
4685 |
} |
4686 |
else |
4687 |
{ |
4688 |
if (__fy - __u * __fy <= __py * _VSTD::exp(__px - __fx)) |
4689 |
break; |
4690 |
} |
4691 |
} |
4692 |
} |
4693 |
return __x; |
4694 |
} |
4695 |
|
4696 |
template <class _CharT, class _Traits, class _IntType> |
4697 |
basic_ostream<_CharT, _Traits>& |
4698 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4699 |
const poisson_distribution<_IntType>& __x) |
4700 |
{ |
4701 |
__save_flags<_CharT, _Traits> __lx(__os); |
4702 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
4703 |
ios_base::scientific); |
4704 |
return __os << __x.mean(); |
4705 |
} |
4706 |
|
4707 |
template <class _CharT, class _Traits, class _IntType> |
4708 |
basic_istream<_CharT, _Traits>& |
4709 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4710 |
poisson_distribution<_IntType>& __x) |
4711 |
{ |
4712 |
typedef poisson_distribution<_IntType> _Eng; |
4713 |
typedef typename _Eng::param_type param_type; |
4714 |
__save_flags<_CharT, _Traits> __lx(__is); |
4715 |
__is.flags(ios_base::dec | ios_base::skipws); |
4716 |
double __mean; |
4717 |
__is >> __mean; |
4718 |
if (!__is.fail()) |
4719 |
__x.param(param_type(__mean)); |
4720 |
return __is; |
4721 |
} |
4722 |
|
4723 |
// weibull_distribution |
4724 |
|
4725 |
template<class _RealType = double> |
4726 |
class _LIBCPP_TYPE_VIS_ONLY weibull_distribution |
4727 |
{ |
4728 |
public: |
4729 |
// types |
4730 |
typedef _RealType result_type; |
4731 |
|
4732 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4733 |
{ |
4734 |
result_type __a_; |
4735 |
result_type __b_; |
4736 |
public: |
4737 |
typedef weibull_distribution distribution_type; |
4738 |
|
4739 |
_LIBCPP_INLINE_VISIBILITY |
4740 |
explicit param_type(result_type __a = 1, result_type __b = 1) |
4741 |
: __a_(__a), __b_(__b) {} |
4742 |
|
4743 |
_LIBCPP_INLINE_VISIBILITY |
4744 |
result_type a() const {return __a_;} |
4745 |
_LIBCPP_INLINE_VISIBILITY |
4746 |
result_type b() const {return __b_;} |
4747 |
|
4748 |
friend _LIBCPP_INLINE_VISIBILITY |
4749 |
bool operator==(const param_type& __x, const param_type& __y) |
4750 |
{return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} |
4751 |
friend _LIBCPP_INLINE_VISIBILITY |
4752 |
bool operator!=(const param_type& __x, const param_type& __y) |
4753 |
{return !(__x == __y);} |
4754 |
}; |
4755 |
|
4756 |
private: |
4757 |
param_type __p_; |
4758 |
|
4759 |
public: |
4760 |
// constructor and reset functions |
4761 |
_LIBCPP_INLINE_VISIBILITY |
4762 |
explicit weibull_distribution(result_type __a = 1, result_type __b = 1) |
4763 |
: __p_(param_type(__a, __b)) {} |
4764 |
_LIBCPP_INLINE_VISIBILITY |
4765 |
explicit weibull_distribution(const param_type& __p) |
4766 |
: __p_(__p) {} |
4767 |
_LIBCPP_INLINE_VISIBILITY |
4768 |
void reset() {} |
4769 |
|
4770 |
// generating functions |
4771 |
template<class _URNG> |
4772 |
_LIBCPP_INLINE_VISIBILITY |
4773 |
result_type operator()(_URNG& __g) |
4774 |
{return (*this)(__g, __p_);} |
4775 |
template<class _URNG> |
4776 |
_LIBCPP_INLINE_VISIBILITY |
4777 |
result_type operator()(_URNG& __g, const param_type& __p) |
4778 |
{return __p.b() * |
4779 |
_VSTD::pow(exponential_distribution<result_type>()(__g), 1/__p.a());} |
4780 |
|
4781 |
// property functions |
4782 |
_LIBCPP_INLINE_VISIBILITY |
4783 |
result_type a() const {return __p_.a();} |
4784 |
_LIBCPP_INLINE_VISIBILITY |
4785 |
result_type b() const {return __p_.b();} |
4786 |
|
4787 |
_LIBCPP_INLINE_VISIBILITY |
4788 |
param_type param() const {return __p_;} |
4789 |
_LIBCPP_INLINE_VISIBILITY |
4790 |
void param(const param_type& __p) {__p_ = __p;} |
4791 |
|
4792 |
_LIBCPP_INLINE_VISIBILITY |
4793 |
result_type min() const {return 0;} |
4794 |
_LIBCPP_INLINE_VISIBILITY |
4795 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
4796 |
|
4797 |
friend _LIBCPP_INLINE_VISIBILITY |
4798 |
bool operator==(const weibull_distribution& __x, |
4799 |
const weibull_distribution& __y) |
4800 |
{return __x.__p_ == __y.__p_;} |
4801 |
friend _LIBCPP_INLINE_VISIBILITY |
4802 |
bool operator!=(const weibull_distribution& __x, |
4803 |
const weibull_distribution& __y) |
4804 |
{return !(__x == __y);} |
4805 |
}; |
4806 |
|
4807 |
template <class _CharT, class _Traits, class _RT> |
4808 |
basic_ostream<_CharT, _Traits>& |
4809 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4810 |
const weibull_distribution<_RT>& __x) |
4811 |
{ |
4812 |
__save_flags<_CharT, _Traits> __lx(__os); |
4813 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
4814 |
ios_base::scientific); |
4815 |
_CharT __sp = __os.widen(' '); |
4816 |
__os.fill(__sp); |
4817 |
__os << __x.a() << __sp << __x.b(); |
4818 |
return __os; |
4819 |
} |
4820 |
|
4821 |
template <class _CharT, class _Traits, class _RT> |
4822 |
basic_istream<_CharT, _Traits>& |
4823 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4824 |
weibull_distribution<_RT>& __x) |
4825 |
{ |
4826 |
typedef weibull_distribution<_RT> _Eng; |
4827 |
typedef typename _Eng::result_type result_type; |
4828 |
typedef typename _Eng::param_type param_type; |
4829 |
__save_flags<_CharT, _Traits> __lx(__is); |
4830 |
__is.flags(ios_base::dec | ios_base::skipws); |
4831 |
result_type __a; |
4832 |
result_type __b; |
4833 |
__is >> __a >> __b; |
4834 |
if (!__is.fail()) |
4835 |
__x.param(param_type(__a, __b)); |
4836 |
return __is; |
4837 |
} |
4838 |
|
4839 |
template<class _RealType = double> |
4840 |
class _LIBCPP_TYPE_VIS_ONLY extreme_value_distribution |
4841 |
{ |
4842 |
public: |
4843 |
// types |
4844 |
typedef _RealType result_type; |
4845 |
|
4846 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4847 |
{ |
4848 |
result_type __a_; |
4849 |
result_type __b_; |
4850 |
public: |
4851 |
typedef extreme_value_distribution distribution_type; |
4852 |
|
4853 |
_LIBCPP_INLINE_VISIBILITY |
4854 |
explicit param_type(result_type __a = 0, result_type __b = 1) |
4855 |
: __a_(__a), __b_(__b) {} |
4856 |
|
4857 |
_LIBCPP_INLINE_VISIBILITY |
4858 |
result_type a() const {return __a_;} |
4859 |
_LIBCPP_INLINE_VISIBILITY |
4860 |
result_type b() const {return __b_;} |
4861 |
|
4862 |
friend _LIBCPP_INLINE_VISIBILITY |
4863 |
bool operator==(const param_type& __x, const param_type& __y) |
4864 |
{return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} |
4865 |
friend _LIBCPP_INLINE_VISIBILITY |
4866 |
bool operator!=(const param_type& __x, const param_type& __y) |
4867 |
{return !(__x == __y);} |
4868 |
}; |
4869 |
|
4870 |
private: |
4871 |
param_type __p_; |
4872 |
|
4873 |
public: |
4874 |
// constructor and reset functions |
4875 |
_LIBCPP_INLINE_VISIBILITY |
4876 |
explicit extreme_value_distribution(result_type __a = 0, result_type __b = 1) |
4877 |
: __p_(param_type(__a, __b)) {} |
4878 |
_LIBCPP_INLINE_VISIBILITY |
4879 |
explicit extreme_value_distribution(const param_type& __p) |
4880 |
: __p_(__p) {} |
4881 |
_LIBCPP_INLINE_VISIBILITY |
4882 |
void reset() {} |
4883 |
|
4884 |
// generating functions |
4885 |
template<class _URNG> |
4886 |
_LIBCPP_INLINE_VISIBILITY |
4887 |
result_type operator()(_URNG& __g) |
4888 |
{return (*this)(__g, __p_);} |
4889 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
4890 |
|
4891 |
// property functions |
4892 |
_LIBCPP_INLINE_VISIBILITY |
4893 |
result_type a() const {return __p_.a();} |
4894 |
_LIBCPP_INLINE_VISIBILITY |
4895 |
result_type b() const {return __p_.b();} |
4896 |
|
4897 |
_LIBCPP_INLINE_VISIBILITY |
4898 |
param_type param() const {return __p_;} |
4899 |
_LIBCPP_INLINE_VISIBILITY |
4900 |
void param(const param_type& __p) {__p_ = __p;} |
4901 |
|
4902 |
_LIBCPP_INLINE_VISIBILITY |
4903 |
result_type min() const {return -numeric_limits<result_type>::infinity();} |
4904 |
_LIBCPP_INLINE_VISIBILITY |
4905 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
4906 |
|
4907 |
friend _LIBCPP_INLINE_VISIBILITY |
4908 |
bool operator==(const extreme_value_distribution& __x, |
4909 |
const extreme_value_distribution& __y) |
4910 |
{return __x.__p_ == __y.__p_;} |
4911 |
friend _LIBCPP_INLINE_VISIBILITY |
4912 |
bool operator!=(const extreme_value_distribution& __x, |
4913 |
const extreme_value_distribution& __y) |
4914 |
{return !(__x == __y);} |
4915 |
}; |
4916 |
|
4917 |
template<class _RealType> |
4918 |
template<class _URNG> |
4919 |
_RealType |
4920 |
extreme_value_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
4921 |
{ |
4922 |
return __p.a() - __p.b() * |
4923 |
_VSTD::log(-_VSTD::log(1-uniform_real_distribution<result_type>()(__g))); |
4924 |
} |
4925 |
|
4926 |
template <class _CharT, class _Traits, class _RT> |
4927 |
basic_ostream<_CharT, _Traits>& |
4928 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
4929 |
const extreme_value_distribution<_RT>& __x) |
4930 |
{ |
4931 |
__save_flags<_CharT, _Traits> __lx(__os); |
4932 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
4933 |
ios_base::scientific); |
4934 |
_CharT __sp = __os.widen(' '); |
4935 |
__os.fill(__sp); |
4936 |
__os << __x.a() << __sp << __x.b(); |
4937 |
return __os; |
4938 |
} |
4939 |
|
4940 |
template <class _CharT, class _Traits, class _RT> |
4941 |
basic_istream<_CharT, _Traits>& |
4942 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
4943 |
extreme_value_distribution<_RT>& __x) |
4944 |
{ |
4945 |
typedef extreme_value_distribution<_RT> _Eng; |
4946 |
typedef typename _Eng::result_type result_type; |
4947 |
typedef typename _Eng::param_type param_type; |
4948 |
__save_flags<_CharT, _Traits> __lx(__is); |
4949 |
__is.flags(ios_base::dec | ios_base::skipws); |
4950 |
result_type __a; |
4951 |
result_type __b; |
4952 |
__is >> __a >> __b; |
4953 |
if (!__is.fail()) |
4954 |
__x.param(param_type(__a, __b)); |
4955 |
return __is; |
4956 |
} |
4957 |
|
4958 |
// gamma_distribution |
4959 |
|
4960 |
template<class _RealType = double> |
4961 |
class _LIBCPP_TYPE_VIS_ONLY gamma_distribution |
4962 |
{ |
4963 |
public: |
4964 |
// types |
4965 |
typedef _RealType result_type; |
4966 |
|
4967 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
4968 |
{ |
4969 |
result_type __alpha_; |
4970 |
result_type __beta_; |
4971 |
public: |
4972 |
typedef gamma_distribution distribution_type; |
4973 |
|
4974 |
_LIBCPP_INLINE_VISIBILITY |
4975 |
explicit param_type(result_type __alpha = 1, result_type __beta = 1) |
4976 |
: __alpha_(__alpha), __beta_(__beta) {} |
4977 |
|
4978 |
_LIBCPP_INLINE_VISIBILITY |
4979 |
result_type alpha() const {return __alpha_;} |
4980 |
_LIBCPP_INLINE_VISIBILITY |
4981 |
result_type beta() const {return __beta_;} |
4982 |
|
4983 |
friend _LIBCPP_INLINE_VISIBILITY |
4984 |
bool operator==(const param_type& __x, const param_type& __y) |
4985 |
{return __x.__alpha_ == __y.__alpha_ && __x.__beta_ == __y.__beta_;} |
4986 |
friend _LIBCPP_INLINE_VISIBILITY |
4987 |
bool operator!=(const param_type& __x, const param_type& __y) |
4988 |
{return !(__x == __y);} |
4989 |
}; |
4990 |
|
4991 |
private: |
4992 |
param_type __p_; |
4993 |
|
4994 |
public: |
4995 |
// constructors and reset functions |
4996 |
_LIBCPP_INLINE_VISIBILITY |
4997 |
explicit gamma_distribution(result_type __alpha = 1, result_type __beta = 1) |
4998 |
: __p_(param_type(__alpha, __beta)) {} |
4999 |
_LIBCPP_INLINE_VISIBILITY |
5000 |
explicit gamma_distribution(const param_type& __p) |
5001 |
: __p_(__p) {} |
5002 |
_LIBCPP_INLINE_VISIBILITY |
5003 |
void reset() {} |
5004 |
|
5005 |
// generating functions |
5006 |
template<class _URNG> |
5007 |
_LIBCPP_INLINE_VISIBILITY |
5008 |
result_type operator()(_URNG& __g) |
5009 |
{return (*this)(__g, __p_);} |
5010 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
5011 |
|
5012 |
// property functions |
5013 |
_LIBCPP_INLINE_VISIBILITY |
5014 |
result_type alpha() const {return __p_.alpha();} |
5015 |
_LIBCPP_INLINE_VISIBILITY |
5016 |
result_type beta() const {return __p_.beta();} |
5017 |
|
5018 |
_LIBCPP_INLINE_VISIBILITY |
5019 |
param_type param() const {return __p_;} |
5020 |
_LIBCPP_INLINE_VISIBILITY |
5021 |
void param(const param_type& __p) {__p_ = __p;} |
5022 |
|
5023 |
_LIBCPP_INLINE_VISIBILITY |
5024 |
result_type min() const {return 0;} |
5025 |
_LIBCPP_INLINE_VISIBILITY |
5026 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
5027 |
|
5028 |
friend _LIBCPP_INLINE_VISIBILITY |
5029 |
bool operator==(const gamma_distribution& __x, |
5030 |
const gamma_distribution& __y) |
5031 |
{return __x.__p_ == __y.__p_;} |
5032 |
friend _LIBCPP_INLINE_VISIBILITY |
5033 |
bool operator!=(const gamma_distribution& __x, |
5034 |
const gamma_distribution& __y) |
5035 |
{return !(__x == __y);} |
5036 |
}; |
5037 |
|
5038 |
template <class _RealType> |
5039 |
template<class _URNG> |
5040 |
_RealType |
5041 |
gamma_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
5042 |
{ |
5043 |
result_type __a = __p.alpha(); |
5044 |
uniform_real_distribution<result_type> __gen(0, 1); |
5045 |
exponential_distribution<result_type> __egen; |
5046 |
result_type __x; |
5047 |
if (__a == 1) |
5048 |
__x = __egen(__g); |
5049 |
else if (__a > 1) |
5050 |
{ |
5051 |
const result_type __b = __a - 1; |
5052 |
const result_type __c = 3 * __a - result_type(0.75); |
5053 |
while (true) |
5054 |
{ |
5055 |
const result_type __u = __gen(__g); |
5056 |
const result_type __v = __gen(__g); |
5057 |
const result_type __w = __u * (1 - __u); |
5058 |
if (__w != 0) |
5059 |
{ |
5060 |
const result_type __y = _VSTD::sqrt(__c / __w) * |
5061 |
(__u - result_type(0.5)); |
5062 |
__x = __b + __y; |
5063 |
if (__x >= 0) |
5064 |
{ |
5065 |
const result_type __z = 64 * __w * __w * __w * __v * __v; |
5066 |
if (__z <= 1 - 2 * __y * __y / __x) |
5067 |
break; |
5068 |
if (_VSTD::log(__z) <= 2 * (__b * _VSTD::log(__x / __b) - __y)) |
5069 |
break; |
5070 |
} |
5071 |
} |
5072 |
} |
5073 |
} |
5074 |
else // __a < 1 |
5075 |
{ |
5076 |
while (true) |
5077 |
{ |
5078 |
const result_type __u = __gen(__g); |
5079 |
const result_type __es = __egen(__g); |
5080 |
if (__u <= 1 - __a) |
5081 |
{ |
5082 |
__x = _VSTD::pow(__u, 1 / __a); |
5083 |
if (__x <= __es) |
5084 |
break; |
5085 |
} |
5086 |
else |
5087 |
{ |
5088 |
const result_type __e = -_VSTD::log((1-__u)/__a); |
5089 |
__x = _VSTD::pow(1 - __a + __a * __e, 1 / __a); |
5090 |
if (__x <= __e + __es) |
5091 |
break; |
5092 |
} |
5093 |
} |
5094 |
} |
5095 |
return __x * __p.beta(); |
5096 |
} |
5097 |
|
5098 |
template <class _CharT, class _Traits, class _RT> |
5099 |
basic_ostream<_CharT, _Traits>& |
5100 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5101 |
const gamma_distribution<_RT>& __x) |
5102 |
{ |
5103 |
__save_flags<_CharT, _Traits> __lx(__os); |
5104 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5105 |
ios_base::scientific); |
5106 |
_CharT __sp = __os.widen(' '); |
5107 |
__os.fill(__sp); |
5108 |
__os << __x.alpha() << __sp << __x.beta(); |
5109 |
return __os; |
5110 |
} |
5111 |
|
5112 |
template <class _CharT, class _Traits, class _RT> |
5113 |
basic_istream<_CharT, _Traits>& |
5114 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5115 |
gamma_distribution<_RT>& __x) |
5116 |
{ |
5117 |
typedef gamma_distribution<_RT> _Eng; |
5118 |
typedef typename _Eng::result_type result_type; |
5119 |
typedef typename _Eng::param_type param_type; |
5120 |
__save_flags<_CharT, _Traits> __lx(__is); |
5121 |
__is.flags(ios_base::dec | ios_base::skipws); |
5122 |
result_type __alpha; |
5123 |
result_type __beta; |
5124 |
__is >> __alpha >> __beta; |
5125 |
if (!__is.fail()) |
5126 |
__x.param(param_type(__alpha, __beta)); |
5127 |
return __is; |
5128 |
} |
5129 |
|
5130 |
// negative_binomial_distribution |
5131 |
|
5132 |
template<class _IntType = int> |
5133 |
class _LIBCPP_TYPE_VIS_ONLY negative_binomial_distribution |
5134 |
{ |
5135 |
public: |
5136 |
// types |
5137 |
typedef _IntType result_type; |
5138 |
|
5139 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5140 |
{ |
5141 |
result_type __k_; |
5142 |
double __p_; |
5143 |
public: |
5144 |
typedef negative_binomial_distribution distribution_type; |
5145 |
|
5146 |
_LIBCPP_INLINE_VISIBILITY |
5147 |
explicit param_type(result_type __k = 1, double __p = 0.5) |
5148 |
: __k_(__k), __p_(__p) {} |
5149 |
|
5150 |
_LIBCPP_INLINE_VISIBILITY |
5151 |
result_type k() const {return __k_;} |
5152 |
_LIBCPP_INLINE_VISIBILITY |
5153 |
double p() const {return __p_;} |
5154 |
|
5155 |
friend _LIBCPP_INLINE_VISIBILITY |
5156 |
bool operator==(const param_type& __x, const param_type& __y) |
5157 |
{return __x.__k_ == __y.__k_ && __x.__p_ == __y.__p_;} |
5158 |
friend _LIBCPP_INLINE_VISIBILITY |
5159 |
bool operator!=(const param_type& __x, const param_type& __y) |
5160 |
{return !(__x == __y);} |
5161 |
}; |
5162 |
|
5163 |
private: |
5164 |
param_type __p_; |
5165 |
|
5166 |
public: |
5167 |
// constructor and reset functions |
5168 |
_LIBCPP_INLINE_VISIBILITY |
5169 |
explicit negative_binomial_distribution(result_type __k = 1, double __p = 0.5) |
5170 |
: __p_(__k, __p) {} |
5171 |
_LIBCPP_INLINE_VISIBILITY |
5172 |
explicit negative_binomial_distribution(const param_type& __p) : __p_(__p) {} |
5173 |
_LIBCPP_INLINE_VISIBILITY |
5174 |
void reset() {} |
5175 |
|
5176 |
// generating functions |
5177 |
template<class _URNG> |
5178 |
_LIBCPP_INLINE_VISIBILITY |
5179 |
result_type operator()(_URNG& __g) |
5180 |
{return (*this)(__g, __p_);} |
5181 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
5182 |
|
5183 |
// property functions |
5184 |
_LIBCPP_INLINE_VISIBILITY |
5185 |
result_type k() const {return __p_.k();} |
5186 |
_LIBCPP_INLINE_VISIBILITY |
5187 |
double p() const {return __p_.p();} |
5188 |
|
5189 |
_LIBCPP_INLINE_VISIBILITY |
5190 |
param_type param() const {return __p_;} |
5191 |
_LIBCPP_INLINE_VISIBILITY |
5192 |
void param(const param_type& __p) {__p_ = __p;} |
5193 |
|
5194 |
_LIBCPP_INLINE_VISIBILITY |
5195 |
result_type min() const {return 0;} |
5196 |
_LIBCPP_INLINE_VISIBILITY |
5197 |
result_type max() const {return numeric_limits<result_type>::max();} |
5198 |
|
5199 |
friend _LIBCPP_INLINE_VISIBILITY |
5200 |
bool operator==(const negative_binomial_distribution& __x, |
5201 |
const negative_binomial_distribution& __y) |
5202 |
{return __x.__p_ == __y.__p_;} |
5203 |
friend _LIBCPP_INLINE_VISIBILITY |
5204 |
bool operator!=(const negative_binomial_distribution& __x, |
5205 |
const negative_binomial_distribution& __y) |
5206 |
{return !(__x == __y);} |
5207 |
}; |
5208 |
|
5209 |
template <class _IntType> |
5210 |
template<class _URNG> |
5211 |
_IntType |
5212 |
negative_binomial_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr) |
5213 |
{ |
5214 |
result_type __k = __pr.k(); |
5215 |
double __p = __pr.p(); |
5216 |
if (__k <= 21 * __p) |
5217 |
{ |
5218 |
bernoulli_distribution __gen(__p); |
5219 |
result_type __f = 0; |
5220 |
result_type __s = 0; |
5221 |
while (__s < __k) |
5222 |
{ |
5223 |
if (__gen(__urng)) |
5224 |
++__s; |
5225 |
else |
5226 |
++__f; |
5227 |
} |
5228 |
return __f; |
5229 |
} |
5230 |
return poisson_distribution<result_type>(gamma_distribution<double> |
5231 |
(__k, (1-__p)/__p)(__urng))(__urng); |
5232 |
} |
5233 |
|
5234 |
template <class _CharT, class _Traits, class _IntType> |
5235 |
basic_ostream<_CharT, _Traits>& |
5236 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5237 |
const negative_binomial_distribution<_IntType>& __x) |
5238 |
{ |
5239 |
__save_flags<_CharT, _Traits> __lx(__os); |
5240 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5241 |
ios_base::scientific); |
5242 |
_CharT __sp = __os.widen(' '); |
5243 |
__os.fill(__sp); |
5244 |
return __os << __x.k() << __sp << __x.p(); |
5245 |
} |
5246 |
|
5247 |
template <class _CharT, class _Traits, class _IntType> |
5248 |
basic_istream<_CharT, _Traits>& |
5249 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5250 |
negative_binomial_distribution<_IntType>& __x) |
5251 |
{ |
5252 |
typedef negative_binomial_distribution<_IntType> _Eng; |
5253 |
typedef typename _Eng::result_type result_type; |
5254 |
typedef typename _Eng::param_type param_type; |
5255 |
__save_flags<_CharT, _Traits> __lx(__is); |
5256 |
__is.flags(ios_base::dec | ios_base::skipws); |
5257 |
result_type __k; |
5258 |
double __p; |
5259 |
__is >> __k >> __p; |
5260 |
if (!__is.fail()) |
5261 |
__x.param(param_type(__k, __p)); |
5262 |
return __is; |
5263 |
} |
5264 |
|
5265 |
// geometric_distribution |
5266 |
|
5267 |
template<class _IntType = int> |
5268 |
class _LIBCPP_TYPE_VIS_ONLY geometric_distribution |
5269 |
{ |
5270 |
public: |
5271 |
// types |
5272 |
typedef _IntType result_type; |
5273 |
|
5274 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5275 |
{ |
5276 |
double __p_; |
5277 |
public: |
5278 |
typedef geometric_distribution distribution_type; |
5279 |
|
5280 |
_LIBCPP_INLINE_VISIBILITY |
5281 |
explicit param_type(double __p = 0.5) : __p_(__p) {} |
5282 |
|
5283 |
_LIBCPP_INLINE_VISIBILITY |
5284 |
double p() const {return __p_;} |
5285 |
|
5286 |
friend _LIBCPP_INLINE_VISIBILITY |
5287 |
bool operator==(const param_type& __x, const param_type& __y) |
5288 |
{return __x.__p_ == __y.__p_;} |
5289 |
friend _LIBCPP_INLINE_VISIBILITY |
5290 |
bool operator!=(const param_type& __x, const param_type& __y) |
5291 |
{return !(__x == __y);} |
5292 |
}; |
5293 |
|
5294 |
private: |
5295 |
param_type __p_; |
5296 |
|
5297 |
public: |
5298 |
// constructors and reset functions |
5299 |
_LIBCPP_INLINE_VISIBILITY |
5300 |
explicit geometric_distribution(double __p = 0.5) : __p_(__p) {} |
5301 |
_LIBCPP_INLINE_VISIBILITY |
5302 |
explicit geometric_distribution(const param_type& __p) : __p_(__p) {} |
5303 |
_LIBCPP_INLINE_VISIBILITY |
5304 |
void reset() {} |
5305 |
|
5306 |
// generating functions |
5307 |
template<class _URNG> |
5308 |
_LIBCPP_INLINE_VISIBILITY |
5309 |
result_type operator()(_URNG& __g) |
5310 |
{return (*this)(__g, __p_);} |
5311 |
template<class _URNG> |
5312 |
_LIBCPP_INLINE_VISIBILITY |
5313 |
result_type operator()(_URNG& __g, const param_type& __p) |
5314 |
{return negative_binomial_distribution<result_type>(1, __p.p())(__g);} |
5315 |
|
5316 |
// property functions |
5317 |
_LIBCPP_INLINE_VISIBILITY |
5318 |
double p() const {return __p_.p();} |
5319 |
|
5320 |
_LIBCPP_INLINE_VISIBILITY |
5321 |
param_type param() const {return __p_;} |
5322 |
_LIBCPP_INLINE_VISIBILITY |
5323 |
void param(const param_type& __p) {__p_ = __p;} |
5324 |
|
5325 |
_LIBCPP_INLINE_VISIBILITY |
5326 |
result_type min() const {return 0;} |
5327 |
_LIBCPP_INLINE_VISIBILITY |
5328 |
result_type max() const {return numeric_limits<result_type>::max();} |
5329 |
|
5330 |
friend _LIBCPP_INLINE_VISIBILITY |
5331 |
bool operator==(const geometric_distribution& __x, |
5332 |
const geometric_distribution& __y) |
5333 |
{return __x.__p_ == __y.__p_;} |
5334 |
friend _LIBCPP_INLINE_VISIBILITY |
5335 |
bool operator!=(const geometric_distribution& __x, |
5336 |
const geometric_distribution& __y) |
5337 |
{return !(__x == __y);} |
5338 |
}; |
5339 |
|
5340 |
template <class _CharT, class _Traits, class _IntType> |
5341 |
basic_ostream<_CharT, _Traits>& |
5342 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5343 |
const geometric_distribution<_IntType>& __x) |
5344 |
{ |
5345 |
__save_flags<_CharT, _Traits> __lx(__os); |
5346 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5347 |
ios_base::scientific); |
5348 |
return __os << __x.p(); |
5349 |
} |
5350 |
|
5351 |
template <class _CharT, class _Traits, class _IntType> |
5352 |
basic_istream<_CharT, _Traits>& |
5353 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5354 |
geometric_distribution<_IntType>& __x) |
5355 |
{ |
5356 |
typedef geometric_distribution<_IntType> _Eng; |
5357 |
typedef typename _Eng::param_type param_type; |
5358 |
__save_flags<_CharT, _Traits> __lx(__is); |
5359 |
__is.flags(ios_base::dec | ios_base::skipws); |
5360 |
double __p; |
5361 |
__is >> __p; |
5362 |
if (!__is.fail()) |
5363 |
__x.param(param_type(__p)); |
5364 |
return __is; |
5365 |
} |
5366 |
|
5367 |
// chi_squared_distribution |
5368 |
|
5369 |
template<class _RealType = double> |
5370 |
class _LIBCPP_TYPE_VIS_ONLY chi_squared_distribution |
5371 |
{ |
5372 |
public: |
5373 |
// types |
5374 |
typedef _RealType result_type; |
5375 |
|
5376 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5377 |
{ |
5378 |
result_type __n_; |
5379 |
public: |
5380 |
typedef chi_squared_distribution distribution_type; |
5381 |
|
5382 |
_LIBCPP_INLINE_VISIBILITY |
5383 |
explicit param_type(result_type __n = 1) : __n_(__n) {} |
5384 |
|
5385 |
_LIBCPP_INLINE_VISIBILITY |
5386 |
result_type n() const {return __n_;} |
5387 |
|
5388 |
friend _LIBCPP_INLINE_VISIBILITY |
5389 |
bool operator==(const param_type& __x, const param_type& __y) |
5390 |
{return __x.__n_ == __y.__n_;} |
5391 |
friend _LIBCPP_INLINE_VISIBILITY |
5392 |
bool operator!=(const param_type& __x, const param_type& __y) |
5393 |
{return !(__x == __y);} |
5394 |
}; |
5395 |
|
5396 |
private: |
5397 |
param_type __p_; |
5398 |
|
5399 |
public: |
5400 |
// constructor and reset functions |
5401 |
_LIBCPP_INLINE_VISIBILITY |
5402 |
explicit chi_squared_distribution(result_type __n = 1) |
5403 |
: __p_(param_type(__n)) {} |
5404 |
_LIBCPP_INLINE_VISIBILITY |
5405 |
explicit chi_squared_distribution(const param_type& __p) |
5406 |
: __p_(__p) {} |
5407 |
_LIBCPP_INLINE_VISIBILITY |
5408 |
void reset() {} |
5409 |
|
5410 |
// generating functions |
5411 |
template<class _URNG> |
5412 |
_LIBCPP_INLINE_VISIBILITY |
5413 |
result_type operator()(_URNG& __g) |
5414 |
{return (*this)(__g, __p_);} |
5415 |
template<class _URNG> |
5416 |
_LIBCPP_INLINE_VISIBILITY |
5417 |
result_type operator()(_URNG& __g, const param_type& __p) |
5418 |
{return gamma_distribution<result_type>(__p.n() / 2, 2)(__g);} |
5419 |
|
5420 |
// property functions |
5421 |
_LIBCPP_INLINE_VISIBILITY |
5422 |
result_type n() const {return __p_.n();} |
5423 |
|
5424 |
_LIBCPP_INLINE_VISIBILITY |
5425 |
param_type param() const {return __p_;} |
5426 |
_LIBCPP_INLINE_VISIBILITY |
5427 |
void param(const param_type& __p) {__p_ = __p;} |
5428 |
|
5429 |
_LIBCPP_INLINE_VISIBILITY |
5430 |
result_type min() const {return 0;} |
5431 |
_LIBCPP_INLINE_VISIBILITY |
5432 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
5433 |
|
5434 |
friend _LIBCPP_INLINE_VISIBILITY |
5435 |
bool operator==(const chi_squared_distribution& __x, |
5436 |
const chi_squared_distribution& __y) |
5437 |
{return __x.__p_ == __y.__p_;} |
5438 |
friend _LIBCPP_INLINE_VISIBILITY |
5439 |
bool operator!=(const chi_squared_distribution& __x, |
5440 |
const chi_squared_distribution& __y) |
5441 |
{return !(__x == __y);} |
5442 |
}; |
5443 |
|
5444 |
template <class _CharT, class _Traits, class _RT> |
5445 |
basic_ostream<_CharT, _Traits>& |
5446 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5447 |
const chi_squared_distribution<_RT>& __x) |
5448 |
{ |
5449 |
__save_flags<_CharT, _Traits> __lx(__os); |
5450 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5451 |
ios_base::scientific); |
5452 |
__os << __x.n(); |
5453 |
return __os; |
5454 |
} |
5455 |
|
5456 |
template <class _CharT, class _Traits, class _RT> |
5457 |
basic_istream<_CharT, _Traits>& |
5458 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5459 |
chi_squared_distribution<_RT>& __x) |
5460 |
{ |
5461 |
typedef chi_squared_distribution<_RT> _Eng; |
5462 |
typedef typename _Eng::result_type result_type; |
5463 |
typedef typename _Eng::param_type param_type; |
5464 |
__save_flags<_CharT, _Traits> __lx(__is); |
5465 |
__is.flags(ios_base::dec | ios_base::skipws); |
5466 |
result_type __n; |
5467 |
__is >> __n; |
5468 |
if (!__is.fail()) |
5469 |
__x.param(param_type(__n)); |
5470 |
return __is; |
5471 |
} |
5472 |
|
5473 |
// cauchy_distribution |
5474 |
|
5475 |
template<class _RealType = double> |
5476 |
class _LIBCPP_TYPE_VIS_ONLY cauchy_distribution |
5477 |
{ |
5478 |
public: |
5479 |
// types |
5480 |
typedef _RealType result_type; |
5481 |
|
5482 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5483 |
{ |
5484 |
result_type __a_; |
5485 |
result_type __b_; |
5486 |
public: |
5487 |
typedef cauchy_distribution distribution_type; |
5488 |
|
5489 |
_LIBCPP_INLINE_VISIBILITY |
5490 |
explicit param_type(result_type __a = 0, result_type __b = 1) |
5491 |
: __a_(__a), __b_(__b) {} |
5492 |
|
5493 |
_LIBCPP_INLINE_VISIBILITY |
5494 |
result_type a() const {return __a_;} |
5495 |
_LIBCPP_INLINE_VISIBILITY |
5496 |
result_type b() const {return __b_;} |
5497 |
|
5498 |
friend _LIBCPP_INLINE_VISIBILITY |
5499 |
bool operator==(const param_type& __x, const param_type& __y) |
5500 |
{return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} |
5501 |
friend _LIBCPP_INLINE_VISIBILITY |
5502 |
bool operator!=(const param_type& __x, const param_type& __y) |
5503 |
{return !(__x == __y);} |
5504 |
}; |
5505 |
|
5506 |
private: |
5507 |
param_type __p_; |
5508 |
|
5509 |
public: |
5510 |
// constructor and reset functions |
5511 |
_LIBCPP_INLINE_VISIBILITY |
5512 |
explicit cauchy_distribution(result_type __a = 0, result_type __b = 1) |
5513 |
: __p_(param_type(__a, __b)) {} |
5514 |
_LIBCPP_INLINE_VISIBILITY |
5515 |
explicit cauchy_distribution(const param_type& __p) |
5516 |
: __p_(__p) {} |
5517 |
_LIBCPP_INLINE_VISIBILITY |
5518 |
void reset() {} |
5519 |
|
5520 |
// generating functions |
5521 |
template<class _URNG> |
5522 |
_LIBCPP_INLINE_VISIBILITY |
5523 |
result_type operator()(_URNG& __g) |
5524 |
{return (*this)(__g, __p_);} |
5525 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
5526 |
|
5527 |
// property functions |
5528 |
_LIBCPP_INLINE_VISIBILITY |
5529 |
result_type a() const {return __p_.a();} |
5530 |
_LIBCPP_INLINE_VISIBILITY |
5531 |
result_type b() const {return __p_.b();} |
5532 |
|
5533 |
_LIBCPP_INLINE_VISIBILITY |
5534 |
param_type param() const {return __p_;} |
5535 |
_LIBCPP_INLINE_VISIBILITY |
5536 |
void param(const param_type& __p) {__p_ = __p;} |
5537 |
|
5538 |
_LIBCPP_INLINE_VISIBILITY |
5539 |
result_type min() const {return -numeric_limits<result_type>::infinity();} |
5540 |
_LIBCPP_INLINE_VISIBILITY |
5541 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
5542 |
|
5543 |
friend _LIBCPP_INLINE_VISIBILITY |
5544 |
bool operator==(const cauchy_distribution& __x, |
5545 |
const cauchy_distribution& __y) |
5546 |
{return __x.__p_ == __y.__p_;} |
5547 |
friend _LIBCPP_INLINE_VISIBILITY |
5548 |
bool operator!=(const cauchy_distribution& __x, |
5549 |
const cauchy_distribution& __y) |
5550 |
{return !(__x == __y);} |
5551 |
}; |
5552 |
|
5553 |
template <class _RealType> |
5554 |
template<class _URNG> |
5555 |
inline _LIBCPP_INLINE_VISIBILITY |
5556 |
_RealType |
5557 |
cauchy_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
5558 |
{ |
5559 |
uniform_real_distribution<result_type> __gen; |
5560 |
// purposefully let tan arg get as close to pi/2 as it wants, tan will return a finite |
5561 |
return __p.a() + __p.b() * _VSTD::tan(3.1415926535897932384626433832795 * __gen(__g)); |
5562 |
} |
5563 |
|
5564 |
template <class _CharT, class _Traits, class _RT> |
5565 |
basic_ostream<_CharT, _Traits>& |
5566 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5567 |
const cauchy_distribution<_RT>& __x) |
5568 |
{ |
5569 |
__save_flags<_CharT, _Traits> __lx(__os); |
5570 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5571 |
ios_base::scientific); |
5572 |
_CharT __sp = __os.widen(' '); |
5573 |
__os.fill(__sp); |
5574 |
__os << __x.a() << __sp << __x.b(); |
5575 |
return __os; |
5576 |
} |
5577 |
|
5578 |
template <class _CharT, class _Traits, class _RT> |
5579 |
basic_istream<_CharT, _Traits>& |
5580 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5581 |
cauchy_distribution<_RT>& __x) |
5582 |
{ |
5583 |
typedef cauchy_distribution<_RT> _Eng; |
5584 |
typedef typename _Eng::result_type result_type; |
5585 |
typedef typename _Eng::param_type param_type; |
5586 |
__save_flags<_CharT, _Traits> __lx(__is); |
5587 |
__is.flags(ios_base::dec | ios_base::skipws); |
5588 |
result_type __a; |
5589 |
result_type __b; |
5590 |
__is >> __a >> __b; |
5591 |
if (!__is.fail()) |
5592 |
__x.param(param_type(__a, __b)); |
5593 |
return __is; |
5594 |
} |
5595 |
|
5596 |
// fisher_f_distribution |
5597 |
|
5598 |
template<class _RealType = double> |
5599 |
class _LIBCPP_TYPE_VIS_ONLY fisher_f_distribution |
5600 |
{ |
5601 |
public: |
5602 |
// types |
5603 |
typedef _RealType result_type; |
5604 |
|
5605 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5606 |
{ |
5607 |
result_type __m_; |
5608 |
result_type __n_; |
5609 |
public: |
5610 |
typedef fisher_f_distribution distribution_type; |
5611 |
|
5612 |
_LIBCPP_INLINE_VISIBILITY |
5613 |
explicit param_type(result_type __m = 1, result_type __n = 1) |
5614 |
: __m_(__m), __n_(__n) {} |
5615 |
|
5616 |
_LIBCPP_INLINE_VISIBILITY |
5617 |
result_type m() const {return __m_;} |
5618 |
_LIBCPP_INLINE_VISIBILITY |
5619 |
result_type n() const {return __n_;} |
5620 |
|
5621 |
friend _LIBCPP_INLINE_VISIBILITY |
5622 |
bool operator==(const param_type& __x, const param_type& __y) |
5623 |
{return __x.__m_ == __y.__m_ && __x.__n_ == __y.__n_;} |
5624 |
friend _LIBCPP_INLINE_VISIBILITY |
5625 |
bool operator!=(const param_type& __x, const param_type& __y) |
5626 |
{return !(__x == __y);} |
5627 |
}; |
5628 |
|
5629 |
private: |
5630 |
param_type __p_; |
5631 |
|
5632 |
public: |
5633 |
// constructor and reset functions |
5634 |
_LIBCPP_INLINE_VISIBILITY |
5635 |
explicit fisher_f_distribution(result_type __m = 1, result_type __n = 1) |
5636 |
: __p_(param_type(__m, __n)) {} |
5637 |
_LIBCPP_INLINE_VISIBILITY |
5638 |
explicit fisher_f_distribution(const param_type& __p) |
5639 |
: __p_(__p) {} |
5640 |
_LIBCPP_INLINE_VISIBILITY |
5641 |
void reset() {} |
5642 |
|
5643 |
// generating functions |
5644 |
template<class _URNG> |
5645 |
_LIBCPP_INLINE_VISIBILITY |
5646 |
result_type operator()(_URNG& __g) |
5647 |
{return (*this)(__g, __p_);} |
5648 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
5649 |
|
5650 |
// property functions |
5651 |
_LIBCPP_INLINE_VISIBILITY |
5652 |
result_type m() const {return __p_.m();} |
5653 |
_LIBCPP_INLINE_VISIBILITY |
5654 |
result_type n() const {return __p_.n();} |
5655 |
|
5656 |
_LIBCPP_INLINE_VISIBILITY |
5657 |
param_type param() const {return __p_;} |
5658 |
_LIBCPP_INLINE_VISIBILITY |
5659 |
void param(const param_type& __p) {__p_ = __p;} |
5660 |
|
5661 |
_LIBCPP_INLINE_VISIBILITY |
5662 |
result_type min() const {return 0;} |
5663 |
_LIBCPP_INLINE_VISIBILITY |
5664 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
5665 |
|
5666 |
friend _LIBCPP_INLINE_VISIBILITY |
5667 |
bool operator==(const fisher_f_distribution& __x, |
5668 |
const fisher_f_distribution& __y) |
5669 |
{return __x.__p_ == __y.__p_;} |
5670 |
friend _LIBCPP_INLINE_VISIBILITY |
5671 |
bool operator!=(const fisher_f_distribution& __x, |
5672 |
const fisher_f_distribution& __y) |
5673 |
{return !(__x == __y);} |
5674 |
}; |
5675 |
|
5676 |
template <class _RealType> |
5677 |
template<class _URNG> |
5678 |
_RealType |
5679 |
fisher_f_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
5680 |
{ |
5681 |
gamma_distribution<result_type> __gdm(__p.m() * result_type(.5)); |
5682 |
gamma_distribution<result_type> __gdn(__p.n() * result_type(.5)); |
5683 |
return __p.n() * __gdm(__g) / (__p.m() * __gdn(__g)); |
5684 |
} |
5685 |
|
5686 |
template <class _CharT, class _Traits, class _RT> |
5687 |
basic_ostream<_CharT, _Traits>& |
5688 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5689 |
const fisher_f_distribution<_RT>& __x) |
5690 |
{ |
5691 |
__save_flags<_CharT, _Traits> __lx(__os); |
5692 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5693 |
ios_base::scientific); |
5694 |
_CharT __sp = __os.widen(' '); |
5695 |
__os.fill(__sp); |
5696 |
__os << __x.m() << __sp << __x.n(); |
5697 |
return __os; |
5698 |
} |
5699 |
|
5700 |
template <class _CharT, class _Traits, class _RT> |
5701 |
basic_istream<_CharT, _Traits>& |
5702 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5703 |
fisher_f_distribution<_RT>& __x) |
5704 |
{ |
5705 |
typedef fisher_f_distribution<_RT> _Eng; |
5706 |
typedef typename _Eng::result_type result_type; |
5707 |
typedef typename _Eng::param_type param_type; |
5708 |
__save_flags<_CharT, _Traits> __lx(__is); |
5709 |
__is.flags(ios_base::dec | ios_base::skipws); |
5710 |
result_type __m; |
5711 |
result_type __n; |
5712 |
__is >> __m >> __n; |
5713 |
if (!__is.fail()) |
5714 |
__x.param(param_type(__m, __n)); |
5715 |
return __is; |
5716 |
} |
5717 |
|
5718 |
// student_t_distribution |
5719 |
|
5720 |
template<class _RealType = double> |
5721 |
class _LIBCPP_TYPE_VIS_ONLY student_t_distribution |
5722 |
{ |
5723 |
public: |
5724 |
// types |
5725 |
typedef _RealType result_type; |
5726 |
|
5727 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5728 |
{ |
5729 |
result_type __n_; |
5730 |
public: |
5731 |
typedef student_t_distribution distribution_type; |
5732 |
|
5733 |
_LIBCPP_INLINE_VISIBILITY |
5734 |
explicit param_type(result_type __n = 1) : __n_(__n) {} |
5735 |
|
5736 |
_LIBCPP_INLINE_VISIBILITY |
5737 |
result_type n() const {return __n_;} |
5738 |
|
5739 |
friend _LIBCPP_INLINE_VISIBILITY |
5740 |
bool operator==(const param_type& __x, const param_type& __y) |
5741 |
{return __x.__n_ == __y.__n_;} |
5742 |
friend _LIBCPP_INLINE_VISIBILITY |
5743 |
bool operator!=(const param_type& __x, const param_type& __y) |
5744 |
{return !(__x == __y);} |
5745 |
}; |
5746 |
|
5747 |
private: |
5748 |
param_type __p_; |
5749 |
normal_distribution<result_type> __nd_; |
5750 |
|
5751 |
public: |
5752 |
// constructor and reset functions |
5753 |
_LIBCPP_INLINE_VISIBILITY |
5754 |
explicit student_t_distribution(result_type __n = 1) |
5755 |
: __p_(param_type(__n)) {} |
5756 |
_LIBCPP_INLINE_VISIBILITY |
5757 |
explicit student_t_distribution(const param_type& __p) |
5758 |
: __p_(__p) {} |
5759 |
_LIBCPP_INLINE_VISIBILITY |
5760 |
void reset() {__nd_.reset();} |
5761 |
|
5762 |
// generating functions |
5763 |
template<class _URNG> |
5764 |
_LIBCPP_INLINE_VISIBILITY |
5765 |
result_type operator()(_URNG& __g) |
5766 |
{return (*this)(__g, __p_);} |
5767 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
5768 |
|
5769 |
// property functions |
5770 |
_LIBCPP_INLINE_VISIBILITY |
5771 |
result_type n() const {return __p_.n();} |
5772 |
|
5773 |
_LIBCPP_INLINE_VISIBILITY |
5774 |
param_type param() const {return __p_;} |
5775 |
_LIBCPP_INLINE_VISIBILITY |
5776 |
void param(const param_type& __p) {__p_ = __p;} |
5777 |
|
5778 |
_LIBCPP_INLINE_VISIBILITY |
5779 |
result_type min() const {return -numeric_limits<result_type>::infinity();} |
5780 |
_LIBCPP_INLINE_VISIBILITY |
5781 |
result_type max() const {return numeric_limits<result_type>::infinity();} |
5782 |
|
5783 |
friend _LIBCPP_INLINE_VISIBILITY |
5784 |
bool operator==(const student_t_distribution& __x, |
5785 |
const student_t_distribution& __y) |
5786 |
{return __x.__p_ == __y.__p_;} |
5787 |
friend _LIBCPP_INLINE_VISIBILITY |
5788 |
bool operator!=(const student_t_distribution& __x, |
5789 |
const student_t_distribution& __y) |
5790 |
{return !(__x == __y);} |
5791 |
}; |
5792 |
|
5793 |
template <class _RealType> |
5794 |
template<class _URNG> |
5795 |
_RealType |
5796 |
student_t_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
5797 |
{ |
5798 |
gamma_distribution<result_type> __gd(__p.n() * .5, 2); |
5799 |
return __nd_(__g) * _VSTD::sqrt(__p.n()/__gd(__g)); |
5800 |
} |
5801 |
|
5802 |
template <class _CharT, class _Traits, class _RT> |
5803 |
basic_ostream<_CharT, _Traits>& |
5804 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5805 |
const student_t_distribution<_RT>& __x) |
5806 |
{ |
5807 |
__save_flags<_CharT, _Traits> __lx(__os); |
5808 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
5809 |
ios_base::scientific); |
5810 |
__os << __x.n(); |
5811 |
return __os; |
5812 |
} |
5813 |
|
5814 |
template <class _CharT, class _Traits, class _RT> |
5815 |
basic_istream<_CharT, _Traits>& |
5816 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5817 |
student_t_distribution<_RT>& __x) |
5818 |
{ |
5819 |
typedef student_t_distribution<_RT> _Eng; |
5820 |
typedef typename _Eng::result_type result_type; |
5821 |
typedef typename _Eng::param_type param_type; |
5822 |
__save_flags<_CharT, _Traits> __lx(__is); |
5823 |
__is.flags(ios_base::dec | ios_base::skipws); |
5824 |
result_type __n; |
5825 |
__is >> __n; |
5826 |
if (!__is.fail()) |
5827 |
__x.param(param_type(__n)); |
5828 |
return __is; |
5829 |
} |
5830 |
|
5831 |
// discrete_distribution |
5832 |
|
5833 |
template<class _IntType = int> |
5834 |
class _LIBCPP_TYPE_VIS_ONLY discrete_distribution |
5835 |
{ |
5836 |
public: |
5837 |
// types |
5838 |
typedef _IntType result_type; |
5839 |
|
5840 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
5841 |
{ |
5842 |
vector<double> __p_; |
5843 |
public: |
5844 |
typedef discrete_distribution distribution_type; |
5845 |
|
5846 |
_LIBCPP_INLINE_VISIBILITY |
5847 |
param_type() {} |
5848 |
template<class _InputIterator> |
5849 |
_LIBCPP_INLINE_VISIBILITY |
5850 |
param_type(_InputIterator __f, _InputIterator __l) |
5851 |
: __p_(__f, __l) {__init();} |
5852 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
5853 |
_LIBCPP_INLINE_VISIBILITY |
5854 |
param_type(initializer_list<double> __wl) |
5855 |
: __p_(__wl.begin(), __wl.end()) {__init();} |
5856 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
5857 |
template<class _UnaryOperation> |
5858 |
param_type(size_t __nw, double __xmin, double __xmax, |
5859 |
_UnaryOperation __fw); |
5860 |
|
5861 |
vector<double> probabilities() const; |
5862 |
|
5863 |
friend _LIBCPP_INLINE_VISIBILITY |
5864 |
bool operator==(const param_type& __x, const param_type& __y) |
5865 |
{return __x.__p_ == __y.__p_;} |
5866 |
friend _LIBCPP_INLINE_VISIBILITY |
5867 |
bool operator!=(const param_type& __x, const param_type& __y) |
5868 |
{return !(__x == __y);} |
5869 |
|
5870 |
private: |
5871 |
void __init(); |
5872 |
|
5873 |
friend class discrete_distribution; |
5874 |
|
5875 |
template <class _CharT, class _Traits, class _IT> |
5876 |
friend |
5877 |
basic_ostream<_CharT, _Traits>& |
5878 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5879 |
const discrete_distribution<_IT>& __x); |
5880 |
|
5881 |
template <class _CharT, class _Traits, class _IT> |
5882 |
friend |
5883 |
basic_istream<_CharT, _Traits>& |
5884 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5885 |
discrete_distribution<_IT>& __x); |
5886 |
}; |
5887 |
|
5888 |
private: |
5889 |
param_type __p_; |
5890 |
|
5891 |
public: |
5892 |
// constructor and reset functions |
5893 |
_LIBCPP_INLINE_VISIBILITY |
5894 |
discrete_distribution() {} |
5895 |
template<class _InputIterator> |
5896 |
_LIBCPP_INLINE_VISIBILITY |
5897 |
discrete_distribution(_InputIterator __f, _InputIterator __l) |
5898 |
: __p_(__f, __l) {} |
5899 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
5900 |
_LIBCPP_INLINE_VISIBILITY |
5901 |
discrete_distribution(initializer_list<double> __wl) |
5902 |
: __p_(__wl) {} |
5903 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
5904 |
template<class _UnaryOperation> |
5905 |
_LIBCPP_INLINE_VISIBILITY |
5906 |
discrete_distribution(size_t __nw, double __xmin, double __xmax, |
5907 |
_UnaryOperation __fw) |
5908 |
: __p_(__nw, __xmin, __xmax, __fw) {} |
5909 |
_LIBCPP_INLINE_VISIBILITY |
5910 |
explicit discrete_distribution(const param_type& __p) |
5911 |
: __p_(__p) {} |
5912 |
_LIBCPP_INLINE_VISIBILITY |
5913 |
void reset() {} |
5914 |
|
5915 |
// generating functions |
5916 |
template<class _URNG> |
5917 |
_LIBCPP_INLINE_VISIBILITY |
5918 |
result_type operator()(_URNG& __g) |
5919 |
{return (*this)(__g, __p_);} |
5920 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
5921 |
|
5922 |
// property functions |
5923 |
_LIBCPP_INLINE_VISIBILITY |
5924 |
vector<double> probabilities() const {return __p_.probabilities();} |
5925 |
|
5926 |
_LIBCPP_INLINE_VISIBILITY |
5927 |
param_type param() const {return __p_;} |
5928 |
_LIBCPP_INLINE_VISIBILITY |
5929 |
void param(const param_type& __p) {__p_ = __p;} |
5930 |
|
5931 |
_LIBCPP_INLINE_VISIBILITY |
5932 |
result_type min() const {return 0;} |
5933 |
_LIBCPP_INLINE_VISIBILITY |
5934 |
result_type max() const {return __p_.__p_.size();} |
5935 |
|
5936 |
friend _LIBCPP_INLINE_VISIBILITY |
5937 |
bool operator==(const discrete_distribution& __x, |
5938 |
const discrete_distribution& __y) |
5939 |
{return __x.__p_ == __y.__p_;} |
5940 |
friend _LIBCPP_INLINE_VISIBILITY |
5941 |
bool operator!=(const discrete_distribution& __x, |
5942 |
const discrete_distribution& __y) |
5943 |
{return !(__x == __y);} |
5944 |
|
5945 |
template <class _CharT, class _Traits, class _IT> |
5946 |
friend |
5947 |
basic_ostream<_CharT, _Traits>& |
5948 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
5949 |
const discrete_distribution<_IT>& __x); |
5950 |
|
5951 |
template <class _CharT, class _Traits, class _IT> |
5952 |
friend |
5953 |
basic_istream<_CharT, _Traits>& |
5954 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
5955 |
discrete_distribution<_IT>& __x); |
5956 |
}; |
5957 |
|
5958 |
template<class _IntType> |
5959 |
template<class _UnaryOperation> |
5960 |
discrete_distribution<_IntType>::param_type::param_type(size_t __nw, |
5961 |
double __xmin, |
5962 |
double __xmax, |
5963 |
_UnaryOperation __fw) |
5964 |
{ |
5965 |
if (__nw > 1) |
5966 |
{ |
5967 |
__p_.reserve(__nw - 1); |
5968 |
double __d = (__xmax - __xmin) / __nw; |
5969 |
double __d2 = __d / 2; |
5970 |
for (size_t __k = 0; __k < __nw; ++__k) |
5971 |
__p_.push_back(__fw(__xmin + __k * __d + __d2)); |
5972 |
__init(); |
5973 |
} |
5974 |
} |
5975 |
|
5976 |
template<class _IntType> |
5977 |
void |
5978 |
discrete_distribution<_IntType>::param_type::__init() |
5979 |
{ |
5980 |
if (!__p_.empty()) |
5981 |
{ |
5982 |
if (__p_.size() > 1) |
5983 |
{ |
5984 |
double __s = _VSTD::accumulate(__p_.begin(), __p_.end(), 0.0); |
5985 |
for (_VSTD::vector<double>::iterator __i = __p_.begin(), __e = __p_.end(); |
5986 |
__i < __e; ++__i) |
5987 |
*__i /= __s; |
5988 |
vector<double> __t(__p_.size() - 1); |
5989 |
_VSTD::partial_sum(__p_.begin(), __p_.end() - 1, __t.begin()); |
5990 |
swap(__p_, __t); |
5991 |
} |
5992 |
else |
5993 |
{ |
5994 |
__p_.clear(); |
5995 |
__p_.shrink_to_fit(); |
5996 |
} |
5997 |
} |
5998 |
} |
5999 |
|
6000 |
template<class _IntType> |
6001 |
vector<double> |
6002 |
discrete_distribution<_IntType>::param_type::probabilities() const |
6003 |
{ |
6004 |
size_t __n = __p_.size(); |
6005 |
_VSTD::vector<double> __p(__n+1); |
6006 |
_VSTD::adjacent_difference(__p_.begin(), __p_.end(), __p.begin()); |
6007 |
if (__n > 0) |
6008 |
__p[__n] = 1 - __p_[__n-1]; |
6009 |
else |
6010 |
__p[0] = 1; |
6011 |
return __p; |
6012 |
} |
6013 |
|
6014 |
template<class _IntType> |
6015 |
template<class _URNG> |
6016 |
_IntType |
6017 |
discrete_distribution<_IntType>::operator()(_URNG& __g, const param_type& __p) |
6018 |
{ |
6019 |
uniform_real_distribution<double> __gen; |
6020 |
return static_cast<_IntType>( |
6021 |
_VSTD::upper_bound(__p.__p_.begin(), __p.__p_.end(), __gen(__g)) - |
6022 |
__p.__p_.begin()); |
6023 |
} |
6024 |
|
6025 |
template <class _CharT, class _Traits, class _IT> |
6026 |
basic_ostream<_CharT, _Traits>& |
6027 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6028 |
const discrete_distribution<_IT>& __x) |
6029 |
{ |
6030 |
__save_flags<_CharT, _Traits> __lx(__os); |
6031 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
6032 |
ios_base::scientific); |
6033 |
_CharT __sp = __os.widen(' '); |
6034 |
__os.fill(__sp); |
6035 |
size_t __n = __x.__p_.__p_.size(); |
6036 |
__os << __n; |
6037 |
for (size_t __i = 0; __i < __n; ++__i) |
6038 |
__os << __sp << __x.__p_.__p_[__i]; |
6039 |
return __os; |
6040 |
} |
6041 |
|
6042 |
template <class _CharT, class _Traits, class _IT> |
6043 |
basic_istream<_CharT, _Traits>& |
6044 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6045 |
discrete_distribution<_IT>& __x) |
6046 |
{ |
6047 |
__save_flags<_CharT, _Traits> __lx(__is); |
6048 |
__is.flags(ios_base::dec | ios_base::skipws); |
6049 |
size_t __n; |
6050 |
__is >> __n; |
6051 |
vector<double> __p(__n); |
6052 |
for (size_t __i = 0; __i < __n; ++__i) |
6053 |
__is >> __p[__i]; |
6054 |
if (!__is.fail()) |
6055 |
swap(__x.__p_.__p_, __p); |
6056 |
return __is; |
6057 |
} |
6058 |
|
6059 |
// piecewise_constant_distribution |
6060 |
|
6061 |
template<class _RealType = double> |
6062 |
class _LIBCPP_TYPE_VIS_ONLY piecewise_constant_distribution |
6063 |
{ |
6064 |
public: |
6065 |
// types |
6066 |
typedef _RealType result_type; |
6067 |
|
6068 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
6069 |
{ |
6070 |
vector<result_type> __b_; |
6071 |
vector<result_type> __densities_; |
6072 |
vector<result_type> __areas_; |
6073 |
public: |
6074 |
typedef piecewise_constant_distribution distribution_type; |
6075 |
|
6076 |
param_type(); |
6077 |
template<class _InputIteratorB, class _InputIteratorW> |
6078 |
param_type(_InputIteratorB __fB, _InputIteratorB __lB, |
6079 |
_InputIteratorW __fW); |
6080 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6081 |
template<class _UnaryOperation> |
6082 |
param_type(initializer_list<result_type> __bl, _UnaryOperation __fw); |
6083 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6084 |
template<class _UnaryOperation> |
6085 |
param_type(size_t __nw, result_type __xmin, result_type __xmax, |
6086 |
_UnaryOperation __fw); |
6087 |
param_type & operator=(const param_type& __rhs); |
6088 |
|
6089 |
_LIBCPP_INLINE_VISIBILITY |
6090 |
vector<result_type> intervals() const {return __b_;} |
6091 |
_LIBCPP_INLINE_VISIBILITY |
6092 |
vector<result_type> densities() const {return __densities_;} |
6093 |
|
6094 |
friend _LIBCPP_INLINE_VISIBILITY |
6095 |
bool operator==(const param_type& __x, const param_type& __y) |
6096 |
{return __x.__densities_ == __y.__densities_ && __x.__b_ == __y.__b_;} |
6097 |
friend _LIBCPP_INLINE_VISIBILITY |
6098 |
bool operator!=(const param_type& __x, const param_type& __y) |
6099 |
{return !(__x == __y);} |
6100 |
|
6101 |
private: |
6102 |
void __init(); |
6103 |
|
6104 |
friend class piecewise_constant_distribution; |
6105 |
|
6106 |
template <class _CharT, class _Traits, class _RT> |
6107 |
friend |
6108 |
basic_ostream<_CharT, _Traits>& |
6109 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6110 |
const piecewise_constant_distribution<_RT>& __x); |
6111 |
|
6112 |
template <class _CharT, class _Traits, class _RT> |
6113 |
friend |
6114 |
basic_istream<_CharT, _Traits>& |
6115 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6116 |
piecewise_constant_distribution<_RT>& __x); |
6117 |
}; |
6118 |
|
6119 |
private: |
6120 |
param_type __p_; |
6121 |
|
6122 |
public: |
6123 |
// constructor and reset functions |
6124 |
_LIBCPP_INLINE_VISIBILITY |
6125 |
piecewise_constant_distribution() {} |
6126 |
template<class _InputIteratorB, class _InputIteratorW> |
6127 |
_LIBCPP_INLINE_VISIBILITY |
6128 |
piecewise_constant_distribution(_InputIteratorB __fB, |
6129 |
_InputIteratorB __lB, |
6130 |
_InputIteratorW __fW) |
6131 |
: __p_(__fB, __lB, __fW) {} |
6132 |
|
6133 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6134 |
template<class _UnaryOperation> |
6135 |
_LIBCPP_INLINE_VISIBILITY |
6136 |
piecewise_constant_distribution(initializer_list<result_type> __bl, |
6137 |
_UnaryOperation __fw) |
6138 |
: __p_(__bl, __fw) {} |
6139 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6140 |
|
6141 |
template<class _UnaryOperation> |
6142 |
_LIBCPP_INLINE_VISIBILITY |
6143 |
piecewise_constant_distribution(size_t __nw, result_type __xmin, |
6144 |
result_type __xmax, _UnaryOperation __fw) |
6145 |
: __p_(__nw, __xmin, __xmax, __fw) {} |
6146 |
|
6147 |
_LIBCPP_INLINE_VISIBILITY |
6148 |
explicit piecewise_constant_distribution(const param_type& __p) |
6149 |
: __p_(__p) {} |
6150 |
|
6151 |
_LIBCPP_INLINE_VISIBILITY |
6152 |
void reset() {} |
6153 |
|
6154 |
// generating functions |
6155 |
template<class _URNG> |
6156 |
_LIBCPP_INLINE_VISIBILITY |
6157 |
result_type operator()(_URNG& __g) |
6158 |
{return (*this)(__g, __p_);} |
6159 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
6160 |
|
6161 |
// property functions |
6162 |
_LIBCPP_INLINE_VISIBILITY |
6163 |
vector<result_type> intervals() const {return __p_.intervals();} |
6164 |
_LIBCPP_INLINE_VISIBILITY |
6165 |
vector<result_type> densities() const {return __p_.densities();} |
6166 |
|
6167 |
_LIBCPP_INLINE_VISIBILITY |
6168 |
param_type param() const {return __p_;} |
6169 |
_LIBCPP_INLINE_VISIBILITY |
6170 |
void param(const param_type& __p) {__p_ = __p;} |
6171 |
|
6172 |
_LIBCPP_INLINE_VISIBILITY |
6173 |
result_type min() const {return __p_.__b_.front();} |
6174 |
_LIBCPP_INLINE_VISIBILITY |
6175 |
result_type max() const {return __p_.__b_.back();} |
6176 |
|
6177 |
friend _LIBCPP_INLINE_VISIBILITY |
6178 |
bool operator==(const piecewise_constant_distribution& __x, |
6179 |
const piecewise_constant_distribution& __y) |
6180 |
{return __x.__p_ == __y.__p_;} |
6181 |
friend _LIBCPP_INLINE_VISIBILITY |
6182 |
bool operator!=(const piecewise_constant_distribution& __x, |
6183 |
const piecewise_constant_distribution& __y) |
6184 |
{return !(__x == __y);} |
6185 |
|
6186 |
template <class _CharT, class _Traits, class _RT> |
6187 |
friend |
6188 |
basic_ostream<_CharT, _Traits>& |
6189 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6190 |
const piecewise_constant_distribution<_RT>& __x); |
6191 |
|
6192 |
template <class _CharT, class _Traits, class _RT> |
6193 |
friend |
6194 |
basic_istream<_CharT, _Traits>& |
6195 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6196 |
piecewise_constant_distribution<_RT>& __x); |
6197 |
}; |
6198 |
|
6199 |
template<class _RealType> |
6200 |
typename piecewise_constant_distribution<_RealType>::param_type & |
6201 |
piecewise_constant_distribution<_RealType>::param_type::operator= |
6202 |
(const param_type& __rhs) |
6203 |
{ |
6204 |
// These can throw |
6205 |
__b_.reserve (__rhs.__b_.size ()); |
6206 |
__densities_.reserve(__rhs.__densities_.size()); |
6207 |
__areas_.reserve (__rhs.__areas_.size()); |
6208 |
|
6209 |
// These can not throw |
6210 |
__b_ = __rhs.__b_; |
6211 |
__densities_ = __rhs.__densities_; |
6212 |
__areas_ = __rhs.__areas_; |
6213 |
return *this; |
6214 |
} |
6215 |
|
6216 |
template<class _RealType> |
6217 |
void |
6218 |
piecewise_constant_distribution<_RealType>::param_type::__init() |
6219 |
{ |
6220 |
// __densities_ contains non-normalized areas |
6221 |
result_type __total_area = _VSTD::accumulate(__densities_.begin(), |
6222 |
__densities_.end(), |
6223 |
result_type()); |
6224 |
for (size_t __i = 0; __i < __densities_.size(); ++__i) |
6225 |
__densities_[__i] /= __total_area; |
6226 |
// __densities_ contains normalized areas |
6227 |
__areas_.assign(__densities_.size(), result_type()); |
6228 |
_VSTD::partial_sum(__densities_.begin(), __densities_.end() - 1, |
6229 |
__areas_.begin() + 1); |
6230 |
// __areas_ contains partial sums of normalized areas: [0, __densities_ - 1] |
6231 |
__densities_.back() = 1 - __areas_.back(); // correct round off error |
6232 |
for (size_t __i = 0; __i < __densities_.size(); ++__i) |
6233 |
__densities_[__i] /= (__b_[__i+1] - __b_[__i]); |
6234 |
// __densities_ now contains __densities_ |
6235 |
} |
6236 |
|
6237 |
template<class _RealType> |
6238 |
piecewise_constant_distribution<_RealType>::param_type::param_type() |
6239 |
: __b_(2), |
6240 |
__densities_(1, 1.0), |
6241 |
__areas_(1, 0.0) |
6242 |
{ |
6243 |
__b_[1] = 1; |
6244 |
} |
6245 |
|
6246 |
template<class _RealType> |
6247 |
template<class _InputIteratorB, class _InputIteratorW> |
6248 |
piecewise_constant_distribution<_RealType>::param_type::param_type( |
6249 |
_InputIteratorB __fB, _InputIteratorB __lB, _InputIteratorW __fW) |
6250 |
: __b_(__fB, __lB) |
6251 |
{ |
6252 |
if (__b_.size() < 2) |
6253 |
{ |
6254 |
__b_.resize(2); |
6255 |
__b_[0] = 0; |
6256 |
__b_[1] = 1; |
6257 |
__densities_.assign(1, 1.0); |
6258 |
__areas_.assign(1, 0.0); |
6259 |
} |
6260 |
else |
6261 |
{ |
6262 |
__densities_.reserve(__b_.size() - 1); |
6263 |
for (size_t __i = 0; __i < __b_.size() - 1; ++__i, ++__fW) |
6264 |
__densities_.push_back(*__fW); |
6265 |
__init(); |
6266 |
} |
6267 |
} |
6268 |
|
6269 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6270 |
|
6271 |
template<class _RealType> |
6272 |
template<class _UnaryOperation> |
6273 |
piecewise_constant_distribution<_RealType>::param_type::param_type( |
6274 |
initializer_list<result_type> __bl, _UnaryOperation __fw) |
6275 |
: __b_(__bl.begin(), __bl.end()) |
6276 |
{ |
6277 |
if (__b_.size() < 2) |
6278 |
{ |
6279 |
__b_.resize(2); |
6280 |
__b_[0] = 0; |
6281 |
__b_[1] = 1; |
6282 |
__densities_.assign(1, 1.0); |
6283 |
__areas_.assign(1, 0.0); |
6284 |
} |
6285 |
else |
6286 |
{ |
6287 |
__densities_.reserve(__b_.size() - 1); |
6288 |
for (size_t __i = 0; __i < __b_.size() - 1; ++__i) |
6289 |
__densities_.push_back(__fw((__b_[__i+1] + __b_[__i])*.5)); |
6290 |
__init(); |
6291 |
} |
6292 |
} |
6293 |
|
6294 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6295 |
|
6296 |
template<class _RealType> |
6297 |
template<class _UnaryOperation> |
6298 |
piecewise_constant_distribution<_RealType>::param_type::param_type( |
6299 |
size_t __nw, result_type __xmin, result_type __xmax, _UnaryOperation __fw) |
6300 |
: __b_(__nw == 0 ? 2 : __nw + 1) |
6301 |
{ |
6302 |
size_t __n = __b_.size() - 1; |
6303 |
result_type __d = (__xmax - __xmin) / __n; |
6304 |
__densities_.reserve(__n); |
6305 |
for (size_t __i = 0; __i < __n; ++__i) |
6306 |
{ |
6307 |
__b_[__i] = __xmin + __i * __d; |
6308 |
__densities_.push_back(__fw(__b_[__i] + __d*.5)); |
6309 |
} |
6310 |
__b_[__n] = __xmax; |
6311 |
__init(); |
6312 |
} |
6313 |
|
6314 |
template<class _RealType> |
6315 |
template<class _URNG> |
6316 |
_RealType |
6317 |
piecewise_constant_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
6318 |
{ |
6319 |
typedef uniform_real_distribution<result_type> _Gen; |
6320 |
result_type __u = _Gen()(__g); |
6321 |
ptrdiff_t __k = _VSTD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), |
6322 |
__u) - __p.__areas_.begin() - 1; |
6323 |
return (__u - __p.__areas_[__k]) / __p.__densities_[__k] + __p.__b_[__k]; |
6324 |
} |
6325 |
|
6326 |
template <class _CharT, class _Traits, class _RT> |
6327 |
basic_ostream<_CharT, _Traits>& |
6328 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6329 |
const piecewise_constant_distribution<_RT>& __x) |
6330 |
{ |
6331 |
__save_flags<_CharT, _Traits> __lx(__os); |
6332 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
6333 |
ios_base::scientific); |
6334 |
_CharT __sp = __os.widen(' '); |
6335 |
__os.fill(__sp); |
6336 |
size_t __n = __x.__p_.__b_.size(); |
6337 |
__os << __n; |
6338 |
for (size_t __i = 0; __i < __n; ++__i) |
6339 |
__os << __sp << __x.__p_.__b_[__i]; |
6340 |
__n = __x.__p_.__densities_.size(); |
6341 |
__os << __sp << __n; |
6342 |
for (size_t __i = 0; __i < __n; ++__i) |
6343 |
__os << __sp << __x.__p_.__densities_[__i]; |
6344 |
__n = __x.__p_.__areas_.size(); |
6345 |
__os << __sp << __n; |
6346 |
for (size_t __i = 0; __i < __n; ++__i) |
6347 |
__os << __sp << __x.__p_.__areas_[__i]; |
6348 |
return __os; |
6349 |
} |
6350 |
|
6351 |
template <class _CharT, class _Traits, class _RT> |
6352 |
basic_istream<_CharT, _Traits>& |
6353 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6354 |
piecewise_constant_distribution<_RT>& __x) |
6355 |
{ |
6356 |
typedef piecewise_constant_distribution<_RT> _Eng; |
6357 |
typedef typename _Eng::result_type result_type; |
6358 |
__save_flags<_CharT, _Traits> __lx(__is); |
6359 |
__is.flags(ios_base::dec | ios_base::skipws); |
6360 |
size_t __n; |
6361 |
__is >> __n; |
6362 |
vector<result_type> __b(__n); |
6363 |
for (size_t __i = 0; __i < __n; ++__i) |
6364 |
__is >> __b[__i]; |
6365 |
__is >> __n; |
6366 |
vector<result_type> __densities(__n); |
6367 |
for (size_t __i = 0; __i < __n; ++__i) |
6368 |
__is >> __densities[__i]; |
6369 |
__is >> __n; |
6370 |
vector<result_type> __areas(__n); |
6371 |
for (size_t __i = 0; __i < __n; ++__i) |
6372 |
__is >> __areas[__i]; |
6373 |
if (!__is.fail()) |
6374 |
{ |
6375 |
swap(__x.__p_.__b_, __b); |
6376 |
swap(__x.__p_.__densities_, __densities); |
6377 |
swap(__x.__p_.__areas_, __areas); |
6378 |
} |
6379 |
return __is; |
6380 |
} |
6381 |
|
6382 |
// piecewise_linear_distribution |
6383 |
|
6384 |
template<class _RealType = double> |
6385 |
class _LIBCPP_TYPE_VIS_ONLY piecewise_linear_distribution |
6386 |
{ |
6387 |
public: |
6388 |
// types |
6389 |
typedef _RealType result_type; |
6390 |
|
6391 |
class _LIBCPP_TYPE_VIS_ONLY param_type |
6392 |
{ |
6393 |
vector<result_type> __b_; |
6394 |
vector<result_type> __densities_; |
6395 |
vector<result_type> __areas_; |
6396 |
public: |
6397 |
typedef piecewise_linear_distribution distribution_type; |
6398 |
|
6399 |
param_type(); |
6400 |
template<class _InputIteratorB, class _InputIteratorW> |
6401 |
param_type(_InputIteratorB __fB, _InputIteratorB __lB, |
6402 |
_InputIteratorW __fW); |
6403 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6404 |
template<class _UnaryOperation> |
6405 |
param_type(initializer_list<result_type> __bl, _UnaryOperation __fw); |
6406 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6407 |
template<class _UnaryOperation> |
6408 |
param_type(size_t __nw, result_type __xmin, result_type __xmax, |
6409 |
_UnaryOperation __fw); |
6410 |
param_type & operator=(const param_type& __rhs); |
6411 |
|
6412 |
_LIBCPP_INLINE_VISIBILITY |
6413 |
vector<result_type> intervals() const {return __b_;} |
6414 |
_LIBCPP_INLINE_VISIBILITY |
6415 |
vector<result_type> densities() const {return __densities_;} |
6416 |
|
6417 |
friend _LIBCPP_INLINE_VISIBILITY |
6418 |
bool operator==(const param_type& __x, const param_type& __y) |
6419 |
{return __x.__densities_ == __y.__densities_ && __x.__b_ == __y.__b_;} |
6420 |
friend _LIBCPP_INLINE_VISIBILITY |
6421 |
bool operator!=(const param_type& __x, const param_type& __y) |
6422 |
{return !(__x == __y);} |
6423 |
|
6424 |
private: |
6425 |
void __init(); |
6426 |
|
6427 |
friend class piecewise_linear_distribution; |
6428 |
|
6429 |
template <class _CharT, class _Traits, class _RT> |
6430 |
friend |
6431 |
basic_ostream<_CharT, _Traits>& |
6432 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6433 |
const piecewise_linear_distribution<_RT>& __x); |
6434 |
|
6435 |
template <class _CharT, class _Traits, class _RT> |
6436 |
friend |
6437 |
basic_istream<_CharT, _Traits>& |
6438 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6439 |
piecewise_linear_distribution<_RT>& __x); |
6440 |
}; |
6441 |
|
6442 |
private: |
6443 |
param_type __p_; |
6444 |
|
6445 |
public: |
6446 |
// constructor and reset functions |
6447 |
_LIBCPP_INLINE_VISIBILITY |
6448 |
piecewise_linear_distribution() {} |
6449 |
template<class _InputIteratorB, class _InputIteratorW> |
6450 |
_LIBCPP_INLINE_VISIBILITY |
6451 |
piecewise_linear_distribution(_InputIteratorB __fB, |
6452 |
_InputIteratorB __lB, |
6453 |
_InputIteratorW __fW) |
6454 |
: __p_(__fB, __lB, __fW) {} |
6455 |
|
6456 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6457 |
template<class _UnaryOperation> |
6458 |
_LIBCPP_INLINE_VISIBILITY |
6459 |
piecewise_linear_distribution(initializer_list<result_type> __bl, |
6460 |
_UnaryOperation __fw) |
6461 |
: __p_(__bl, __fw) {} |
6462 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6463 |
|
6464 |
template<class _UnaryOperation> |
6465 |
_LIBCPP_INLINE_VISIBILITY |
6466 |
piecewise_linear_distribution(size_t __nw, result_type __xmin, |
6467 |
result_type __xmax, _UnaryOperation __fw) |
6468 |
: __p_(__nw, __xmin, __xmax, __fw) {} |
6469 |
|
6470 |
_LIBCPP_INLINE_VISIBILITY |
6471 |
explicit piecewise_linear_distribution(const param_type& __p) |
6472 |
: __p_(__p) {} |
6473 |
|
6474 |
_LIBCPP_INLINE_VISIBILITY |
6475 |
void reset() {} |
6476 |
|
6477 |
// generating functions |
6478 |
template<class _URNG> |
6479 |
_LIBCPP_INLINE_VISIBILITY |
6480 |
result_type operator()(_URNG& __g) |
6481 |
{return (*this)(__g, __p_);} |
6482 |
template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); |
6483 |
|
6484 |
// property functions |
6485 |
_LIBCPP_INLINE_VISIBILITY |
6486 |
vector<result_type> intervals() const {return __p_.intervals();} |
6487 |
_LIBCPP_INLINE_VISIBILITY |
6488 |
vector<result_type> densities() const {return __p_.densities();} |
6489 |
|
6490 |
_LIBCPP_INLINE_VISIBILITY |
6491 |
param_type param() const {return __p_;} |
6492 |
_LIBCPP_INLINE_VISIBILITY |
6493 |
void param(const param_type& __p) {__p_ = __p;} |
6494 |
|
6495 |
_LIBCPP_INLINE_VISIBILITY |
6496 |
result_type min() const {return __p_.__b_.front();} |
6497 |
_LIBCPP_INLINE_VISIBILITY |
6498 |
result_type max() const {return __p_.__b_.back();} |
6499 |
|
6500 |
friend _LIBCPP_INLINE_VISIBILITY |
6501 |
bool operator==(const piecewise_linear_distribution& __x, |
6502 |
const piecewise_linear_distribution& __y) |
6503 |
{return __x.__p_ == __y.__p_;} |
6504 |
friend _LIBCPP_INLINE_VISIBILITY |
6505 |
bool operator!=(const piecewise_linear_distribution& __x, |
6506 |
const piecewise_linear_distribution& __y) |
6507 |
{return !(__x == __y);} |
6508 |
|
6509 |
template <class _CharT, class _Traits, class _RT> |
6510 |
friend |
6511 |
basic_ostream<_CharT, _Traits>& |
6512 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6513 |
const piecewise_linear_distribution<_RT>& __x); |
6514 |
|
6515 |
template <class _CharT, class _Traits, class _RT> |
6516 |
friend |
6517 |
basic_istream<_CharT, _Traits>& |
6518 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6519 |
piecewise_linear_distribution<_RT>& __x); |
6520 |
}; |
6521 |
|
6522 |
template<class _RealType> |
6523 |
typename piecewise_linear_distribution<_RealType>::param_type & |
6524 |
piecewise_linear_distribution<_RealType>::param_type::operator= |
6525 |
(const param_type& __rhs) |
6526 |
{ |
6527 |
// These can throw |
6528 |
__b_.reserve (__rhs.__b_.size ()); |
6529 |
__densities_.reserve(__rhs.__densities_.size()); |
6530 |
__areas_.reserve (__rhs.__areas_.size()); |
6531 |
|
6532 |
// These can not throw |
6533 |
__b_ = __rhs.__b_; |
6534 |
__densities_ = __rhs.__densities_; |
6535 |
__areas_ = __rhs.__areas_; |
6536 |
return *this; |
6537 |
} |
6538 |
|
6539 |
|
6540 |
template<class _RealType> |
6541 |
void |
6542 |
piecewise_linear_distribution<_RealType>::param_type::__init() |
6543 |
{ |
6544 |
__areas_.assign(__densities_.size() - 1, result_type()); |
6545 |
result_type _Sp = 0; |
6546 |
for (size_t __i = 0; __i < __areas_.size(); ++__i) |
6547 |
{ |
6548 |
__areas_[__i] = (__densities_[__i+1] + __densities_[__i]) * |
6549 |
(__b_[__i+1] - __b_[__i]) * .5; |
6550 |
_Sp += __areas_[__i]; |
6551 |
} |
6552 |
for (size_t __i = __areas_.size(); __i > 1;) |
6553 |
{ |
6554 |
--__i; |
6555 |
__areas_[__i] = __areas_[__i-1] / _Sp; |
6556 |
} |
6557 |
__areas_[0] = 0; |
6558 |
for (size_t __i = 1; __i < __areas_.size(); ++__i) |
6559 |
__areas_[__i] += __areas_[__i-1]; |
6560 |
for (size_t __i = 0; __i < __densities_.size(); ++__i) |
6561 |
__densities_[__i] /= _Sp; |
6562 |
} |
6563 |
|
6564 |
template<class _RealType> |
6565 |
piecewise_linear_distribution<_RealType>::param_type::param_type() |
6566 |
: __b_(2), |
6567 |
__densities_(2, 1.0), |
6568 |
__areas_(1, 0.0) |
6569 |
{ |
6570 |
__b_[1] = 1; |
6571 |
} |
6572 |
|
6573 |
template<class _RealType> |
6574 |
template<class _InputIteratorB, class _InputIteratorW> |
6575 |
piecewise_linear_distribution<_RealType>::param_type::param_type( |
6576 |
_InputIteratorB __fB, _InputIteratorB __lB, _InputIteratorW __fW) |
6577 |
: __b_(__fB, __lB) |
6578 |
{ |
6579 |
if (__b_.size() < 2) |
6580 |
{ |
6581 |
__b_.resize(2); |
6582 |
__b_[0] = 0; |
6583 |
__b_[1] = 1; |
6584 |
__densities_.assign(2, 1.0); |
6585 |
__areas_.assign(1, 0.0); |
6586 |
} |
6587 |
else |
6588 |
{ |
6589 |
__densities_.reserve(__b_.size()); |
6590 |
for (size_t __i = 0; __i < __b_.size(); ++__i, ++__fW) |
6591 |
__densities_.push_back(*__fW); |
6592 |
__init(); |
6593 |
} |
6594 |
} |
6595 |
|
6596 |
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6597 |
|
6598 |
template<class _RealType> |
6599 |
template<class _UnaryOperation> |
6600 |
piecewise_linear_distribution<_RealType>::param_type::param_type( |
6601 |
initializer_list<result_type> __bl, _UnaryOperation __fw) |
6602 |
: __b_(__bl.begin(), __bl.end()) |
6603 |
{ |
6604 |
if (__b_.size() < 2) |
6605 |
{ |
6606 |
__b_.resize(2); |
6607 |
__b_[0] = 0; |
6608 |
__b_[1] = 1; |
6609 |
__densities_.assign(2, 1.0); |
6610 |
__areas_.assign(1, 0.0); |
6611 |
} |
6612 |
else |
6613 |
{ |
6614 |
__densities_.reserve(__b_.size()); |
6615 |
for (size_t __i = 0; __i < __b_.size(); ++__i) |
6616 |
__densities_.push_back(__fw(__b_[__i])); |
6617 |
__init(); |
6618 |
} |
6619 |
} |
6620 |
|
6621 |
#endif // _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS |
6622 |
|
6623 |
template<class _RealType> |
6624 |
template<class _UnaryOperation> |
6625 |
piecewise_linear_distribution<_RealType>::param_type::param_type( |
6626 |
size_t __nw, result_type __xmin, result_type __xmax, _UnaryOperation __fw) |
6627 |
: __b_(__nw == 0 ? 2 : __nw + 1) |
6628 |
{ |
6629 |
size_t __n = __b_.size() - 1; |
6630 |
result_type __d = (__xmax - __xmin) / __n; |
6631 |
__densities_.reserve(__b_.size()); |
6632 |
for (size_t __i = 0; __i < __n; ++__i) |
6633 |
{ |
6634 |
__b_[__i] = __xmin + __i * __d; |
6635 |
__densities_.push_back(__fw(__b_[__i])); |
6636 |
} |
6637 |
__b_[__n] = __xmax; |
6638 |
__densities_.push_back(__fw(__b_[__n])); |
6639 |
__init(); |
6640 |
} |
6641 |
|
6642 |
template<class _RealType> |
6643 |
template<class _URNG> |
6644 |
_RealType |
6645 |
piecewise_linear_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) |
6646 |
{ |
6647 |
typedef uniform_real_distribution<result_type> _Gen; |
6648 |
result_type __u = _Gen()(__g); |
6649 |
ptrdiff_t __k = _VSTD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), |
6650 |
__u) - __p.__areas_.begin() - 1; |
6651 |
__u -= __p.__areas_[__k]; |
6652 |
const result_type __dk = __p.__densities_[__k]; |
6653 |
const result_type __dk1 = __p.__densities_[__k+1]; |
6654 |
const result_type __deltad = __dk1 - __dk; |
6655 |
const result_type __bk = __p.__b_[__k]; |
6656 |
if (__deltad == 0) |
6657 |
return __u / __dk + __bk; |
6658 |
const result_type __bk1 = __p.__b_[__k+1]; |
6659 |
const result_type __deltab = __bk1 - __bk; |
6660 |
return (__bk * __dk1 - __bk1 * __dk + |
6661 |
_VSTD::sqrt(__deltab * (__deltab * __dk * __dk + 2 * __deltad * __u))) / |
6662 |
__deltad; |
6663 |
} |
6664 |
|
6665 |
template <class _CharT, class _Traits, class _RT> |
6666 |
basic_ostream<_CharT, _Traits>& |
6667 |
operator<<(basic_ostream<_CharT, _Traits>& __os, |
6668 |
const piecewise_linear_distribution<_RT>& __x) |
6669 |
{ |
6670 |
__save_flags<_CharT, _Traits> __lx(__os); |
6671 |
__os.flags(ios_base::dec | ios_base::left | ios_base::fixed | |
6672 |
ios_base::scientific); |
6673 |
_CharT __sp = __os.widen(' '); |
6674 |
__os.fill(__sp); |
6675 |
size_t __n = __x.__p_.__b_.size(); |
6676 |
__os << __n; |
6677 |
for (size_t __i = 0; __i < __n; ++__i) |
6678 |
__os << __sp << __x.__p_.__b_[__i]; |
6679 |
__n = __x.__p_.__densities_.size(); |
6680 |
__os << __sp << __n; |
6681 |
for (size_t __i = 0; __i < __n; ++__i) |
6682 |
__os << __sp << __x.__p_.__densities_[__i]; |
6683 |
__n = __x.__p_.__areas_.size(); |
6684 |
__os << __sp << __n; |
6685 |
for (size_t __i = 0; __i < __n; ++__i) |
6686 |
__os << __sp << __x.__p_.__areas_[__i]; |
6687 |
return __os; |
6688 |
} |
6689 |
|
6690 |
template <class _CharT, class _Traits, class _RT> |
6691 |
basic_istream<_CharT, _Traits>& |
6692 |
operator>>(basic_istream<_CharT, _Traits>& __is, |
6693 |
piecewise_linear_distribution<_RT>& __x) |
6694 |
{ |
6695 |
typedef piecewise_linear_distribution<_RT> _Eng; |
6696 |
typedef typename _Eng::result_type result_type; |
6697 |
__save_flags<_CharT, _Traits> __lx(__is); |
6698 |
__is.flags(ios_base::dec | ios_base::skipws); |
6699 |
size_t __n; |
6700 |
__is >> __n; |
6701 |
vector<result_type> __b(__n); |
6702 |
for (size_t __i = 0; __i < __n; ++__i) |
6703 |
__is >> __b[__i]; |
6704 |
__is >> __n; |
6705 |
vector<result_type> __densities(__n); |
6706 |
for (size_t __i = 0; __i < __n; ++__i) |
6707 |
__is >> __densities[__i]; |
6708 |
__is >> __n; |
6709 |
vector<result_type> __areas(__n); |
6710 |
for (size_t __i = 0; __i < __n; ++__i) |
6711 |
__is >> __areas[__i]; |
6712 |
if (!__is.fail()) |
6713 |
{ |
6714 |
swap(__x.__p_.__b_, __b); |
6715 |
swap(__x.__p_.__densities_, __densities); |
6716 |
swap(__x.__p_.__areas_, __areas); |
6717 |
} |
6718 |
return __is; |
6719 |
} |
6720 |
|
6721 |
_LIBCPP_END_NAMESPACE_STD |
6722 |
|
6723 |
#endif // _LIBCPP_RANDOM |