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 #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 1650 #pragma GCC system_header 1651 #endif 1652 1653 _LIBCPP_PUSH_MACROS 1654 #include <__undef_macros> 1655 1656 1657 _LIBCPP_BEGIN_NAMESPACE_STD 1658 1659 // __is_seed_sequence 1660 1661 template <class _Sseq, class _Engine> 1662 struct __is_seed_sequence 1663 { 1664 static _LIBCPP_CONSTEXPR const bool value = 1665 !is_convertible<_Sseq, typename _Engine::result_type>::value && 1666 !is_same<typename remove_cv<_Sseq>::type, _Engine>::value; 1667 }; 1668 1669 // linear_congruential_engine 1670 1671 template <unsigned long long __a, unsigned long long __c, 1672 unsigned long long __m, unsigned long long _Mp, 1673 bool _MightOverflow = (__a != 0 && __m != 0 && __m-1 > (_Mp-__c)/__a)> 1674 struct __lce_ta; 1675 1676 // 64 1677 1678 template <unsigned long long __a, unsigned long long __c, unsigned long long __m> 1679 struct __lce_ta<__a, __c, __m, (unsigned long long)(~0), true> 1680 { 1681 typedef unsigned long long result_type; 1682 _LIBCPP_INLINE_VISIBILITY 1683 static result_type next(result_type __x) 1684 { 1685 // Schrage's algorithm 1686 const result_type __q = __m / __a; 1687 const result_type __r = __m % __a; 1688 const result_type __t0 = __a * (__x % __q); 1689 const result_type __t1 = __r * (__x / __q); 1690 __x = __t0 + (__t0 < __t1) * __m - __t1; 1691 __x += __c - (__x >= __m - __c) * __m; 1692 return __x; 1693 } 1694 }; 1695 1696 template <unsigned long long __a, unsigned long long __m> 1697 struct __lce_ta<__a, 0, __m, (unsigned long long)(~0), true> 1698 { 1699 typedef unsigned long long result_type; 1700 _LIBCPP_INLINE_VISIBILITY 1701 static result_type next(result_type __x) 1702 { 1703 // Schrage's algorithm 1704 const result_type __q = __m / __a; 1705 const result_type __r = __m % __a; 1706 const result_type __t0 = __a * (__x % __q); 1707 const result_type __t1 = __r * (__x / __q); 1708 __x = __t0 + (__t0 < __t1) * __m - __t1; 1709 return __x; 1710 } 1711 }; 1712 1713 template <unsigned long long __a, unsigned long long __c, unsigned long long __m> 1714 struct __lce_ta<__a, __c, __m, (unsigned long long)(~0), false> 1715 { 1716 typedef unsigned long long result_type; 1717 _LIBCPP_INLINE_VISIBILITY 1718 static result_type next(result_type __x) 1719 { 1720 return (__a * __x + __c) % __m; 1721 } 1722 }; 1723 1724 template <unsigned long long __a, unsigned long long __c> 1725 struct __lce_ta<__a, __c, 0, (unsigned long long)(~0), false> 1726 { 1727 typedef unsigned long long result_type; 1728 _LIBCPP_INLINE_VISIBILITY 1729 static result_type next(result_type __x) 1730 { 1731 return __a * __x + __c; 1732 } 1733 }; 1734 1735 // 32 1736 1737 template <unsigned long long _Ap, unsigned long long _Cp, unsigned long long _Mp> 1738 struct __lce_ta<_Ap, _Cp, _Mp, unsigned(~0), true> 1739 { 1740 typedef unsigned result_type; 1741 _LIBCPP_INLINE_VISIBILITY 1742 static result_type next(result_type __x) 1743 { 1744 const result_type __a = static_cast<result_type>(_Ap); 1745 const result_type __c = static_cast<result_type>(_Cp); 1746 const result_type __m = static_cast<result_type>(_Mp); 1747 // Schrage's algorithm 1748 const result_type __q = __m / __a; 1749 const result_type __r = __m % __a; 1750 const result_type __t0 = __a * (__x % __q); 1751 const result_type __t1 = __r * (__x / __q); 1752 __x = __t0 + (__t0 < __t1) * __m - __t1; 1753 __x += __c - (__x >= __m - __c) * __m; 1754 return __x; 1755 } 1756 }; 1757 1758 template <unsigned long long _Ap, unsigned long long _Mp> 1759 struct __lce_ta<_Ap, 0, _Mp, unsigned(~0), true> 1760 { 1761 typedef unsigned result_type; 1762 _LIBCPP_INLINE_VISIBILITY 1763 static result_type next(result_type __x) 1764 { 1765 const result_type __a = static_cast<result_type>(_Ap); 1766 const result_type __m = static_cast<result_type>(_Mp); 1767 // Schrage's algorithm 1768 const result_type __q = __m / __a; 1769 const result_type __r = __m % __a; 1770 const result_type __t0 = __a * (__x % __q); 1771 const result_type __t1 = __r * (__x / __q); 1772 __x = __t0 + (__t0 < __t1) * __m - __t1; 1773 return __x; 1774 } 1775 }; 1776 1777 template <unsigned long long _Ap, unsigned long long _Cp, unsigned long long _Mp> 1778 struct __lce_ta<_Ap, _Cp, _Mp, unsigned(~0), false> 1779 { 1780 typedef unsigned result_type; 1781 _LIBCPP_INLINE_VISIBILITY 1782 static result_type next(result_type __x) 1783 { 1784 const result_type __a = static_cast<result_type>(_Ap); 1785 const result_type __c = static_cast<result_type>(_Cp); 1786 const result_type __m = static_cast<result_type>(_Mp); 1787 return (__a * __x + __c) % __m; 1788 } 1789 }; 1790 1791 template <unsigned long long _Ap, unsigned long long _Cp> 1792 struct __lce_ta<_Ap, _Cp, 0, unsigned(~0), false> 1793 { 1794 typedef unsigned result_type; 1795 _LIBCPP_INLINE_VISIBILITY 1796 static result_type next(result_type __x) 1797 { 1798 const result_type __a = static_cast<result_type>(_Ap); 1799 const result_type __c = static_cast<result_type>(_Cp); 1800 return __a * __x + __c; 1801 } 1802 }; 1803 1804 // 16 1805 1806 template <unsigned long long __a, unsigned long long __c, unsigned long long __m, bool __b> 1807 struct __lce_ta<__a, __c, __m, (unsigned short)(~0), __b> 1808 { 1809 typedef unsigned short result_type; 1810 _LIBCPP_INLINE_VISIBILITY 1811 static result_type next(result_type __x) 1812 { 1813 return static_cast<result_type>(__lce_ta<__a, __c, __m, unsigned(~0)>::next(__x)); 1814 } 1815 }; 1816 1817 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1818 class _LIBCPP_TEMPLATE_VIS linear_congruential_engine; 1819 1820 template <class _CharT, class _Traits, 1821 class _Up, _Up _Ap, _Up _Cp, _Up _Np> 1822 _LIBCPP_INLINE_VISIBILITY 1823 basic_ostream<_CharT, _Traits>& 1824 operator<<(basic_ostream<_CharT, _Traits>& __os, 1825 const linear_congruential_engine<_Up, _Ap, _Cp, _Np>&); 1826 1827 template <class _CharT, class _Traits, 1828 class _Up, _Up _Ap, _Up _Cp, _Up _Np> 1829 basic_istream<_CharT, _Traits>& 1830 operator>>(basic_istream<_CharT, _Traits>& __is, 1831 linear_congruential_engine<_Up, _Ap, _Cp, _Np>& __x); 1832 1833 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1834 class _LIBCPP_TEMPLATE_VIS linear_congruential_engine 1835 { 1836 public: 1837 // types 1838 typedef _UIntType result_type; 1839 1840 private: 1841 result_type __x_; 1842 1843 static _LIBCPP_CONSTEXPR const result_type _Mp = result_type(~0); 1844 1845 static_assert(__m == 0 || __a < __m, "linear_congruential_engine invalid parameters"); 1846 static_assert(__m == 0 || __c < __m, "linear_congruential_engine invalid parameters"); 1847 public: 1848 static _LIBCPP_CONSTEXPR const result_type _Min = __c == 0u ? 1u: 0u; 1849 static _LIBCPP_CONSTEXPR const result_type _Max = __m - 1u; 1850 static_assert(_Min < _Max, "linear_congruential_engine invalid parameters"); 1851 1852 // engine characteristics 1853 static _LIBCPP_CONSTEXPR const result_type multiplier = __a; 1854 static _LIBCPP_CONSTEXPR const result_type increment = __c; 1855 static _LIBCPP_CONSTEXPR const result_type modulus = __m; 1856 _LIBCPP_INLINE_VISIBILITY 1857 static _LIBCPP_CONSTEXPR result_type min() {return _Min;} 1858 _LIBCPP_INLINE_VISIBILITY 1859 static _LIBCPP_CONSTEXPR result_type max() {return _Max;} 1860 static _LIBCPP_CONSTEXPR const result_type default_seed = 1u; 1861 1862 // constructors and seeding functions 1863 _LIBCPP_INLINE_VISIBILITY 1864 explicit linear_congruential_engine(result_type __s = default_seed) 1865 {seed(__s);} 1866 template<class _Sseq> 1867 _LIBCPP_INLINE_VISIBILITY 1868 explicit linear_congruential_engine(_Sseq& __q, 1869 typename enable_if<__is_seed_sequence<_Sseq, linear_congruential_engine>::value>::type* = 0) 1870 {seed(__q);} 1871 _LIBCPP_INLINE_VISIBILITY 1872 void seed(result_type __s = default_seed) 1873 {seed(integral_constant<bool, __m == 0>(), 1874 integral_constant<bool, __c == 0>(), __s);} 1875 template<class _Sseq> 1876 _LIBCPP_INLINE_VISIBILITY 1877 typename enable_if 1878 < 1879 __is_seed_sequence<_Sseq, linear_congruential_engine>::value, 1880 void 1881 >::type 1882 seed(_Sseq& __q) 1883 {__seed(__q, integral_constant<unsigned, 1884 1 + (__m == 0 ? (sizeof(result_type) * __CHAR_BIT__ - 1)/32 1885 : (__m > 0x100000000ull))>());} 1886 1887 // generating functions 1888 _LIBCPP_INLINE_VISIBILITY 1889 result_type operator()() 1890 {return __x_ = static_cast<result_type>(__lce_ta<__a, __c, __m, _Mp>::next(__x_));} 1891 _LIBCPP_INLINE_VISIBILITY 1892 void discard(unsigned long long __z) {for (; __z; --__z) operator()();} 1893 1894 friend _LIBCPP_INLINE_VISIBILITY 1895 bool operator==(const linear_congruential_engine& __x, 1896 const linear_congruential_engine& __y) 1897 {return __x.__x_ == __y.__x_;} 1898 friend _LIBCPP_INLINE_VISIBILITY 1899 bool operator!=(const linear_congruential_engine& __x, 1900 const linear_congruential_engine& __y) 1901 {return !(__x == __y);} 1902 1903 private: 1904 1905 _LIBCPP_INLINE_VISIBILITY 1906 void seed(true_type, true_type, result_type __s) {__x_ = __s == 0 ? 1 : __s;} 1907 _LIBCPP_INLINE_VISIBILITY 1908 void seed(true_type, false_type, result_type __s) {__x_ = __s;} 1909 _LIBCPP_INLINE_VISIBILITY 1910 void seed(false_type, true_type, result_type __s) {__x_ = __s % __m == 0 ? 1911 1 : __s % __m;} 1912 _LIBCPP_INLINE_VISIBILITY 1913 void seed(false_type, false_type, result_type __s) {__x_ = __s % __m;} 1914 1915 template<class _Sseq> 1916 void __seed(_Sseq& __q, integral_constant<unsigned, 1>); 1917 template<class _Sseq> 1918 void __seed(_Sseq& __q, integral_constant<unsigned, 2>); 1919 1920 template <class _CharT, class _Traits, 1921 class _Up, _Up _Ap, _Up _Cp, _Up _Np> 1922 friend 1923 basic_ostream<_CharT, _Traits>& 1924 operator<<(basic_ostream<_CharT, _Traits>& __os, 1925 const linear_congruential_engine<_Up, _Ap, _Cp, _Np>&); 1926 1927 template <class _CharT, class _Traits, 1928 class _Up, _Up _Ap, _Up _Cp, _Up _Np> 1929 friend 1930 basic_istream<_CharT, _Traits>& 1931 operator>>(basic_istream<_CharT, _Traits>& __is, 1932 linear_congruential_engine<_Up, _Ap, _Cp, _Np>& __x); 1933 }; 1934 1935 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1936 _LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type 1937 linear_congruential_engine<_UIntType, __a, __c, __m>::multiplier; 1938 1939 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1940 _LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type 1941 linear_congruential_engine<_UIntType, __a, __c, __m>::increment; 1942 1943 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1944 _LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type 1945 linear_congruential_engine<_UIntType, __a, __c, __m>::modulus; 1946 1947 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1948 _LIBCPP_CONSTEXPR const typename linear_congruential_engine<_UIntType, __a, __c, __m>::result_type 1949 linear_congruential_engine<_UIntType, __a, __c, __m>::default_seed; 1950 1951 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1952 template<class _Sseq> 1953 void 1954 linear_congruential_engine<_UIntType, __a, __c, __m>::__seed(_Sseq& __q, 1955 integral_constant<unsigned, 1>) 1956 { 1957 const unsigned __k = 1; 1958 uint32_t __ar[__k+3]; 1959 __q.generate(__ar, __ar + __k + 3); 1960 result_type __s = static_cast<result_type>(__ar[3] % __m); 1961 __x_ = __c == 0 && __s == 0 ? result_type(1) : __s; 1962 } 1963 1964 template <class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1965 template<class _Sseq> 1966 void 1967 linear_congruential_engine<_UIntType, __a, __c, __m>::__seed(_Sseq& __q, 1968 integral_constant<unsigned, 2>) 1969 { 1970 const unsigned __k = 2; 1971 uint32_t __ar[__k+3]; 1972 __q.generate(__ar, __ar + __k + 3); 1973 result_type __s = static_cast<result_type>((__ar[3] + 1974 ((uint64_t)__ar[4] << 32)) % __m); 1975 __x_ = __c == 0 && __s == 0 ? result_type(1) : __s; 1976 } 1977 1978 template <class _CharT, class _Traits, 1979 class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1980 inline _LIBCPP_INLINE_VISIBILITY 1981 basic_ostream<_CharT, _Traits>& 1982 operator<<(basic_ostream<_CharT, _Traits>& __os, 1983 const linear_congruential_engine<_UIntType, __a, __c, __m>& __x) 1984 { 1985 __save_flags<_CharT, _Traits> __lx(__os); 1986 __os.flags(ios_base::dec | ios_base::left); 1987 __os.fill(__os.widen(' ')); 1988 return __os << __x.__x_; 1989 } 1990 1991 template <class _CharT, class _Traits, 1992 class _UIntType, _UIntType __a, _UIntType __c, _UIntType __m> 1993 basic_istream<_CharT, _Traits>& 1994 operator>>(basic_istream<_CharT, _Traits>& __is, 1995 linear_congruential_engine<_UIntType, __a, __c, __m>& __x) 1996 { 1997 __save_flags<_CharT, _Traits> __lx(__is); 1998 __is.flags(ios_base::dec | ios_base::skipws); 1999 _UIntType __t; 2000 __is >> __t; 2001 if (!__is.fail()) 2002 __x.__x_ = __t; 2003 return __is; 2004 } 2005 2006 typedef linear_congruential_engine<uint_fast32_t, 16807, 0, 2147483647> 2007 minstd_rand0; 2008 typedef linear_congruential_engine<uint_fast32_t, 48271, 0, 2147483647> 2009 minstd_rand; 2010 typedef minstd_rand default_random_engine; 2011 // mersenne_twister_engine 2012 2013 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2014 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2015 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2016 class _LIBCPP_TEMPLATE_VIS mersenne_twister_engine; 2017 2018 template <class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2019 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2020 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2021 bool 2022 operator==(const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2023 _Bp, _Tp, _Cp, _Lp, _Fp>& __x, 2024 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2025 _Bp, _Tp, _Cp, _Lp, _Fp>& __y); 2026 2027 template <class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2028 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2029 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2030 _LIBCPP_INLINE_VISIBILITY 2031 bool 2032 operator!=(const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2033 _Bp, _Tp, _Cp, _Lp, _Fp>& __x, 2034 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2035 _Bp, _Tp, _Cp, _Lp, _Fp>& __y); 2036 2037 template <class _CharT, class _Traits, 2038 class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2039 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2040 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2041 basic_ostream<_CharT, _Traits>& 2042 operator<<(basic_ostream<_CharT, _Traits>& __os, 2043 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2044 _Bp, _Tp, _Cp, _Lp, _Fp>& __x); 2045 2046 template <class _CharT, class _Traits, 2047 class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2048 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2049 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2050 basic_istream<_CharT, _Traits>& 2051 operator>>(basic_istream<_CharT, _Traits>& __is, 2052 mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2053 _Bp, _Tp, _Cp, _Lp, _Fp>& __x); 2054 2055 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2056 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2057 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2058 class _LIBCPP_TEMPLATE_VIS mersenne_twister_engine 2059 { 2060 public: 2061 // types 2062 typedef _UIntType result_type; 2063 2064 private: 2065 result_type __x_[__n]; 2066 size_t __i_; 2067 2068 static_assert( 0 < __m, "mersenne_twister_engine invalid parameters"); 2069 static_assert(__m <= __n, "mersenne_twister_engine invalid parameters"); 2070 static _LIBCPP_CONSTEXPR const result_type _Dt = numeric_limits<result_type>::digits; 2071 static_assert(__w <= _Dt, "mersenne_twister_engine invalid parameters"); 2072 static_assert( 2 <= __w, "mersenne_twister_engine invalid parameters"); 2073 static_assert(__r <= __w, "mersenne_twister_engine invalid parameters"); 2074 static_assert(__u <= __w, "mersenne_twister_engine invalid parameters"); 2075 static_assert(__s <= __w, "mersenne_twister_engine invalid parameters"); 2076 static_assert(__t <= __w, "mersenne_twister_engine invalid parameters"); 2077 static_assert(__l <= __w, "mersenne_twister_engine invalid parameters"); 2078 public: 2079 static _LIBCPP_CONSTEXPR const result_type _Min = 0; 2080 static _LIBCPP_CONSTEXPR const result_type _Max = __w == _Dt ? result_type(~0) : 2081 (result_type(1) << __w) - result_type(1); 2082 static_assert(_Min < _Max, "mersenne_twister_engine invalid parameters"); 2083 static_assert(__a <= _Max, "mersenne_twister_engine invalid parameters"); 2084 static_assert(__b <= _Max, "mersenne_twister_engine invalid parameters"); 2085 static_assert(__c <= _Max, "mersenne_twister_engine invalid parameters"); 2086 static_assert(__d <= _Max, "mersenne_twister_engine invalid parameters"); 2087 static_assert(__f <= _Max, "mersenne_twister_engine invalid parameters"); 2088 2089 // engine characteristics 2090 static _LIBCPP_CONSTEXPR const size_t word_size = __w; 2091 static _LIBCPP_CONSTEXPR const size_t state_size = __n; 2092 static _LIBCPP_CONSTEXPR const size_t shift_size = __m; 2093 static _LIBCPP_CONSTEXPR const size_t mask_bits = __r; 2094 static _LIBCPP_CONSTEXPR const result_type xor_mask = __a; 2095 static _LIBCPP_CONSTEXPR const size_t tempering_u = __u; 2096 static _LIBCPP_CONSTEXPR const result_type tempering_d = __d; 2097 static _LIBCPP_CONSTEXPR const size_t tempering_s = __s; 2098 static _LIBCPP_CONSTEXPR const result_type tempering_b = __b; 2099 static _LIBCPP_CONSTEXPR const size_t tempering_t = __t; 2100 static _LIBCPP_CONSTEXPR const result_type tempering_c = __c; 2101 static _LIBCPP_CONSTEXPR const size_t tempering_l = __l; 2102 static _LIBCPP_CONSTEXPR const result_type initialization_multiplier = __f; 2103 _LIBCPP_INLINE_VISIBILITY 2104 static _LIBCPP_CONSTEXPR result_type min() { return _Min; } 2105 _LIBCPP_INLINE_VISIBILITY 2106 static _LIBCPP_CONSTEXPR result_type max() { return _Max; } 2107 static _LIBCPP_CONSTEXPR const result_type default_seed = 5489u; 2108 2109 // constructors and seeding functions 2110 _LIBCPP_INLINE_VISIBILITY 2111 explicit mersenne_twister_engine(result_type __sd = default_seed) 2112 {seed(__sd);} 2113 template<class _Sseq> 2114 _LIBCPP_INLINE_VISIBILITY 2115 explicit mersenne_twister_engine(_Sseq& __q, 2116 typename enable_if<__is_seed_sequence<_Sseq, mersenne_twister_engine>::value>::type* = 0) 2117 {seed(__q);} 2118 void seed(result_type __sd = default_seed); 2119 template<class _Sseq> 2120 _LIBCPP_INLINE_VISIBILITY 2121 typename enable_if 2122 < 2123 __is_seed_sequence<_Sseq, mersenne_twister_engine>::value, 2124 void 2125 >::type 2126 seed(_Sseq& __q) 2127 {__seed(__q, integral_constant<unsigned, 1 + (__w - 1) / 32>());} 2128 2129 // generating functions 2130 result_type operator()(); 2131 _LIBCPP_INLINE_VISIBILITY 2132 void discard(unsigned long long __z) {for (; __z; --__z) operator()();} 2133 2134 template <class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2135 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2136 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2137 friend 2138 bool 2139 operator==(const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2140 _Bp, _Tp, _Cp, _Lp, _Fp>& __x, 2141 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2142 _Bp, _Tp, _Cp, _Lp, _Fp>& __y); 2143 2144 template <class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2145 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2146 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2147 friend 2148 bool 2149 operator!=(const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2150 _Bp, _Tp, _Cp, _Lp, _Fp>& __x, 2151 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2152 _Bp, _Tp, _Cp, _Lp, _Fp>& __y); 2153 2154 template <class _CharT, class _Traits, 2155 class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2156 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2157 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2158 friend 2159 basic_ostream<_CharT, _Traits>& 2160 operator<<(basic_ostream<_CharT, _Traits>& __os, 2161 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2162 _Bp, _Tp, _Cp, _Lp, _Fp>& __x); 2163 2164 template <class _CharT, class _Traits, 2165 class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2166 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2167 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2168 friend 2169 basic_istream<_CharT, _Traits>& 2170 operator>>(basic_istream<_CharT, _Traits>& __is, 2171 mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2172 _Bp, _Tp, _Cp, _Lp, _Fp>& __x); 2173 private: 2174 2175 template<class _Sseq> 2176 void __seed(_Sseq& __q, integral_constant<unsigned, 1>); 2177 template<class _Sseq> 2178 void __seed(_Sseq& __q, integral_constant<unsigned, 2>); 2179 2180 template <size_t __count> 2181 _LIBCPP_INLINE_VISIBILITY 2182 static 2183 typename enable_if 2184 < 2185 __count < __w, 2186 result_type 2187 >::type 2188 __lshift(result_type __x) {return (__x << __count) & _Max;} 2189 2190 template <size_t __count> 2191 _LIBCPP_INLINE_VISIBILITY 2192 static 2193 typename enable_if 2194 < 2195 (__count >= __w), 2196 result_type 2197 >::type 2198 __lshift(result_type) {return result_type(0);} 2199 2200 template <size_t __count> 2201 _LIBCPP_INLINE_VISIBILITY 2202 static 2203 typename enable_if 2204 < 2205 __count < _Dt, 2206 result_type 2207 >::type 2208 __rshift(result_type __x) {return __x >> __count;} 2209 2210 template <size_t __count> 2211 _LIBCPP_INLINE_VISIBILITY 2212 static 2213 typename enable_if 2214 < 2215 (__count >= _Dt), 2216 result_type 2217 >::type 2218 __rshift(result_type) {return result_type(0);} 2219 }; 2220 2221 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2222 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2223 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2224 _LIBCPP_CONSTEXPR const size_t 2225 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::word_size; 2226 2227 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2228 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2229 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2230 _LIBCPP_CONSTEXPR const size_t 2231 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::state_size; 2232 2233 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2234 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2235 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2236 _LIBCPP_CONSTEXPR const size_t 2237 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::shift_size; 2238 2239 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2240 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2241 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2242 _LIBCPP_CONSTEXPR const size_t 2243 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::mask_bits; 2244 2245 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2246 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2247 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2248 _LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type 2249 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::xor_mask; 2250 2251 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2252 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2253 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2254 _LIBCPP_CONSTEXPR const size_t 2255 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_u; 2256 2257 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2258 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2259 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2260 _LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type 2261 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_d; 2262 2263 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2264 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2265 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2266 _LIBCPP_CONSTEXPR const size_t 2267 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_s; 2268 2269 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2270 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2271 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2272 _LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type 2273 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_b; 2274 2275 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2276 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2277 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2278 _LIBCPP_CONSTEXPR const size_t 2279 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_t; 2280 2281 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2282 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2283 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2284 _LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type 2285 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_c; 2286 2287 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2288 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2289 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2290 _LIBCPP_CONSTEXPR const size_t 2291 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::tempering_l; 2292 2293 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2294 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2295 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2296 _LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type 2297 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::initialization_multiplier; 2298 2299 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2300 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2301 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2302 _LIBCPP_CONSTEXPR const typename mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::result_type 2303 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, __t, __c, __l, __f>::default_seed; 2304 2305 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2306 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2307 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2308 void 2309 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, 2310 __t, __c, __l, __f>::seed(result_type __sd) 2311 _LIBCPP_DISABLE_UBSAN_UNSIGNED_INTEGER_CHECK 2312 { // __w >= 2 2313 __x_[0] = __sd & _Max; 2314 for (size_t __i = 1; __i < __n; ++__i) 2315 __x_[__i] = (__f * (__x_[__i-1] ^ __rshift<__w - 2>(__x_[__i-1])) + __i) & _Max; 2316 __i_ = 0; 2317 } 2318 2319 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2320 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2321 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2322 template<class _Sseq> 2323 void 2324 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, 2325 __t, __c, __l, __f>::__seed(_Sseq& __q, integral_constant<unsigned, 1>) 2326 { 2327 const unsigned __k = 1; 2328 uint32_t __ar[__n * __k]; 2329 __q.generate(__ar, __ar + __n * __k); 2330 for (size_t __i = 0; __i < __n; ++__i) 2331 __x_[__i] = static_cast<result_type>(__ar[__i] & _Max); 2332 const result_type __mask = __r == _Dt ? result_type(~0) : 2333 (result_type(1) << __r) - result_type(1); 2334 __i_ = 0; 2335 if ((__x_[0] & ~__mask) == 0) 2336 { 2337 for (size_t __i = 1; __i < __n; ++__i) 2338 if (__x_[__i] != 0) 2339 return; 2340 __x_[0] = result_type(1) << (__w - 1); 2341 } 2342 } 2343 2344 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2345 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2346 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2347 template<class _Sseq> 2348 void 2349 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, 2350 __t, __c, __l, __f>::__seed(_Sseq& __q, integral_constant<unsigned, 2>) 2351 { 2352 const unsigned __k = 2; 2353 uint32_t __ar[__n * __k]; 2354 __q.generate(__ar, __ar + __n * __k); 2355 for (size_t __i = 0; __i < __n; ++__i) 2356 __x_[__i] = static_cast<result_type>( 2357 (__ar[2 * __i] + ((uint64_t)__ar[2 * __i + 1] << 32)) & _Max); 2358 const result_type __mask = __r == _Dt ? result_type(~0) : 2359 (result_type(1) << __r) - result_type(1); 2360 __i_ = 0; 2361 if ((__x_[0] & ~__mask) == 0) 2362 { 2363 for (size_t __i = 1; __i < __n; ++__i) 2364 if (__x_[__i] != 0) 2365 return; 2366 __x_[0] = result_type(1) << (__w - 1); 2367 } 2368 } 2369 2370 template <class _UIntType, size_t __w, size_t __n, size_t __m, size_t __r, 2371 _UIntType __a, size_t __u, _UIntType __d, size_t __s, 2372 _UIntType __b, size_t __t, _UIntType __c, size_t __l, _UIntType __f> 2373 _UIntType 2374 mersenne_twister_engine<_UIntType, __w, __n, __m, __r, __a, __u, __d, __s, __b, 2375 __t, __c, __l, __f>::operator()() 2376 { 2377 const size_t __j = (__i_ + 1) % __n; 2378 const result_type __mask = __r == _Dt ? result_type(~0) : 2379 (result_type(1) << __r) - result_type(1); 2380 const result_type _Yp = (__x_[__i_] & ~__mask) | (__x_[__j] & __mask); 2381 const size_t __k = (__i_ + __m) % __n; 2382 __x_[__i_] = __x_[__k] ^ __rshift<1>(_Yp) ^ (__a * (_Yp & 1)); 2383 result_type __z = __x_[__i_] ^ (__rshift<__u>(__x_[__i_]) & __d); 2384 __i_ = __j; 2385 __z ^= __lshift<__s>(__z) & __b; 2386 __z ^= __lshift<__t>(__z) & __c; 2387 return __z ^ __rshift<__l>(__z); 2388 } 2389 2390 template <class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2391 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2392 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2393 bool 2394 operator==(const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2395 _Bp, _Tp, _Cp, _Lp, _Fp>& __x, 2396 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2397 _Bp, _Tp, _Cp, _Lp, _Fp>& __y) 2398 { 2399 if (__x.__i_ == __y.__i_) 2400 return _VSTD::equal(__x.__x_, __x.__x_ + _Np, __y.__x_); 2401 if (__x.__i_ == 0 || __y.__i_ == 0) 2402 { 2403 size_t __j = _VSTD::min(_Np - __x.__i_, _Np - __y.__i_); 2404 if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, 2405 __y.__x_ + __y.__i_)) 2406 return false; 2407 if (__x.__i_ == 0) 2408 return _VSTD::equal(__x.__x_ + __j, __x.__x_ + _Np, __y.__x_); 2409 return _VSTD::equal(__x.__x_, __x.__x_ + (_Np - __j), __y.__x_ + __j); 2410 } 2411 if (__x.__i_ < __y.__i_) 2412 { 2413 size_t __j = _Np - __y.__i_; 2414 if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), 2415 __y.__x_ + __y.__i_)) 2416 return false; 2417 if (!_VSTD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _Np, 2418 __y.__x_)) 2419 return false; 2420 return _VSTD::equal(__x.__x_, __x.__x_ + __x.__i_, 2421 __y.__x_ + (_Np - (__x.__i_ + __j))); 2422 } 2423 size_t __j = _Np - __x.__i_; 2424 if (!_VSTD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), 2425 __x.__x_ + __x.__i_)) 2426 return false; 2427 if (!_VSTD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _Np, 2428 __x.__x_)) 2429 return false; 2430 return _VSTD::equal(__y.__x_, __y.__x_ + __y.__i_, 2431 __x.__x_ + (_Np - (__y.__i_ + __j))); 2432 } 2433 2434 template <class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2435 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2436 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2437 inline _LIBCPP_INLINE_VISIBILITY 2438 bool 2439 operator!=(const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2440 _Bp, _Tp, _Cp, _Lp, _Fp>& __x, 2441 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2442 _Bp, _Tp, _Cp, _Lp, _Fp>& __y) 2443 { 2444 return !(__x == __y); 2445 } 2446 2447 template <class _CharT, class _Traits, 2448 class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2449 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2450 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2451 basic_ostream<_CharT, _Traits>& 2452 operator<<(basic_ostream<_CharT, _Traits>& __os, 2453 const mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2454 _Bp, _Tp, _Cp, _Lp, _Fp>& __x) 2455 { 2456 __save_flags<_CharT, _Traits> __lx(__os); 2457 __os.flags(ios_base::dec | ios_base::left); 2458 _CharT __sp = __os.widen(' '); 2459 __os.fill(__sp); 2460 __os << __x.__x_[__x.__i_]; 2461 for (size_t __j = __x.__i_ + 1; __j < _Np; ++__j) 2462 __os << __sp << __x.__x_[__j]; 2463 for (size_t __j = 0; __j < __x.__i_; ++__j) 2464 __os << __sp << __x.__x_[__j]; 2465 return __os; 2466 } 2467 2468 template <class _CharT, class _Traits, 2469 class _UInt, size_t _Wp, size_t _Np, size_t _Mp, size_t _Rp, 2470 _UInt _Ap, size_t _Up, _UInt _Dp, size_t _Sp, 2471 _UInt _Bp, size_t _Tp, _UInt _Cp, size_t _Lp, _UInt _Fp> 2472 basic_istream<_CharT, _Traits>& 2473 operator>>(basic_istream<_CharT, _Traits>& __is, 2474 mersenne_twister_engine<_UInt, _Wp, _Np, _Mp, _Rp, _Ap, _Up, _Dp, _Sp, 2475 _Bp, _Tp, _Cp, _Lp, _Fp>& __x) 2476 { 2477 __save_flags<_CharT, _Traits> __lx(__is); 2478 __is.flags(ios_base::dec | ios_base::skipws); 2479 _UInt __t[_Np]; 2480 for (size_t __i = 0; __i < _Np; ++__i) 2481 __is >> __t[__i]; 2482 if (!__is.fail()) 2483 { 2484 for (size_t __i = 0; __i < _Np; ++__i) 2485 __x.__x_[__i] = __t[__i]; 2486 __x.__i_ = 0; 2487 } 2488 return __is; 2489 } 2490 2491 typedef mersenne_twister_engine<uint_fast32_t, 32, 624, 397, 31, 2492 0x9908b0df, 11, 0xffffffff, 2493 7, 0x9d2c5680, 2494 15, 0xefc60000, 2495 18, 1812433253> mt19937; 2496 typedef mersenne_twister_engine<uint_fast64_t, 64, 312, 156, 31, 2497 0xb5026f5aa96619e9ULL, 29, 0x5555555555555555ULL, 2498 17, 0x71d67fffeda60000ULL, 2499 37, 0xfff7eee000000000ULL, 2500 43, 6364136223846793005ULL> mt19937_64; 2501 2502 // subtract_with_carry_engine 2503 2504 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2505 class _LIBCPP_TEMPLATE_VIS subtract_with_carry_engine; 2506 2507 template<class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2508 bool 2509 operator==( 2510 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x, 2511 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __y); 2512 2513 template<class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2514 _LIBCPP_INLINE_VISIBILITY 2515 bool 2516 operator!=( 2517 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x, 2518 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __y); 2519 2520 template <class _CharT, class _Traits, 2521 class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2522 basic_ostream<_CharT, _Traits>& 2523 operator<<(basic_ostream<_CharT, _Traits>& __os, 2524 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x); 2525 2526 template <class _CharT, class _Traits, 2527 class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2528 basic_istream<_CharT, _Traits>& 2529 operator>>(basic_istream<_CharT, _Traits>& __is, 2530 subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x); 2531 2532 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2533 class _LIBCPP_TEMPLATE_VIS subtract_with_carry_engine 2534 { 2535 public: 2536 // types 2537 typedef _UIntType result_type; 2538 2539 private: 2540 result_type __x_[__r]; 2541 result_type __c_; 2542 size_t __i_; 2543 2544 static _LIBCPP_CONSTEXPR const result_type _Dt = numeric_limits<result_type>::digits; 2545 static_assert( 0 < __w, "subtract_with_carry_engine invalid parameters"); 2546 static_assert(__w <= _Dt, "subtract_with_carry_engine invalid parameters"); 2547 static_assert( 0 < __s, "subtract_with_carry_engine invalid parameters"); 2548 static_assert(__s < __r, "subtract_with_carry_engine invalid parameters"); 2549 public: 2550 static _LIBCPP_CONSTEXPR const result_type _Min = 0; 2551 static _LIBCPP_CONSTEXPR const result_type _Max = __w == _Dt ? result_type(~0) : 2552 (result_type(1) << __w) - result_type(1); 2553 static_assert(_Min < _Max, "subtract_with_carry_engine invalid parameters"); 2554 2555 // engine characteristics 2556 static _LIBCPP_CONSTEXPR const size_t word_size = __w; 2557 static _LIBCPP_CONSTEXPR const size_t short_lag = __s; 2558 static _LIBCPP_CONSTEXPR const size_t long_lag = __r; 2559 _LIBCPP_INLINE_VISIBILITY 2560 static _LIBCPP_CONSTEXPR result_type min() { return _Min; } 2561 _LIBCPP_INLINE_VISIBILITY 2562 static _LIBCPP_CONSTEXPR result_type max() { return _Max; } 2563 static _LIBCPP_CONSTEXPR const result_type default_seed = 19780503u; 2564 2565 // constructors and seeding functions 2566 _LIBCPP_INLINE_VISIBILITY 2567 explicit subtract_with_carry_engine(result_type __sd = default_seed) 2568 {seed(__sd);} 2569 template<class _Sseq> 2570 _LIBCPP_INLINE_VISIBILITY 2571 explicit subtract_with_carry_engine(_Sseq& __q, 2572 typename enable_if<__is_seed_sequence<_Sseq, subtract_with_carry_engine>::value>::type* = 0) 2573 {seed(__q);} 2574 _LIBCPP_INLINE_VISIBILITY 2575 void seed(result_type __sd = default_seed) 2576 {seed(__sd, integral_constant<unsigned, 1 + (__w - 1) / 32>());} 2577 template<class _Sseq> 2578 _LIBCPP_INLINE_VISIBILITY 2579 typename enable_if 2580 < 2581 __is_seed_sequence<_Sseq, subtract_with_carry_engine>::value, 2582 void 2583 >::type 2584 seed(_Sseq& __q) 2585 {__seed(__q, integral_constant<unsigned, 1 + (__w - 1) / 32>());} 2586 2587 // generating functions 2588 result_type operator()(); 2589 _LIBCPP_INLINE_VISIBILITY 2590 void discard(unsigned long long __z) {for (; __z; --__z) operator()();} 2591 2592 template<class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2593 friend 2594 bool 2595 operator==( 2596 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x, 2597 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __y); 2598 2599 template<class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2600 friend 2601 bool 2602 operator!=( 2603 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x, 2604 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __y); 2605 2606 template <class _CharT, class _Traits, 2607 class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2608 friend 2609 basic_ostream<_CharT, _Traits>& 2610 operator<<(basic_ostream<_CharT, _Traits>& __os, 2611 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x); 2612 2613 template <class _CharT, class _Traits, 2614 class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2615 friend 2616 basic_istream<_CharT, _Traits>& 2617 operator>>(basic_istream<_CharT, _Traits>& __is, 2618 subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x); 2619 2620 private: 2621 2622 void seed(result_type __sd, integral_constant<unsigned, 1>); 2623 void seed(result_type __sd, integral_constant<unsigned, 2>); 2624 template<class _Sseq> 2625 void __seed(_Sseq& __q, integral_constant<unsigned, 1>); 2626 template<class _Sseq> 2627 void __seed(_Sseq& __q, integral_constant<unsigned, 2>); 2628 }; 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>::word_size; 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>::short_lag; 2635 2636 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2637 _LIBCPP_CONSTEXPR const size_t subtract_with_carry_engine<_UIntType, __w, __s, __r>::long_lag; 2638 2639 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2640 _LIBCPP_CONSTEXPR const typename subtract_with_carry_engine<_UIntType, __w, __s, __r>::result_type 2641 subtract_with_carry_engine<_UIntType, __w, __s, __r>::default_seed; 2642 2643 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2644 void 2645 subtract_with_carry_engine<_UIntType, __w, __s, __r>::seed(result_type __sd, 2646 integral_constant<unsigned, 1>) 2647 { 2648 linear_congruential_engine<result_type, 40014u, 0u, 2147483563u> 2649 __e(__sd == 0u ? default_seed : __sd); 2650 for (size_t __i = 0; __i < __r; ++__i) 2651 __x_[__i] = static_cast<result_type>(__e() & _Max); 2652 __c_ = __x_[__r-1] == 0; 2653 __i_ = 0; 2654 } 2655 2656 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2657 void 2658 subtract_with_carry_engine<_UIntType, __w, __s, __r>::seed(result_type __sd, 2659 integral_constant<unsigned, 2>) 2660 { 2661 linear_congruential_engine<result_type, 40014u, 0u, 2147483563u> 2662 __e(__sd == 0u ? default_seed : __sd); 2663 for (size_t __i = 0; __i < __r; ++__i) 2664 { 2665 result_type __e0 = __e(); 2666 __x_[__i] = static_cast<result_type>( 2667 (__e0 + ((uint64_t)__e() << 32)) & _Max); 2668 } 2669 __c_ = __x_[__r-1] == 0; 2670 __i_ = 0; 2671 } 2672 2673 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2674 template<class _Sseq> 2675 void 2676 subtract_with_carry_engine<_UIntType, __w, __s, __r>::__seed(_Sseq& __q, 2677 integral_constant<unsigned, 1>) 2678 { 2679 const unsigned __k = 1; 2680 uint32_t __ar[__r * __k]; 2681 __q.generate(__ar, __ar + __r * __k); 2682 for (size_t __i = 0; __i < __r; ++__i) 2683 __x_[__i] = static_cast<result_type>(__ar[__i] & _Max); 2684 __c_ = __x_[__r-1] == 0; 2685 __i_ = 0; 2686 } 2687 2688 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2689 template<class _Sseq> 2690 void 2691 subtract_with_carry_engine<_UIntType, __w, __s, __r>::__seed(_Sseq& __q, 2692 integral_constant<unsigned, 2>) 2693 { 2694 const unsigned __k = 2; 2695 uint32_t __ar[__r * __k]; 2696 __q.generate(__ar, __ar + __r * __k); 2697 for (size_t __i = 0; __i < __r; ++__i) 2698 __x_[__i] = static_cast<result_type>( 2699 (__ar[2 * __i] + ((uint64_t)__ar[2 * __i + 1] << 32)) & _Max); 2700 __c_ = __x_[__r-1] == 0; 2701 __i_ = 0; 2702 } 2703 2704 template<class _UIntType, size_t __w, size_t __s, size_t __r> 2705 _UIntType 2706 subtract_with_carry_engine<_UIntType, __w, __s, __r>::operator()() 2707 { 2708 const result_type& __xs = __x_[(__i_ + (__r - __s)) % __r]; 2709 result_type& __xr = __x_[__i_]; 2710 result_type __new_c = __c_ == 0 ? __xs < __xr : __xs != 0 ? __xs <= __xr : 1; 2711 __xr = (__xs - __xr - __c_) & _Max; 2712 __c_ = __new_c; 2713 __i_ = (__i_ + 1) % __r; 2714 return __xr; 2715 } 2716 2717 template<class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2718 bool 2719 operator==( 2720 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x, 2721 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __y) 2722 { 2723 if (__x.__c_ != __y.__c_) 2724 return false; 2725 if (__x.__i_ == __y.__i_) 2726 return _VSTD::equal(__x.__x_, __x.__x_ + _Rp, __y.__x_); 2727 if (__x.__i_ == 0 || __y.__i_ == 0) 2728 { 2729 size_t __j = _VSTD::min(_Rp - __x.__i_, _Rp - __y.__i_); 2730 if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + __x.__i_ + __j, 2731 __y.__x_ + __y.__i_)) 2732 return false; 2733 if (__x.__i_ == 0) 2734 return _VSTD::equal(__x.__x_ + __j, __x.__x_ + _Rp, __y.__x_); 2735 return _VSTD::equal(__x.__x_, __x.__x_ + (_Rp - __j), __y.__x_ + __j); 2736 } 2737 if (__x.__i_ < __y.__i_) 2738 { 2739 size_t __j = _Rp - __y.__i_; 2740 if (!_VSTD::equal(__x.__x_ + __x.__i_, __x.__x_ + (__x.__i_ + __j), 2741 __y.__x_ + __y.__i_)) 2742 return false; 2743 if (!_VSTD::equal(__x.__x_ + (__x.__i_ + __j), __x.__x_ + _Rp, 2744 __y.__x_)) 2745 return false; 2746 return _VSTD::equal(__x.__x_, __x.__x_ + __x.__i_, 2747 __y.__x_ + (_Rp - (__x.__i_ + __j))); 2748 } 2749 size_t __j = _Rp - __x.__i_; 2750 if (!_VSTD::equal(__y.__x_ + __y.__i_, __y.__x_ + (__y.__i_ + __j), 2751 __x.__x_ + __x.__i_)) 2752 return false; 2753 if (!_VSTD::equal(__y.__x_ + (__y.__i_ + __j), __y.__x_ + _Rp, 2754 __x.__x_)) 2755 return false; 2756 return _VSTD::equal(__y.__x_, __y.__x_ + __y.__i_, 2757 __x.__x_ + (_Rp - (__y.__i_ + __j))); 2758 } 2759 2760 template<class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2761 inline _LIBCPP_INLINE_VISIBILITY 2762 bool 2763 operator!=( 2764 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x, 2765 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __y) 2766 { 2767 return !(__x == __y); 2768 } 2769 2770 template <class _CharT, class _Traits, 2771 class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2772 basic_ostream<_CharT, _Traits>& 2773 operator<<(basic_ostream<_CharT, _Traits>& __os, 2774 const subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x) 2775 { 2776 __save_flags<_CharT, _Traits> __lx(__os); 2777 __os.flags(ios_base::dec | ios_base::left); 2778 _CharT __sp = __os.widen(' '); 2779 __os.fill(__sp); 2780 __os << __x.__x_[__x.__i_]; 2781 for (size_t __j = __x.__i_ + 1; __j < _Rp; ++__j) 2782 __os << __sp << __x.__x_[__j]; 2783 for (size_t __j = 0; __j < __x.__i_; ++__j) 2784 __os << __sp << __x.__x_[__j]; 2785 __os << __sp << __x.__c_; 2786 return __os; 2787 } 2788 2789 template <class _CharT, class _Traits, 2790 class _UInt, size_t _Wp, size_t _Sp, size_t _Rp> 2791 basic_istream<_CharT, _Traits>& 2792 operator>>(basic_istream<_CharT, _Traits>& __is, 2793 subtract_with_carry_engine<_UInt, _Wp, _Sp, _Rp>& __x) 2794 { 2795 __save_flags<_CharT, _Traits> __lx(__is); 2796 __is.flags(ios_base::dec | ios_base::skipws); 2797 _UInt __t[_Rp+1]; 2798 for (size_t __i = 0; __i < _Rp+1; ++__i) 2799 __is >> __t[__i]; 2800 if (!__is.fail()) 2801 { 2802 for (size_t __i = 0; __i < _Rp; ++__i) 2803 __x.__x_[__i] = __t[__i]; 2804 __x.__c_ = __t[_Rp]; 2805 __x.__i_ = 0; 2806 } 2807 return __is; 2808 } 2809 2810 typedef subtract_with_carry_engine<uint_fast32_t, 24, 10, 24> ranlux24_base; 2811 typedef subtract_with_carry_engine<uint_fast64_t, 48, 5, 12> ranlux48_base; 2812 2813 // discard_block_engine 2814 2815 template<class _Engine, size_t __p, size_t __r> 2816 class _LIBCPP_TEMPLATE_VIS discard_block_engine 2817 { 2818 _Engine __e_; 2819 int __n_; 2820 2821 static_assert( 0 < __r, "discard_block_engine invalid parameters"); 2822 static_assert(__r <= __p, "discard_block_engine invalid parameters"); 2823 static_assert(__r <= INT_MAX, "discard_block_engine invalid parameters"); 2824 public: 2825 // types 2826 typedef typename _Engine::result_type result_type; 2827 2828 // engine characteristics 2829 static _LIBCPP_CONSTEXPR const size_t block_size = __p; 2830 static _LIBCPP_CONSTEXPR const size_t used_block = __r; 2831 2832 #ifdef _LIBCPP_CXX03_LANG 2833 static const result_type _Min = _Engine::_Min; 2834 static const result_type _Max = _Engine::_Max; 2835 #else 2836 static _LIBCPP_CONSTEXPR const result_type _Min = _Engine::min(); 2837 static _LIBCPP_CONSTEXPR const result_type _Max = _Engine::max(); 2838 #endif 2839 2840 _LIBCPP_INLINE_VISIBILITY 2841 static _LIBCPP_CONSTEXPR result_type min() { return _Engine::min(); } 2842 _LIBCPP_INLINE_VISIBILITY 2843 static _LIBCPP_CONSTEXPR result_type max() { return _Engine::max(); } 2844 2845 // constructors and seeding functions 2846 _LIBCPP_INLINE_VISIBILITY 2847 discard_block_engine() : __n_(0) {} 2848 _LIBCPP_INLINE_VISIBILITY 2849 explicit discard_block_engine(const _Engine& __e) 2850 : __e_(__e), __n_(0) {} 2851 #ifndef _LIBCPP_CXX03_LANG 2852 _LIBCPP_INLINE_VISIBILITY 2853 explicit discard_block_engine(_Engine&& __e) 2854 : __e_(_VSTD::move(__e)), __n_(0) {} 2855 #endif // _LIBCPP_CXX03_LANG 2856 _LIBCPP_INLINE_VISIBILITY 2857 explicit discard_block_engine(result_type __sd) : __e_(__sd), __n_(0) {} 2858 template<class _Sseq> 2859 _LIBCPP_INLINE_VISIBILITY 2860 explicit discard_block_engine(_Sseq& __q, 2861 typename enable_if<__is_seed_sequence<_Sseq, discard_block_engine>::value && 2862 !is_convertible<_Sseq, _Engine>::value>::type* = 0) 2863 : __e_(__q), __n_(0) {} 2864 _LIBCPP_INLINE_VISIBILITY 2865 void seed() {__e_.seed(); __n_ = 0;} 2866 _LIBCPP_INLINE_VISIBILITY 2867 void seed(result_type __sd) {__e_.seed(__sd); __n_ = 0;} 2868 template<class _Sseq> 2869 _LIBCPP_INLINE_VISIBILITY 2870 typename enable_if 2871 < 2872 __is_seed_sequence<_Sseq, discard_block_engine>::value, 2873 void 2874 >::type 2875 seed(_Sseq& __q) {__e_.seed(__q); __n_ = 0;} 2876 2877 // generating functions 2878 result_type operator()(); 2879 _LIBCPP_INLINE_VISIBILITY 2880 void discard(unsigned long long __z) {for (; __z; --__z) operator()();} 2881 2882 // property functions 2883 _LIBCPP_INLINE_VISIBILITY 2884 const _Engine& base() const _NOEXCEPT {return __e_;} 2885 2886 template<class _Eng, size_t _Pp, size_t _Rp> 2887 friend 2888 bool 2889 operator==( 2890 const discard_block_engine<_Eng, _Pp, _Rp>& __x, 2891 const discard_block_engine<_Eng, _Pp, _Rp>& __y); 2892 2893 template<class _Eng, size_t _Pp, size_t _Rp> 2894 friend 2895 bool 2896 operator!=( 2897 const discard_block_engine<_Eng, _Pp, _Rp>& __x, 2898 const discard_block_engine<_Eng, _Pp, _Rp>& __y); 2899 2900 template <class _CharT, class _Traits, 2901 class _Eng, size_t _Pp, size_t _Rp> 2902 friend 2903 basic_ostream<_CharT, _Traits>& 2904 operator<<(basic_ostream<_CharT, _Traits>& __os, 2905 const discard_block_engine<_Eng, _Pp, _Rp>& __x); 2906 2907 template <class _CharT, class _Traits, 2908 class _Eng, size_t _Pp, size_t _Rp> 2909 friend 2910 basic_istream<_CharT, _Traits>& 2911 operator>>(basic_istream<_CharT, _Traits>& __is, 2912 discard_block_engine<_Eng, _Pp, _Rp>& __x); 2913 }; 2914 2915 template<class _Engine, size_t __p, size_t __r> 2916 _LIBCPP_CONSTEXPR const size_t discard_block_engine<_Engine, __p, __r>::block_size; 2917 2918 template<class _Engine, size_t __p, size_t __r> 2919 _LIBCPP_CONSTEXPR const size_t discard_block_engine<_Engine, __p, __r>::used_block; 2920 2921 template<class _Engine, size_t __p, size_t __r> 2922 typename discard_block_engine<_Engine, __p, __r>::result_type 2923 discard_block_engine<_Engine, __p, __r>::operator()() 2924 { 2925 if (__n_ >= static_cast<int>(__r)) 2926 { 2927 __e_.discard(__p - __r); 2928 __n_ = 0; 2929 } 2930 ++__n_; 2931 return __e_(); 2932 } 2933 2934 template<class _Eng, size_t _Pp, size_t _Rp> 2935 inline _LIBCPP_INLINE_VISIBILITY 2936 bool 2937 operator==(const discard_block_engine<_Eng, _Pp, _Rp>& __x, 2938 const discard_block_engine<_Eng, _Pp, _Rp>& __y) 2939 { 2940 return __x.__n_ == __y.__n_ && __x.__e_ == __y.__e_; 2941 } 2942 2943 template<class _Eng, size_t _Pp, size_t _Rp> 2944 inline _LIBCPP_INLINE_VISIBILITY 2945 bool 2946 operator!=(const discard_block_engine<_Eng, _Pp, _Rp>& __x, 2947 const discard_block_engine<_Eng, _Pp, _Rp>& __y) 2948 { 2949 return !(__x == __y); 2950 } 2951 2952 template <class _CharT, class _Traits, 2953 class _Eng, size_t _Pp, size_t _Rp> 2954 basic_ostream<_CharT, _Traits>& 2955 operator<<(basic_ostream<_CharT, _Traits>& __os, 2956 const discard_block_engine<_Eng, _Pp, _Rp>& __x) 2957 { 2958 __save_flags<_CharT, _Traits> __lx(__os); 2959 __os.flags(ios_base::dec | ios_base::left); 2960 _CharT __sp = __os.widen(' '); 2961 __os.fill(__sp); 2962 return __os << __x.__e_ << __sp << __x.__n_; 2963 } 2964 2965 template <class _CharT, class _Traits, 2966 class _Eng, size_t _Pp, size_t _Rp> 2967 basic_istream<_CharT, _Traits>& 2968 operator>>(basic_istream<_CharT, _Traits>& __is, 2969 discard_block_engine<_Eng, _Pp, _Rp>& __x) 2970 { 2971 __save_flags<_CharT, _Traits> __lx(__is); 2972 __is.flags(ios_base::dec | ios_base::skipws); 2973 _Eng __e; 2974 int __n; 2975 __is >> __e >> __n; 2976 if (!__is.fail()) 2977 { 2978 __x.__e_ = __e; 2979 __x.__n_ = __n; 2980 } 2981 return __is; 2982 } 2983 2984 typedef discard_block_engine<ranlux24_base, 223, 23> ranlux24; 2985 typedef discard_block_engine<ranlux48_base, 389, 11> ranlux48; 2986 2987 // independent_bits_engine 2988 2989 template<class _Engine, size_t __w, class _UIntType> 2990 class _LIBCPP_TEMPLATE_VIS independent_bits_engine 2991 { 2992 template <class _UInt, _UInt _R0, size_t _Wp, size_t _Mp> 2993 class __get_n 2994 { 2995 static _LIBCPP_CONSTEXPR const size_t _Dt = numeric_limits<_UInt>::digits; 2996 static _LIBCPP_CONSTEXPR const size_t _Np = _Wp / _Mp + (_Wp % _Mp != 0); 2997 static _LIBCPP_CONSTEXPR const size_t _W0 = _Wp / _Np; 2998 static _LIBCPP_CONSTEXPR const _UInt _Y0 = _W0 >= _Dt ? 0 : (_R0 >> _W0) << _W0; 2999 public: 3000 static _LIBCPP_CONSTEXPR const size_t value = _R0 - _Y0 > _Y0 / _Np ? _Np + 1 : _Np; 3001 }; 3002 public: 3003 // types 3004 typedef _UIntType result_type; 3005 3006 private: 3007 _Engine __e_; 3008 3009 static _LIBCPP_CONSTEXPR const result_type _Dt = numeric_limits<result_type>::digits; 3010 static_assert( 0 < __w, "independent_bits_engine invalid parameters"); 3011 static_assert(__w <= _Dt, "independent_bits_engine invalid parameters"); 3012 3013 typedef typename _Engine::result_type _Engine_result_type; 3014 typedef typename conditional 3015 < 3016 sizeof(_Engine_result_type) <= sizeof(result_type), 3017 result_type, 3018 _Engine_result_type 3019 >::type _Working_result_type; 3020 #ifdef _LIBCPP_CXX03_LANG 3021 static const _Working_result_type _Rp = _Engine::_Max - _Engine::_Min 3022 + _Working_result_type(1); 3023 #else 3024 static _LIBCPP_CONSTEXPR const _Working_result_type _Rp = _Engine::max() - _Engine::min() 3025 + _Working_result_type(1); 3026 #endif 3027 static _LIBCPP_CONSTEXPR const size_t __m = __log2<_Working_result_type, _Rp>::value; 3028 static _LIBCPP_CONSTEXPR const size_t __n = __get_n<_Working_result_type, _Rp, __w, __m>::value; 3029 static _LIBCPP_CONSTEXPR const size_t __w0 = __w / __n; 3030 static _LIBCPP_CONSTEXPR const size_t __n0 = __n - __w % __n; 3031 static _LIBCPP_CONSTEXPR const size_t _WDt = numeric_limits<_Working_result_type>::digits; 3032 static _LIBCPP_CONSTEXPR const size_t _EDt = numeric_limits<_Engine_result_type>::digits; 3033 static _LIBCPP_CONSTEXPR const _Working_result_type __y0 = __w0 >= _WDt ? 0 : 3034 (_Rp >> __w0) << __w0; 3035 static _LIBCPP_CONSTEXPR const _Working_result_type __y1 = __w0 >= _WDt - 1 ? 0 : 3036 (_Rp >> (__w0+1)) << (__w0+1); 3037 static _LIBCPP_CONSTEXPR const _Engine_result_type __mask0 = __w0 > 0 ? 3038 _Engine_result_type(~0) >> (_EDt - __w0) : 3039 _Engine_result_type(0); 3040 static _LIBCPP_CONSTEXPR const _Engine_result_type __mask1 = __w0 < _EDt - 1 ? 3041 _Engine_result_type(~0) >> (_EDt - (__w0 + 1)) : 3042 _Engine_result_type(~0); 3043 public: 3044 static _LIBCPP_CONSTEXPR const result_type _Min = 0; 3045 static _LIBCPP_CONSTEXPR const result_type _Max = __w == _Dt ? result_type(~0) : 3046 (result_type(1) << __w) - result_type(1); 3047 static_assert(_Min < _Max, "independent_bits_engine invalid parameters"); 3048 3049 // engine characteristics 3050 _LIBCPP_INLINE_VISIBILITY 3051 static _LIBCPP_CONSTEXPR result_type min() { return _Min; } 3052 _LIBCPP_INLINE_VISIBILITY 3053 static _LIBCPP_CONSTEXPR result_type max() { return _Max; } 3054 3055 // constructors and seeding functions 3056 _LIBCPP_INLINE_VISIBILITY 3057 independent_bits_engine() {} 3058 _LIBCPP_INLINE_VISIBILITY 3059 explicit independent_bits_engine(const _Engine& __e) 3060 : __e_(__e) {} 3061 #ifndef _LIBCPP_CXX03_LANG 3062 _LIBCPP_INLINE_VISIBILITY 3063 explicit independent_bits_engine(_Engine&& __e) 3064 : __e_(_VSTD::move(__e)) {} 3065 #endif // _LIBCPP_CXX03_LANG 3066 _LIBCPP_INLINE_VISIBILITY 3067 explicit independent_bits_engine(result_type __sd) : __e_(__sd) {} 3068 template<class _Sseq> 3069 _LIBCPP_INLINE_VISIBILITY 3070 explicit independent_bits_engine(_Sseq& __q, 3071 typename enable_if<__is_seed_sequence<_Sseq, independent_bits_engine>::value && 3072 !is_convertible<_Sseq, _Engine>::value>::type* = 0) 3073 : __e_(__q) {} 3074 _LIBCPP_INLINE_VISIBILITY 3075 void seed() {__e_.seed();} 3076 _LIBCPP_INLINE_VISIBILITY 3077 void seed(result_type __sd) {__e_.seed(__sd);} 3078 template<class _Sseq> 3079 _LIBCPP_INLINE_VISIBILITY 3080 typename enable_if 3081 < 3082 __is_seed_sequence<_Sseq, independent_bits_engine>::value, 3083 void 3084 >::type 3085 seed(_Sseq& __q) {__e_.seed(__q);} 3086 3087 // generating functions 3088 _LIBCPP_INLINE_VISIBILITY 3089 result_type operator()() {return __eval(integral_constant<bool, _Rp != 0>());} 3090 _LIBCPP_INLINE_VISIBILITY 3091 void discard(unsigned long long __z) {for (; __z; --__z) operator()();} 3092 3093 // property functions 3094 _LIBCPP_INLINE_VISIBILITY 3095 const _Engine& base() const _NOEXCEPT {return __e_;} 3096 3097 template<class _Eng, size_t _Wp, class _UInt> 3098 friend 3099 bool 3100 operator==( 3101 const independent_bits_engine<_Eng, _Wp, _UInt>& __x, 3102 const independent_bits_engine<_Eng, _Wp, _UInt>& __y); 3103 3104 template<class _Eng, size_t _Wp, class _UInt> 3105 friend 3106 bool 3107 operator!=( 3108 const independent_bits_engine<_Eng, _Wp, _UInt>& __x, 3109 const independent_bits_engine<_Eng, _Wp, _UInt>& __y); 3110 3111 template <class _CharT, class _Traits, 3112 class _Eng, size_t _Wp, class _UInt> 3113 friend 3114 basic_ostream<_CharT, _Traits>& 3115 operator<<(basic_ostream<_CharT, _Traits>& __os, 3116 const independent_bits_engine<_Eng, _Wp, _UInt>& __x); 3117 3118 template <class _CharT, class _Traits, 3119 class _Eng, size_t _Wp, class _UInt> 3120 friend 3121 basic_istream<_CharT, _Traits>& 3122 operator>>(basic_istream<_CharT, _Traits>& __is, 3123 independent_bits_engine<_Eng, _Wp, _UInt>& __x); 3124 3125 private: 3126 _LIBCPP_INLINE_VISIBILITY 3127 result_type __eval(false_type); 3128 result_type __eval(true_type); 3129 3130 template <size_t __count> 3131 _LIBCPP_INLINE_VISIBILITY 3132 static 3133 typename enable_if 3134 < 3135 __count < _Dt, 3136 result_type 3137 >::type 3138 __lshift(result_type __x) {return __x << __count;} 3139 3140 template <size_t __count> 3141 _LIBCPP_INLINE_VISIBILITY 3142 static 3143 typename enable_if 3144 < 3145 (__count >= _Dt), 3146 result_type 3147 >::type 3148 __lshift(result_type) {return result_type(0);} 3149 }; 3150 3151 template<class _Engine, size_t __w, class _UIntType> 3152 inline 3153 _UIntType 3154 independent_bits_engine<_Engine, __w, _UIntType>::__eval(false_type) 3155 { 3156 return static_cast<result_type>(__e_() & __mask0); 3157 } 3158 3159 template<class _Engine, size_t __w, class _UIntType> 3160 _UIntType 3161 independent_bits_engine<_Engine, __w, _UIntType>::__eval(true_type) 3162 { 3163 result_type _Sp = 0; 3164 for (size_t __k = 0; __k < __n0; ++__k) 3165 { 3166 _Engine_result_type __u; 3167 do 3168 { 3169 __u = __e_() - _Engine::min(); 3170 } while (__u >= __y0); 3171 _Sp = static_cast<result_type>(__lshift<__w0>(_Sp) + (__u & __mask0)); 3172 } 3173 for (size_t __k = __n0; __k < __n; ++__k) 3174 { 3175 _Engine_result_type __u; 3176 do 3177 { 3178 __u = __e_() - _Engine::min(); 3179 } while (__u >= __y1); 3180 _Sp = static_cast<result_type>(__lshift<__w0+1>(_Sp) + (__u & __mask1)); 3181 } 3182 return _Sp; 3183 } 3184 3185 template<class _Eng, size_t _Wp, class _UInt> 3186 inline _LIBCPP_INLINE_VISIBILITY 3187 bool 3188 operator==( 3189 const independent_bits_engine<_Eng, _Wp, _UInt>& __x, 3190 const independent_bits_engine<_Eng, _Wp, _UInt>& __y) 3191 { 3192 return __x.base() == __y.base(); 3193 } 3194 3195 template<class _Eng, size_t _Wp, class _UInt> 3196 inline _LIBCPP_INLINE_VISIBILITY 3197 bool 3198 operator!=( 3199 const independent_bits_engine<_Eng, _Wp, _UInt>& __x, 3200 const independent_bits_engine<_Eng, _Wp, _UInt>& __y) 3201 { 3202 return !(__x == __y); 3203 } 3204 3205 template <class _CharT, class _Traits, 3206 class _Eng, size_t _Wp, class _UInt> 3207 basic_ostream<_CharT, _Traits>& 3208 operator<<(basic_ostream<_CharT, _Traits>& __os, 3209 const independent_bits_engine<_Eng, _Wp, _UInt>& __x) 3210 { 3211 return __os << __x.base(); 3212 } 3213 3214 template <class _CharT, class _Traits, 3215 class _Eng, size_t _Wp, class _UInt> 3216 basic_istream<_CharT, _Traits>& 3217 operator>>(basic_istream<_CharT, _Traits>& __is, 3218 independent_bits_engine<_Eng, _Wp, _UInt>& __x) 3219 { 3220 _Eng __e; 3221 __is >> __e; 3222 if (!__is.fail()) 3223 __x.__e_ = __e; 3224 return __is; 3225 } 3226 3227 // shuffle_order_engine 3228 3229 template <uint64_t _Xp, uint64_t _Yp> 3230 struct __ugcd 3231 { 3232 static _LIBCPP_CONSTEXPR const uint64_t value = __ugcd<_Yp, _Xp % _Yp>::value; 3233 }; 3234 3235 template <uint64_t _Xp> 3236 struct __ugcd<_Xp, 0> 3237 { 3238 static _LIBCPP_CONSTEXPR const uint64_t value = _Xp; 3239 }; 3240 3241 template <uint64_t _Np, uint64_t _Dp> 3242 class __uratio 3243 { 3244 static_assert(_Dp != 0, "__uratio divide by 0"); 3245 static _LIBCPP_CONSTEXPR const uint64_t __gcd = __ugcd<_Np, _Dp>::value; 3246 public: 3247 static _LIBCPP_CONSTEXPR const uint64_t num = _Np / __gcd; 3248 static _LIBCPP_CONSTEXPR const uint64_t den = _Dp / __gcd; 3249 3250 typedef __uratio<num, den> type; 3251 }; 3252 3253 template<class _Engine, size_t __k> 3254 class _LIBCPP_TEMPLATE_VIS shuffle_order_engine 3255 { 3256 static_assert(0 < __k, "shuffle_order_engine invalid parameters"); 3257 public: 3258 // types 3259 typedef typename _Engine::result_type result_type; 3260 3261 private: 3262 _Engine __e_; 3263 result_type _V_[__k]; 3264 result_type _Y_; 3265 3266 public: 3267 // engine characteristics 3268 static _LIBCPP_CONSTEXPR const size_t table_size = __k; 3269 3270 #ifdef _LIBCPP_CXX03_LANG 3271 static const result_type _Min = _Engine::_Min; 3272 static const result_type _Max = _Engine::_Max; 3273 #else 3274 static _LIBCPP_CONSTEXPR const result_type _Min = _Engine::min(); 3275 static _LIBCPP_CONSTEXPR const result_type _Max = _Engine::max(); 3276 #endif 3277 static_assert(_Min < _Max, "shuffle_order_engine invalid parameters"); 3278 _LIBCPP_INLINE_VISIBILITY 3279 static _LIBCPP_CONSTEXPR result_type min() { return _Min; } 3280 _LIBCPP_INLINE_VISIBILITY 3281 static _LIBCPP_CONSTEXPR result_type max() { return _Max; } 3282 3283 static _LIBCPP_CONSTEXPR const unsigned long long _Rp = _Max - _Min + 1ull; 3284 3285 // constructors and seeding functions 3286 _LIBCPP_INLINE_VISIBILITY 3287 shuffle_order_engine() {__init();} 3288 _LIBCPP_INLINE_VISIBILITY 3289 explicit shuffle_order_engine(const _Engine& __e) 3290 : __e_(__e) {__init();} 3291 #ifndef _LIBCPP_CXX03_LANG 3292 _LIBCPP_INLINE_VISIBILITY 3293 explicit shuffle_order_engine(_Engine&& __e) 3294 : __e_(_VSTD::move(__e)) {__init();} 3295 #endif // _LIBCPP_CXX03_LANG 3296 _LIBCPP_INLINE_VISIBILITY 3297 explicit shuffle_order_engine(result_type __sd) : __e_(__sd) {__init();} 3298 template<class _Sseq> 3299 _LIBCPP_INLINE_VISIBILITY 3300 explicit shuffle_order_engine(_Sseq& __q, 3301 typename enable_if<__is_seed_sequence<_Sseq, shuffle_order_engine>::value && 3302 !is_convertible<_Sseq, _Engine>::value>::type* = 0) 3303 : __e_(__q) {__init();} 3304 _LIBCPP_INLINE_VISIBILITY 3305 void seed() {__e_.seed(); __init();} 3306 _LIBCPP_INLINE_VISIBILITY 3307 void seed(result_type __sd) {__e_.seed(__sd); __init();} 3308 template<class _Sseq> 3309 _LIBCPP_INLINE_VISIBILITY 3310 typename enable_if 3311 < 3312 __is_seed_sequence<_Sseq, shuffle_order_engine>::value, 3313 void 3314 >::type 3315 seed(_Sseq& __q) {__e_.seed(__q); __init();} 3316 3317 // generating functions 3318 _LIBCPP_INLINE_VISIBILITY 3319 result_type operator()() {return __eval(integral_constant<bool, _Rp != 0>());} 3320 _LIBCPP_INLINE_VISIBILITY 3321 void discard(unsigned long long __z) {for (; __z; --__z) operator()();} 3322 3323 // property functions 3324 _LIBCPP_INLINE_VISIBILITY 3325 const _Engine& base() const _NOEXCEPT {return __e_;} 3326 3327 private: 3328 template<class _Eng, size_t _Kp> 3329 friend 3330 bool 3331 operator==( 3332 const shuffle_order_engine<_Eng, _Kp>& __x, 3333 const shuffle_order_engine<_Eng, _Kp>& __y); 3334 3335 template<class _Eng, size_t _Kp> 3336 friend 3337 bool 3338 operator!=( 3339 const shuffle_order_engine<_Eng, _Kp>& __x, 3340 const shuffle_order_engine<_Eng, _Kp>& __y); 3341 3342 template <class _CharT, class _Traits, 3343 class _Eng, size_t _Kp> 3344 friend 3345 basic_ostream<_CharT, _Traits>& 3346 operator<<(basic_ostream<_CharT, _Traits>& __os, 3347 const shuffle_order_engine<_Eng, _Kp>& __x); 3348 3349 template <class _CharT, class _Traits, 3350 class _Eng, size_t _Kp> 3351 friend 3352 basic_istream<_CharT, _Traits>& 3353 operator>>(basic_istream<_CharT, _Traits>& __is, 3354 shuffle_order_engine<_Eng, _Kp>& __x); 3355 3356 _LIBCPP_INLINE_VISIBILITY 3357 void __init() 3358 { 3359 for (size_t __i = 0; __i < __k; ++__i) 3360 _V_[__i] = __e_(); 3361 _Y_ = __e_(); 3362 } 3363 3364 _LIBCPP_INLINE_VISIBILITY 3365 result_type __eval(false_type) {return __eval2(integral_constant<bool, __k & 1>());} 3366 _LIBCPP_INLINE_VISIBILITY 3367 result_type __eval(true_type) {return __eval(__uratio<__k, _Rp>());} 3368 3369 _LIBCPP_INLINE_VISIBILITY 3370 result_type __eval2(false_type) {return __eval(__uratio<__k/2, 0x8000000000000000ull>());} 3371 _LIBCPP_INLINE_VISIBILITY 3372 result_type __eval2(true_type) {return __evalf<__k, 0>();} 3373 3374 template <uint64_t _Np, uint64_t _Dp> 3375 _LIBCPP_INLINE_VISIBILITY 3376 typename enable_if 3377 < 3378 (__uratio<_Np, _Dp>::num > 0xFFFFFFFFFFFFFFFFull / (_Max - _Min)), 3379 result_type 3380 >::type 3381 __eval(__uratio<_Np, _Dp>) 3382 {return __evalf<__uratio<_Np, _Dp>::num, __uratio<_Np, _Dp>::den>();} 3383 3384 template <uint64_t _Np, uint64_t _Dp> 3385 _LIBCPP_INLINE_VISIBILITY 3386 typename enable_if 3387 < 3388 __uratio<_Np, _Dp>::num <= 0xFFFFFFFFFFFFFFFFull / (_Max - _Min), 3389 result_type 3390 >::type 3391 __eval(__uratio<_Np, _Dp>) 3392 { 3393 const size_t __j = static_cast<size_t>(__uratio<_Np, _Dp>::num * (_Y_ - _Min) 3394 / __uratio<_Np, _Dp>::den); 3395 _Y_ = _V_[__j]; 3396 _V_[__j] = __e_(); 3397 return _Y_; 3398 } 3399 3400 template <uint64_t __n, uint64_t __d> 3401 _LIBCPP_INLINE_VISIBILITY 3402 result_type __evalf() 3403 { 3404 const double _Fp = __d == 0 ? 3405 __n / (2. * 0x8000000000000000ull) : 3406 __n / (double)__d; 3407 const size_t __j = static_cast<size_t>(_Fp * (_Y_ - _Min)); 3408 _Y_ = _V_[__j]; 3409 _V_[__j] = __e_(); 3410 return _Y_; 3411 } 3412 }; 3413 3414 template<class _Engine, size_t __k> 3415 _LIBCPP_CONSTEXPR const size_t shuffle_order_engine<_Engine, __k>::table_size; 3416 3417 template<class _Eng, size_t _Kp> 3418 bool 3419 operator==( 3420 const shuffle_order_engine<_Eng, _Kp>& __x, 3421 const shuffle_order_engine<_Eng, _Kp>& __y) 3422 { 3423 return __x._Y_ == __y._Y_ && _VSTD::equal(__x._V_, __x._V_ + _Kp, __y._V_) && 3424 __x.__e_ == __y.__e_; 3425 } 3426 3427 template<class _Eng, size_t _Kp> 3428 inline _LIBCPP_INLINE_VISIBILITY 3429 bool 3430 operator!=( 3431 const shuffle_order_engine<_Eng, _Kp>& __x, 3432 const shuffle_order_engine<_Eng, _Kp>& __y) 3433 { 3434 return !(__x == __y); 3435 } 3436 3437 template <class _CharT, class _Traits, 3438 class _Eng, size_t _Kp> 3439 basic_ostream<_CharT, _Traits>& 3440 operator<<(basic_ostream<_CharT, _Traits>& __os, 3441 const shuffle_order_engine<_Eng, _Kp>& __x) 3442 { 3443 __save_flags<_CharT, _Traits> __lx(__os); 3444 __os.flags(ios_base::dec | ios_base::left); 3445 _CharT __sp = __os.widen(' '); 3446 __os.fill(__sp); 3447 __os << __x.__e_ << __sp << __x._V_[0]; 3448 for (size_t __i = 1; __i < _Kp; ++__i) 3449 __os << __sp << __x._V_[__i]; 3450 return __os << __sp << __x._Y_; 3451 } 3452 3453 template <class _CharT, class _Traits, 3454 class _Eng, size_t _Kp> 3455 basic_istream<_CharT, _Traits>& 3456 operator>>(basic_istream<_CharT, _Traits>& __is, 3457 shuffle_order_engine<_Eng, _Kp>& __x) 3458 { 3459 typedef typename shuffle_order_engine<_Eng, _Kp>::result_type result_type; 3460 __save_flags<_CharT, _Traits> __lx(__is); 3461 __is.flags(ios_base::dec | ios_base::skipws); 3462 _Eng __e; 3463 result_type _Vp[_Kp+1]; 3464 __is >> __e; 3465 for (size_t __i = 0; __i < _Kp+1; ++__i) 3466 __is >> _Vp[__i]; 3467 if (!__is.fail()) 3468 { 3469 __x.__e_ = __e; 3470 for (size_t __i = 0; __i < _Kp; ++__i) 3471 __x._V_[__i] = _Vp[__i]; 3472 __x._Y_ = _Vp[_Kp]; 3473 } 3474 return __is; 3475 } 3476 3477 typedef shuffle_order_engine<minstd_rand0, 256> knuth_b; 3478 3479 // random_device 3480 3481 class _LIBCPP_TYPE_VIS random_device 3482 { 3483 #ifdef _LIBCPP_USING_DEV_RANDOM 3484 int __f_; 3485 #endif // defined(_LIBCPP_USING_DEV_RANDOM) 3486 public: 3487 // types 3488 typedef unsigned result_type; 3489 3490 // generator characteristics 3491 static _LIBCPP_CONSTEXPR const result_type _Min = 0; 3492 static _LIBCPP_CONSTEXPR const result_type _Max = 0xFFFFFFFFu; 3493 3494 _LIBCPP_INLINE_VISIBILITY 3495 static _LIBCPP_CONSTEXPR result_type min() { return _Min;} 3496 _LIBCPP_INLINE_VISIBILITY 3497 static _LIBCPP_CONSTEXPR result_type max() { return _Max;} 3498 3499 // constructors 3500 explicit random_device(const string& __token = "/dev/urandom"); 3501 ~random_device(); 3502 3503 // generating functions 3504 result_type operator()(); 3505 3506 // property functions 3507 double entropy() const _NOEXCEPT; 3508 3509 private: 3510 // no copy functions 3511 random_device(const random_device&); // = delete; 3512 random_device& operator=(const random_device&); // = delete; 3513 }; 3514 3515 // seed_seq 3516 3517 class _LIBCPP_TEMPLATE_VIS seed_seq 3518 { 3519 public: 3520 // types 3521 typedef uint32_t result_type; 3522 3523 private: 3524 vector<result_type> __v_; 3525 3526 template<class _InputIterator> 3527 void init(_InputIterator __first, _InputIterator __last); 3528 public: 3529 // constructors 3530 _LIBCPP_INLINE_VISIBILITY 3531 seed_seq() _NOEXCEPT {} 3532 #ifndef _LIBCPP_CXX03_LANG 3533 template<class _Tp> 3534 _LIBCPP_INLINE_VISIBILITY 3535 seed_seq(initializer_list<_Tp> __il) {init(__il.begin(), __il.end());} 3536 #endif // _LIBCPP_CXX03_LANG 3537 3538 template<class _InputIterator> 3539 _LIBCPP_INLINE_VISIBILITY 3540 seed_seq(_InputIterator __first, _InputIterator __last) 3541 {init(__first, __last);} 3542 3543 // generating functions 3544 template<class _RandomAccessIterator> 3545 void generate(_RandomAccessIterator __first, _RandomAccessIterator __last); 3546 3547 // property functions 3548 _LIBCPP_INLINE_VISIBILITY 3549 size_t size() const _NOEXCEPT {return __v_.size();} 3550 template<class _OutputIterator> 3551 _LIBCPP_INLINE_VISIBILITY 3552 void param(_OutputIterator __dest) const 3553 {_VSTD::copy(__v_.begin(), __v_.end(), __dest);} 3554 3555 private: 3556 // no copy functions 3557 seed_seq(const seed_seq&); // = delete; 3558 void operator=(const seed_seq&); // = delete; 3559 3560 _LIBCPP_INLINE_VISIBILITY 3561 static result_type _Tp(result_type __x) {return __x ^ (__x >> 27);} 3562 }; 3563 3564 template<class _InputIterator> 3565 void 3566 seed_seq::init(_InputIterator __first, _InputIterator __last) 3567 { 3568 for (_InputIterator __s = __first; __s != __last; ++__s) 3569 __v_.push_back(*__s & 0xFFFFFFFF); 3570 } 3571 3572 template<class _RandomAccessIterator> 3573 void 3574 seed_seq::generate(_RandomAccessIterator __first, _RandomAccessIterator __last) 3575 { 3576 if (__first != __last) 3577 { 3578 _VSTD::fill(__first, __last, 0x8b8b8b8b); 3579 const size_t __n = static_cast<size_t>(__last - __first); 3580 const size_t __s = __v_.size(); 3581 const size_t __t = (__n >= 623) ? 11 3582 : (__n >= 68) ? 7 3583 : (__n >= 39) ? 5 3584 : (__n >= 7) ? 3 3585 : (__n - 1) / 2; 3586 const size_t __p = (__n - __t) / 2; 3587 const size_t __q = __p + __t; 3588 const size_t __m = _VSTD::max(__s + 1, __n); 3589 // __k = 0; 3590 { 3591 result_type __r = 1664525 * _Tp(__first[0] ^ __first[__p] 3592 ^ __first[__n - 1]); 3593 __first[__p] += __r; 3594 __r += __s; 3595 __first[__q] += __r; 3596 __first[0] = __r; 3597 } 3598 for (size_t __k = 1; __k <= __s; ++__k) 3599 { 3600 const size_t __kmodn = __k % __n; 3601 const size_t __kpmodn = (__k + __p) % __n; 3602 result_type __r = 1664525 * _Tp(__first[__kmodn] ^ __first[__kpmodn] 3603 ^ __first[(__k - 1) % __n]); 3604 __first[__kpmodn] += __r; 3605 __r += __kmodn + __v_[__k-1]; 3606 __first[(__k + __q) % __n] += __r; 3607 __first[__kmodn] = __r; 3608 } 3609 for (size_t __k = __s + 1; __k < __m; ++__k) 3610 { 3611 const size_t __kmodn = __k % __n; 3612 const size_t __kpmodn = (__k + __p) % __n; 3613 result_type __r = 1664525 * _Tp(__first[__kmodn] ^ __first[__kpmodn] 3614 ^ __first[(__k - 1) % __n]); 3615 __first[__kpmodn] += __r; 3616 __r += __kmodn; 3617 __first[(__k + __q) % __n] += __r; 3618 __first[__kmodn] = __r; 3619 } 3620 for (size_t __k = __m; __k < __m + __n; ++__k) 3621 { 3622 const size_t __kmodn = __k % __n; 3623 const size_t __kpmodn = (__k + __p) % __n; 3624 result_type __r = 1566083941 * _Tp(__first[__kmodn] + 3625 __first[__kpmodn] + 3626 __first[(__k - 1) % __n]); 3627 __first[__kpmodn] ^= __r; 3628 __r -= __kmodn; 3629 __first[(__k + __q) % __n] ^= __r; 3630 __first[__kmodn] = __r; 3631 } 3632 } 3633 } 3634 3635 // generate_canonical 3636 3637 template<class _RealType, size_t __bits, class _URNG> 3638 _RealType 3639 generate_canonical(_URNG& __g) 3640 { 3641 const size_t _Dt = numeric_limits<_RealType>::digits; 3642 const size_t __b = _Dt < __bits ? _Dt : __bits; 3643 #ifdef _LIBCPP_CXX03_LANG 3644 const size_t __logR = __log2<uint64_t, _URNG::_Max - _URNG::_Min + uint64_t(1)>::value; 3645 #else 3646 const size_t __logR = __log2<uint64_t, _URNG::max() - _URNG::min() + uint64_t(1)>::value; 3647 #endif 3648 const size_t __k = __b / __logR + (__b % __logR != 0) + (__b == 0); 3649 const _RealType _Rp = _URNG::max() - _URNG::min() + _RealType(1); 3650 _RealType __base = _Rp; 3651 _RealType _Sp = __g() - _URNG::min(); 3652 for (size_t __i = 1; __i < __k; ++__i, __base *= _Rp) 3653 _Sp += (__g() - _URNG::min()) * __base; 3654 return _Sp / __base; 3655 } 3656 3657 // uniform_int_distribution 3658 3659 // in <algorithm> 3660 3661 template <class _CharT, class _Traits, class _IT> 3662 basic_ostream<_CharT, _Traits>& 3663 operator<<(basic_ostream<_CharT, _Traits>& __os, 3664 const uniform_int_distribution<_IT>& __x) 3665 { 3666 __save_flags<_CharT, _Traits> __lx(__os); 3667 __os.flags(ios_base::dec | ios_base::left); 3668 _CharT __sp = __os.widen(' '); 3669 __os.fill(__sp); 3670 return __os << __x.a() << __sp << __x.b(); 3671 } 3672 3673 template <class _CharT, class _Traits, class _IT> 3674 basic_istream<_CharT, _Traits>& 3675 operator>>(basic_istream<_CharT, _Traits>& __is, 3676 uniform_int_distribution<_IT>& __x) 3677 { 3678 typedef uniform_int_distribution<_IT> _Eng; 3679 typedef typename _Eng::result_type result_type; 3680 typedef typename _Eng::param_type param_type; 3681 __save_flags<_CharT, _Traits> __lx(__is); 3682 __is.flags(ios_base::dec | ios_base::skipws); 3683 result_type __a; 3684 result_type __b; 3685 __is >> __a >> __b; 3686 if (!__is.fail()) 3687 __x.param(param_type(__a, __b)); 3688 return __is; 3689 } 3690 3691 // uniform_real_distribution 3692 3693 template<class _RealType = double> 3694 class _LIBCPP_TEMPLATE_VIS uniform_real_distribution 3695 { 3696 public: 3697 // types 3698 typedef _RealType result_type; 3699 3700 class _LIBCPP_TEMPLATE_VIS param_type 3701 { 3702 result_type __a_; 3703 result_type __b_; 3704 public: 3705 typedef uniform_real_distribution distribution_type; 3706 3707 _LIBCPP_INLINE_VISIBILITY 3708 explicit param_type(result_type __a = 0, 3709 result_type __b = 1) 3710 : __a_(__a), __b_(__b) {} 3711 3712 _LIBCPP_INLINE_VISIBILITY 3713 result_type a() const {return __a_;} 3714 _LIBCPP_INLINE_VISIBILITY 3715 result_type b() const {return __b_;} 3716 3717 friend _LIBCPP_INLINE_VISIBILITY 3718 bool operator==(const param_type& __x, const param_type& __y) 3719 {return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} 3720 friend _LIBCPP_INLINE_VISIBILITY 3721 bool operator!=(const param_type& __x, const param_type& __y) 3722 {return !(__x == __y);} 3723 }; 3724 3725 private: 3726 param_type __p_; 3727 3728 public: 3729 // constructors and reset functions 3730 _LIBCPP_INLINE_VISIBILITY 3731 explicit uniform_real_distribution(result_type __a = 0, result_type __b = 1) 3732 : __p_(param_type(__a, __b)) {} 3733 _LIBCPP_INLINE_VISIBILITY 3734 explicit uniform_real_distribution(const param_type& __p) : __p_(__p) {} 3735 _LIBCPP_INLINE_VISIBILITY 3736 void reset() {} 3737 3738 // generating functions 3739 template<class _URNG> 3740 _LIBCPP_INLINE_VISIBILITY 3741 result_type operator()(_URNG& __g) 3742 {return (*this)(__g, __p_);} 3743 template<class _URNG> _LIBCPP_INLINE_VISIBILITY result_type operator()(_URNG& __g, const param_type& __p); 3744 3745 // property functions 3746 _LIBCPP_INLINE_VISIBILITY 3747 result_type a() const {return __p_.a();} 3748 _LIBCPP_INLINE_VISIBILITY 3749 result_type b() const {return __p_.b();} 3750 3751 _LIBCPP_INLINE_VISIBILITY 3752 param_type param() const {return __p_;} 3753 _LIBCPP_INLINE_VISIBILITY 3754 void param(const param_type& __p) {__p_ = __p;} 3755 3756 _LIBCPP_INLINE_VISIBILITY 3757 result_type min() const {return a();} 3758 _LIBCPP_INLINE_VISIBILITY 3759 result_type max() const {return b();} 3760 3761 friend _LIBCPP_INLINE_VISIBILITY 3762 bool operator==(const uniform_real_distribution& __x, 3763 const uniform_real_distribution& __y) 3764 {return __x.__p_ == __y.__p_;} 3765 friend _LIBCPP_INLINE_VISIBILITY 3766 bool operator!=(const uniform_real_distribution& __x, 3767 const uniform_real_distribution& __y) 3768 {return !(__x == __y);} 3769 }; 3770 3771 template<class _RealType> 3772 template<class _URNG> 3773 inline 3774 typename uniform_real_distribution<_RealType>::result_type 3775 uniform_real_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 3776 { 3777 return (__p.b() - __p.a()) 3778 * _VSTD::generate_canonical<_RealType, numeric_limits<_RealType>::digits>(__g) 3779 + __p.a(); 3780 } 3781 3782 template <class _CharT, class _Traits, class _RT> 3783 basic_ostream<_CharT, _Traits>& 3784 operator<<(basic_ostream<_CharT, _Traits>& __os, 3785 const uniform_real_distribution<_RT>& __x) 3786 { 3787 __save_flags<_CharT, _Traits> __lx(__os); 3788 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 3789 ios_base::scientific); 3790 _CharT __sp = __os.widen(' '); 3791 __os.fill(__sp); 3792 return __os << __x.a() << __sp << __x.b(); 3793 } 3794 3795 template <class _CharT, class _Traits, class _RT> 3796 basic_istream<_CharT, _Traits>& 3797 operator>>(basic_istream<_CharT, _Traits>& __is, 3798 uniform_real_distribution<_RT>& __x) 3799 { 3800 typedef uniform_real_distribution<_RT> _Eng; 3801 typedef typename _Eng::result_type result_type; 3802 typedef typename _Eng::param_type param_type; 3803 __save_flags<_CharT, _Traits> __lx(__is); 3804 __is.flags(ios_base::dec | ios_base::skipws); 3805 result_type __a; 3806 result_type __b; 3807 __is >> __a >> __b; 3808 if (!__is.fail()) 3809 __x.param(param_type(__a, __b)); 3810 return __is; 3811 } 3812 3813 // bernoulli_distribution 3814 3815 class _LIBCPP_TEMPLATE_VIS bernoulli_distribution 3816 { 3817 public: 3818 // types 3819 typedef bool result_type; 3820 3821 class _LIBCPP_TEMPLATE_VIS param_type 3822 { 3823 double __p_; 3824 public: 3825 typedef bernoulli_distribution distribution_type; 3826 3827 _LIBCPP_INLINE_VISIBILITY 3828 explicit param_type(double __p = 0.5) : __p_(__p) {} 3829 3830 _LIBCPP_INLINE_VISIBILITY 3831 double p() const {return __p_;} 3832 3833 friend _LIBCPP_INLINE_VISIBILITY 3834 bool operator==(const param_type& __x, const param_type& __y) 3835 {return __x.__p_ == __y.__p_;} 3836 friend _LIBCPP_INLINE_VISIBILITY 3837 bool operator!=(const param_type& __x, const param_type& __y) 3838 {return !(__x == __y);} 3839 }; 3840 3841 private: 3842 param_type __p_; 3843 3844 public: 3845 // constructors and reset functions 3846 _LIBCPP_INLINE_VISIBILITY 3847 explicit bernoulli_distribution(double __p = 0.5) 3848 : __p_(param_type(__p)) {} 3849 _LIBCPP_INLINE_VISIBILITY 3850 explicit bernoulli_distribution(const param_type& __p) : __p_(__p) {} 3851 _LIBCPP_INLINE_VISIBILITY 3852 void reset() {} 3853 3854 // generating functions 3855 template<class _URNG> 3856 _LIBCPP_INLINE_VISIBILITY 3857 result_type operator()(_URNG& __g) 3858 {return (*this)(__g, __p_);} 3859 template<class _URNG> _LIBCPP_INLINE_VISIBILITY result_type operator()(_URNG& __g, const param_type& __p); 3860 3861 // property functions 3862 _LIBCPP_INLINE_VISIBILITY 3863 double p() const {return __p_.p();} 3864 3865 _LIBCPP_INLINE_VISIBILITY 3866 param_type param() const {return __p_;} 3867 _LIBCPP_INLINE_VISIBILITY 3868 void param(const param_type& __p) {__p_ = __p;} 3869 3870 _LIBCPP_INLINE_VISIBILITY 3871 result_type min() const {return false;} 3872 _LIBCPP_INLINE_VISIBILITY 3873 result_type max() const {return true;} 3874 3875 friend _LIBCPP_INLINE_VISIBILITY 3876 bool operator==(const bernoulli_distribution& __x, 3877 const bernoulli_distribution& __y) 3878 {return __x.__p_ == __y.__p_;} 3879 friend _LIBCPP_INLINE_VISIBILITY 3880 bool operator!=(const bernoulli_distribution& __x, 3881 const bernoulli_distribution& __y) 3882 {return !(__x == __y);} 3883 }; 3884 3885 template<class _URNG> 3886 inline 3887 bernoulli_distribution::result_type 3888 bernoulli_distribution::operator()(_URNG& __g, const param_type& __p) 3889 { 3890 uniform_real_distribution<double> __gen; 3891 return __gen(__g) < __p.p(); 3892 } 3893 3894 template <class _CharT, class _Traits> 3895 basic_ostream<_CharT, _Traits>& 3896 operator<<(basic_ostream<_CharT, _Traits>& __os, const bernoulli_distribution& __x) 3897 { 3898 __save_flags<_CharT, _Traits> __lx(__os); 3899 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 3900 ios_base::scientific); 3901 _CharT __sp = __os.widen(' '); 3902 __os.fill(__sp); 3903 return __os << __x.p(); 3904 } 3905 3906 template <class _CharT, class _Traits> 3907 basic_istream<_CharT, _Traits>& 3908 operator>>(basic_istream<_CharT, _Traits>& __is, bernoulli_distribution& __x) 3909 { 3910 typedef bernoulli_distribution _Eng; 3911 typedef typename _Eng::param_type param_type; 3912 __save_flags<_CharT, _Traits> __lx(__is); 3913 __is.flags(ios_base::dec | ios_base::skipws); 3914 double __p; 3915 __is >> __p; 3916 if (!__is.fail()) 3917 __x.param(param_type(__p)); 3918 return __is; 3919 } 3920 3921 // binomial_distribution 3922 3923 template<class _IntType = int> 3924 class _LIBCPP_TEMPLATE_VIS binomial_distribution 3925 { 3926 public: 3927 // types 3928 typedef _IntType result_type; 3929 3930 class _LIBCPP_TEMPLATE_VIS param_type 3931 { 3932 result_type __t_; 3933 double __p_; 3934 double __pr_; 3935 double __odds_ratio_; 3936 result_type __r0_; 3937 public: 3938 typedef binomial_distribution distribution_type; 3939 3940 explicit param_type(result_type __t = 1, double __p = 0.5); 3941 3942 _LIBCPP_INLINE_VISIBILITY 3943 result_type t() const {return __t_;} 3944 _LIBCPP_INLINE_VISIBILITY 3945 double p() const {return __p_;} 3946 3947 friend _LIBCPP_INLINE_VISIBILITY 3948 bool operator==(const param_type& __x, const param_type& __y) 3949 {return __x.__t_ == __y.__t_ && __x.__p_ == __y.__p_;} 3950 friend _LIBCPP_INLINE_VISIBILITY 3951 bool operator!=(const param_type& __x, const param_type& __y) 3952 {return !(__x == __y);} 3953 3954 friend class binomial_distribution; 3955 }; 3956 3957 private: 3958 param_type __p_; 3959 3960 public: 3961 // constructors and reset functions 3962 _LIBCPP_INLINE_VISIBILITY 3963 explicit binomial_distribution(result_type __t = 1, double __p = 0.5) 3964 : __p_(param_type(__t, __p)) {} 3965 _LIBCPP_INLINE_VISIBILITY 3966 explicit binomial_distribution(const param_type& __p) : __p_(__p) {} 3967 _LIBCPP_INLINE_VISIBILITY 3968 void reset() {} 3969 3970 // generating functions 3971 template<class _URNG> 3972 _LIBCPP_INLINE_VISIBILITY 3973 result_type operator()(_URNG& __g) 3974 {return (*this)(__g, __p_);} 3975 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 3976 3977 // property functions 3978 _LIBCPP_INLINE_VISIBILITY 3979 result_type t() const {return __p_.t();} 3980 _LIBCPP_INLINE_VISIBILITY 3981 double p() const {return __p_.p();} 3982 3983 _LIBCPP_INLINE_VISIBILITY 3984 param_type param() const {return __p_;} 3985 _LIBCPP_INLINE_VISIBILITY 3986 void param(const param_type& __p) {__p_ = __p;} 3987 3988 _LIBCPP_INLINE_VISIBILITY 3989 result_type min() const {return 0;} 3990 _LIBCPP_INLINE_VISIBILITY 3991 result_type max() const {return t();} 3992 3993 friend _LIBCPP_INLINE_VISIBILITY 3994 bool operator==(const binomial_distribution& __x, 3995 const binomial_distribution& __y) 3996 {return __x.__p_ == __y.__p_;} 3997 friend _LIBCPP_INLINE_VISIBILITY 3998 bool operator!=(const binomial_distribution& __x, 3999 const binomial_distribution& __y) 4000 {return !(__x == __y);} 4001 }; 4002 4003 #ifndef _LIBCPP_MSVCRT 4004 extern "C" double lgamma_r(double, int *); 4005 #endif 4006 4007 inline _LIBCPP_INLINE_VISIBILITY double __libcpp_lgamma(double __d) { 4008 #if defined(_LIBCPP_MSVCRT) 4009 return lgamma(__d); 4010 #else 4011 int __sign; 4012 return lgamma_r(__d, &__sign); 4013 #endif 4014 } 4015 4016 template<class _IntType> 4017 binomial_distribution<_IntType>::param_type::param_type(const result_type __t, const double __p) 4018 : __t_(__t), __p_(__p) 4019 { 4020 if (0 < __p_ && __p_ < 1) 4021 { 4022 __r0_ = static_cast<result_type>((__t_ + 1) * __p_); 4023 __pr_ = _VSTD::exp(__libcpp_lgamma(__t_ + 1.) - 4024 __libcpp_lgamma(__r0_ + 1.) - 4025 __libcpp_lgamma(__t_ - __r0_ + 1.) + __r0_ * _VSTD::log(__p_) + 4026 (__t_ - __r0_) * _VSTD::log(1 - __p_)); 4027 __odds_ratio_ = __p_ / (1 - __p_); 4028 } 4029 } 4030 4031 // Reference: Kemp, C.D. (1986). `A modal method for generating binomial 4032 // variables', Commun. Statist. - Theor. Meth. 15(3), 805-813. 4033 template<class _IntType> 4034 template<class _URNG> 4035 _IntType 4036 binomial_distribution<_IntType>::operator()(_URNG& __g, const param_type& __pr) 4037 { 4038 if (__pr.__t_ == 0 || __pr.__p_ == 0) 4039 return 0; 4040 if (__pr.__p_ == 1) 4041 return __pr.__t_; 4042 uniform_real_distribution<double> __gen; 4043 double __u = __gen(__g) - __pr.__pr_; 4044 if (__u < 0) 4045 return __pr.__r0_; 4046 double __pu = __pr.__pr_; 4047 double __pd = __pu; 4048 result_type __ru = __pr.__r0_; 4049 result_type __rd = __ru; 4050 while (true) 4051 { 4052 if (__rd >= 1) 4053 { 4054 __pd *= __rd / (__pr.__odds_ratio_ * (__pr.__t_ - __rd + 1)); 4055 __u -= __pd; 4056 if (__u < 0) 4057 return __rd - 1; 4058 } 4059 if ( __rd != 0 ) 4060 --__rd; 4061 ++__ru; 4062 if (__ru <= __pr.__t_) 4063 { 4064 __pu *= (__pr.__t_ - __ru + 1) * __pr.__odds_ratio_ / __ru; 4065 __u -= __pu; 4066 if (__u < 0) 4067 return __ru; 4068 } 4069 } 4070 } 4071 4072 template <class _CharT, class _Traits, class _IntType> 4073 basic_ostream<_CharT, _Traits>& 4074 operator<<(basic_ostream<_CharT, _Traits>& __os, 4075 const binomial_distribution<_IntType>& __x) 4076 { 4077 __save_flags<_CharT, _Traits> __lx(__os); 4078 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 4079 ios_base::scientific); 4080 _CharT __sp = __os.widen(' '); 4081 __os.fill(__sp); 4082 return __os << __x.t() << __sp << __x.p(); 4083 } 4084 4085 template <class _CharT, class _Traits, class _IntType> 4086 basic_istream<_CharT, _Traits>& 4087 operator>>(basic_istream<_CharT, _Traits>& __is, 4088 binomial_distribution<_IntType>& __x) 4089 { 4090 typedef binomial_distribution<_IntType> _Eng; 4091 typedef typename _Eng::result_type result_type; 4092 typedef typename _Eng::param_type param_type; 4093 __save_flags<_CharT, _Traits> __lx(__is); 4094 __is.flags(ios_base::dec | ios_base::skipws); 4095 result_type __t; 4096 double __p; 4097 __is >> __t >> __p; 4098 if (!__is.fail()) 4099 __x.param(param_type(__t, __p)); 4100 return __is; 4101 } 4102 4103 // exponential_distribution 4104 4105 template<class _RealType = double> 4106 class _LIBCPP_TEMPLATE_VIS exponential_distribution 4107 { 4108 public: 4109 // types 4110 typedef _RealType result_type; 4111 4112 class _LIBCPP_TEMPLATE_VIS param_type 4113 { 4114 result_type __lambda_; 4115 public: 4116 typedef exponential_distribution distribution_type; 4117 4118 _LIBCPP_INLINE_VISIBILITY 4119 explicit param_type(result_type __lambda = 1) : __lambda_(__lambda) {} 4120 4121 _LIBCPP_INLINE_VISIBILITY 4122 result_type lambda() const {return __lambda_;} 4123 4124 friend _LIBCPP_INLINE_VISIBILITY 4125 bool operator==(const param_type& __x, const param_type& __y) 4126 {return __x.__lambda_ == __y.__lambda_;} 4127 friend _LIBCPP_INLINE_VISIBILITY 4128 bool operator!=(const param_type& __x, const param_type& __y) 4129 {return !(__x == __y);} 4130 }; 4131 4132 private: 4133 param_type __p_; 4134 4135 public: 4136 // constructors and reset functions 4137 _LIBCPP_INLINE_VISIBILITY 4138 explicit exponential_distribution(result_type __lambda = 1) 4139 : __p_(param_type(__lambda)) {} 4140 _LIBCPP_INLINE_VISIBILITY 4141 explicit exponential_distribution(const param_type& __p) : __p_(__p) {} 4142 _LIBCPP_INLINE_VISIBILITY 4143 void reset() {} 4144 4145 // generating functions 4146 template<class _URNG> 4147 _LIBCPP_INLINE_VISIBILITY 4148 result_type operator()(_URNG& __g) 4149 {return (*this)(__g, __p_);} 4150 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 4151 4152 // property functions 4153 _LIBCPP_INLINE_VISIBILITY 4154 result_type lambda() const {return __p_.lambda();} 4155 4156 _LIBCPP_INLINE_VISIBILITY 4157 param_type param() const {return __p_;} 4158 _LIBCPP_INLINE_VISIBILITY 4159 void param(const param_type& __p) {__p_ = __p;} 4160 4161 _LIBCPP_INLINE_VISIBILITY 4162 result_type min() const {return 0;} 4163 _LIBCPP_INLINE_VISIBILITY 4164 result_type max() const {return numeric_limits<result_type>::infinity();} 4165 4166 friend _LIBCPP_INLINE_VISIBILITY 4167 bool operator==(const exponential_distribution& __x, 4168 const exponential_distribution& __y) 4169 {return __x.__p_ == __y.__p_;} 4170 friend _LIBCPP_INLINE_VISIBILITY 4171 bool operator!=(const exponential_distribution& __x, 4172 const exponential_distribution& __y) 4173 {return !(__x == __y);} 4174 }; 4175 4176 template <class _RealType> 4177 template<class _URNG> 4178 _RealType 4179 exponential_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 4180 { 4181 return -_VSTD::log 4182 ( 4183 result_type(1) - 4184 _VSTD::generate_canonical<result_type, 4185 numeric_limits<result_type>::digits>(__g) 4186 ) 4187 / __p.lambda(); 4188 } 4189 4190 template <class _CharT, class _Traits, class _RealType> 4191 basic_ostream<_CharT, _Traits>& 4192 operator<<(basic_ostream<_CharT, _Traits>& __os, 4193 const exponential_distribution<_RealType>& __x) 4194 { 4195 __save_flags<_CharT, _Traits> __lx(__os); 4196 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 4197 ios_base::scientific); 4198 return __os << __x.lambda(); 4199 } 4200 4201 template <class _CharT, class _Traits, class _RealType> 4202 basic_istream<_CharT, _Traits>& 4203 operator>>(basic_istream<_CharT, _Traits>& __is, 4204 exponential_distribution<_RealType>& __x) 4205 { 4206 typedef exponential_distribution<_RealType> _Eng; 4207 typedef typename _Eng::result_type result_type; 4208 typedef typename _Eng::param_type param_type; 4209 __save_flags<_CharT, _Traits> __lx(__is); 4210 __is.flags(ios_base::dec | ios_base::skipws); 4211 result_type __lambda; 4212 __is >> __lambda; 4213 if (!__is.fail()) 4214 __x.param(param_type(__lambda)); 4215 return __is; 4216 } 4217 4218 // normal_distribution 4219 4220 template<class _RealType = double> 4221 class _LIBCPP_TEMPLATE_VIS normal_distribution 4222 { 4223 public: 4224 // types 4225 typedef _RealType result_type; 4226 4227 class _LIBCPP_TEMPLATE_VIS param_type 4228 { 4229 result_type __mean_; 4230 result_type __stddev_; 4231 public: 4232 typedef normal_distribution distribution_type; 4233 4234 _LIBCPP_INLINE_VISIBILITY 4235 explicit param_type(result_type __mean = 0, result_type __stddev = 1) 4236 : __mean_(__mean), __stddev_(__stddev) {} 4237 4238 _LIBCPP_INLINE_VISIBILITY 4239 result_type mean() const {return __mean_;} 4240 _LIBCPP_INLINE_VISIBILITY 4241 result_type stddev() const {return __stddev_;} 4242 4243 friend _LIBCPP_INLINE_VISIBILITY 4244 bool operator==(const param_type& __x, const param_type& __y) 4245 {return __x.__mean_ == __y.__mean_ && __x.__stddev_ == __y.__stddev_;} 4246 friend _LIBCPP_INLINE_VISIBILITY 4247 bool operator!=(const param_type& __x, const param_type& __y) 4248 {return !(__x == __y);} 4249 }; 4250 4251 private: 4252 param_type __p_; 4253 result_type _V_; 4254 bool _V_hot_; 4255 4256 public: 4257 // constructors and reset functions 4258 _LIBCPP_INLINE_VISIBILITY 4259 explicit normal_distribution(result_type __mean = 0, result_type __stddev = 1) 4260 : __p_(param_type(__mean, __stddev)), _V_hot_(false) {} 4261 _LIBCPP_INLINE_VISIBILITY 4262 explicit normal_distribution(const param_type& __p) 4263 : __p_(__p), _V_hot_(false) {} 4264 _LIBCPP_INLINE_VISIBILITY 4265 void reset() {_V_hot_ = false;} 4266 4267 // generating functions 4268 template<class _URNG> 4269 _LIBCPP_INLINE_VISIBILITY 4270 result_type operator()(_URNG& __g) 4271 {return (*this)(__g, __p_);} 4272 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 4273 4274 // property functions 4275 _LIBCPP_INLINE_VISIBILITY 4276 result_type mean() const {return __p_.mean();} 4277 _LIBCPP_INLINE_VISIBILITY 4278 result_type stddev() const {return __p_.stddev();} 4279 4280 _LIBCPP_INLINE_VISIBILITY 4281 param_type param() const {return __p_;} 4282 _LIBCPP_INLINE_VISIBILITY 4283 void param(const param_type& __p) {__p_ = __p;} 4284 4285 _LIBCPP_INLINE_VISIBILITY 4286 result_type min() const {return -numeric_limits<result_type>::infinity();} 4287 _LIBCPP_INLINE_VISIBILITY 4288 result_type max() const {return numeric_limits<result_type>::infinity();} 4289 4290 friend _LIBCPP_INLINE_VISIBILITY 4291 bool operator==(const normal_distribution& __x, 4292 const normal_distribution& __y) 4293 {return __x.__p_ == __y.__p_ && __x._V_hot_ == __y._V_hot_ && 4294 (!__x._V_hot_ || __x._V_ == __y._V_);} 4295 friend _LIBCPP_INLINE_VISIBILITY 4296 bool operator!=(const normal_distribution& __x, 4297 const normal_distribution& __y) 4298 {return !(__x == __y);} 4299 4300 template <class _CharT, class _Traits, class _RT> 4301 friend 4302 basic_ostream<_CharT, _Traits>& 4303 operator<<(basic_ostream<_CharT, _Traits>& __os, 4304 const normal_distribution<_RT>& __x); 4305 4306 template <class _CharT, class _Traits, class _RT> 4307 friend 4308 basic_istream<_CharT, _Traits>& 4309 operator>>(basic_istream<_CharT, _Traits>& __is, 4310 normal_distribution<_RT>& __x); 4311 }; 4312 4313 template <class _RealType> 4314 template<class _URNG> 4315 _RealType 4316 normal_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 4317 { 4318 result_type _Up; 4319 if (_V_hot_) 4320 { 4321 _V_hot_ = false; 4322 _Up = _V_; 4323 } 4324 else 4325 { 4326 uniform_real_distribution<result_type> _Uni(-1, 1); 4327 result_type __u; 4328 result_type __v; 4329 result_type __s; 4330 do 4331 { 4332 __u = _Uni(__g); 4333 __v = _Uni(__g); 4334 __s = __u * __u + __v * __v; 4335 } while (__s > 1 || __s == 0); 4336 result_type _Fp = _VSTD::sqrt(-2 * _VSTD::log(__s) / __s); 4337 _V_ = __v * _Fp; 4338 _V_hot_ = true; 4339 _Up = __u * _Fp; 4340 } 4341 return _Up * __p.stddev() + __p.mean(); 4342 } 4343 4344 template <class _CharT, class _Traits, class _RT> 4345 basic_ostream<_CharT, _Traits>& 4346 operator<<(basic_ostream<_CharT, _Traits>& __os, 4347 const normal_distribution<_RT>& __x) 4348 { 4349 __save_flags<_CharT, _Traits> __lx(__os); 4350 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 4351 ios_base::scientific); 4352 _CharT __sp = __os.widen(' '); 4353 __os.fill(__sp); 4354 __os << __x.mean() << __sp << __x.stddev() << __sp << __x._V_hot_; 4355 if (__x._V_hot_) 4356 __os << __sp << __x._V_; 4357 return __os; 4358 } 4359 4360 template <class _CharT, class _Traits, class _RT> 4361 basic_istream<_CharT, _Traits>& 4362 operator>>(basic_istream<_CharT, _Traits>& __is, 4363 normal_distribution<_RT>& __x) 4364 { 4365 typedef normal_distribution<_RT> _Eng; 4366 typedef typename _Eng::result_type result_type; 4367 typedef typename _Eng::param_type param_type; 4368 __save_flags<_CharT, _Traits> __lx(__is); 4369 __is.flags(ios_base::dec | ios_base::skipws); 4370 result_type __mean; 4371 result_type __stddev; 4372 result_type _Vp = 0; 4373 bool _V_hot = false; 4374 __is >> __mean >> __stddev >> _V_hot; 4375 if (_V_hot) 4376 __is >> _Vp; 4377 if (!__is.fail()) 4378 { 4379 __x.param(param_type(__mean, __stddev)); 4380 __x._V_hot_ = _V_hot; 4381 __x._V_ = _Vp; 4382 } 4383 return __is; 4384 } 4385 4386 // lognormal_distribution 4387 4388 template<class _RealType = double> 4389 class _LIBCPP_TEMPLATE_VIS lognormal_distribution 4390 { 4391 public: 4392 // types 4393 typedef _RealType result_type; 4394 4395 class _LIBCPP_TEMPLATE_VIS param_type 4396 { 4397 normal_distribution<result_type> __nd_; 4398 public: 4399 typedef lognormal_distribution distribution_type; 4400 4401 _LIBCPP_INLINE_VISIBILITY 4402 explicit param_type(result_type __m = 0, result_type __s = 1) 4403 : __nd_(__m, __s) {} 4404 4405 _LIBCPP_INLINE_VISIBILITY 4406 result_type m() const {return __nd_.mean();} 4407 _LIBCPP_INLINE_VISIBILITY 4408 result_type s() const {return __nd_.stddev();} 4409 4410 friend _LIBCPP_INLINE_VISIBILITY 4411 bool operator==(const param_type& __x, const param_type& __y) 4412 {return __x.__nd_ == __y.__nd_;} 4413 friend _LIBCPP_INLINE_VISIBILITY 4414 bool operator!=(const param_type& __x, const param_type& __y) 4415 {return !(__x == __y);} 4416 friend class lognormal_distribution; 4417 4418 template <class _CharT, class _Traits, class _RT> 4419 friend 4420 basic_ostream<_CharT, _Traits>& 4421 operator<<(basic_ostream<_CharT, _Traits>& __os, 4422 const lognormal_distribution<_RT>& __x); 4423 4424 template <class _CharT, class _Traits, class _RT> 4425 friend 4426 basic_istream<_CharT, _Traits>& 4427 operator>>(basic_istream<_CharT, _Traits>& __is, 4428 lognormal_distribution<_RT>& __x); 4429 }; 4430 4431 private: 4432 param_type __p_; 4433 4434 public: 4435 // constructor and reset functions 4436 _LIBCPP_INLINE_VISIBILITY 4437 explicit lognormal_distribution(result_type __m = 0, result_type __s = 1) 4438 : __p_(param_type(__m, __s)) {} 4439 _LIBCPP_INLINE_VISIBILITY 4440 explicit lognormal_distribution(const param_type& __p) 4441 : __p_(__p) {} 4442 _LIBCPP_INLINE_VISIBILITY 4443 void reset() {__p_.__nd_.reset();} 4444 4445 // generating functions 4446 template<class _URNG> 4447 _LIBCPP_INLINE_VISIBILITY 4448 result_type operator()(_URNG& __g) 4449 {return (*this)(__g, __p_);} 4450 template<class _URNG> 4451 _LIBCPP_INLINE_VISIBILITY 4452 result_type operator()(_URNG& __g, const param_type& __p) 4453 {return _VSTD::exp(const_cast<normal_distribution<result_type>&>(__p.__nd_)(__g));} 4454 4455 // property functions 4456 _LIBCPP_INLINE_VISIBILITY 4457 result_type m() const {return __p_.m();} 4458 _LIBCPP_INLINE_VISIBILITY 4459 result_type s() const {return __p_.s();} 4460 4461 _LIBCPP_INLINE_VISIBILITY 4462 param_type param() const {return __p_;} 4463 _LIBCPP_INLINE_VISIBILITY 4464 void param(const param_type& __p) {__p_ = __p;} 4465 4466 _LIBCPP_INLINE_VISIBILITY 4467 result_type min() const {return 0;} 4468 _LIBCPP_INLINE_VISIBILITY 4469 result_type max() const {return numeric_limits<result_type>::infinity();} 4470 4471 friend _LIBCPP_INLINE_VISIBILITY 4472 bool operator==(const lognormal_distribution& __x, 4473 const lognormal_distribution& __y) 4474 {return __x.__p_ == __y.__p_;} 4475 friend _LIBCPP_INLINE_VISIBILITY 4476 bool operator!=(const lognormal_distribution& __x, 4477 const lognormal_distribution& __y) 4478 {return !(__x == __y);} 4479 4480 template <class _CharT, class _Traits, class _RT> 4481 friend 4482 basic_ostream<_CharT, _Traits>& 4483 operator<<(basic_ostream<_CharT, _Traits>& __os, 4484 const lognormal_distribution<_RT>& __x); 4485 4486 template <class _CharT, class _Traits, class _RT> 4487 friend 4488 basic_istream<_CharT, _Traits>& 4489 operator>>(basic_istream<_CharT, _Traits>& __is, 4490 lognormal_distribution<_RT>& __x); 4491 }; 4492 4493 template <class _CharT, class _Traits, class _RT> 4494 inline _LIBCPP_INLINE_VISIBILITY 4495 basic_ostream<_CharT, _Traits>& 4496 operator<<(basic_ostream<_CharT, _Traits>& __os, 4497 const lognormal_distribution<_RT>& __x) 4498 { 4499 return __os << __x.__p_.__nd_; 4500 } 4501 4502 template <class _CharT, class _Traits, class _RT> 4503 inline _LIBCPP_INLINE_VISIBILITY 4504 basic_istream<_CharT, _Traits>& 4505 operator>>(basic_istream<_CharT, _Traits>& __is, 4506 lognormal_distribution<_RT>& __x) 4507 { 4508 return __is >> __x.__p_.__nd_; 4509 } 4510 4511 // poisson_distribution 4512 4513 template<class _IntType = int> 4514 class _LIBCPP_TEMPLATE_VIS poisson_distribution 4515 { 4516 public: 4517 // types 4518 typedef _IntType result_type; 4519 4520 class _LIBCPP_TEMPLATE_VIS param_type 4521 { 4522 double __mean_; 4523 double __s_; 4524 double __d_; 4525 double __l_; 4526 double __omega_; 4527 double __c0_; 4528 double __c1_; 4529 double __c2_; 4530 double __c3_; 4531 double __c_; 4532 4533 public: 4534 typedef poisson_distribution distribution_type; 4535 4536 explicit param_type(double __mean = 1.0); 4537 4538 _LIBCPP_INLINE_VISIBILITY 4539 double mean() const {return __mean_;} 4540 4541 friend _LIBCPP_INLINE_VISIBILITY 4542 bool operator==(const param_type& __x, const param_type& __y) 4543 {return __x.__mean_ == __y.__mean_;} 4544 friend _LIBCPP_INLINE_VISIBILITY 4545 bool operator!=(const param_type& __x, const param_type& __y) 4546 {return !(__x == __y);} 4547 4548 friend class poisson_distribution; 4549 }; 4550 4551 private: 4552 param_type __p_; 4553 4554 public: 4555 // constructors and reset functions 4556 _LIBCPP_INLINE_VISIBILITY 4557 explicit poisson_distribution(double __mean = 1.0) : __p_(__mean) {} 4558 _LIBCPP_INLINE_VISIBILITY 4559 explicit poisson_distribution(const param_type& __p) : __p_(__p) {} 4560 _LIBCPP_INLINE_VISIBILITY 4561 void reset() {} 4562 4563 // generating functions 4564 template<class _URNG> 4565 _LIBCPP_INLINE_VISIBILITY 4566 result_type operator()(_URNG& __g) 4567 {return (*this)(__g, __p_);} 4568 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 4569 4570 // property functions 4571 _LIBCPP_INLINE_VISIBILITY 4572 double mean() const {return __p_.mean();} 4573 4574 _LIBCPP_INLINE_VISIBILITY 4575 param_type param() const {return __p_;} 4576 _LIBCPP_INLINE_VISIBILITY 4577 void param(const param_type& __p) {__p_ = __p;} 4578 4579 _LIBCPP_INLINE_VISIBILITY 4580 result_type min() const {return 0;} 4581 _LIBCPP_INLINE_VISIBILITY 4582 result_type max() const {return numeric_limits<result_type>::max();} 4583 4584 friend _LIBCPP_INLINE_VISIBILITY 4585 bool operator==(const poisson_distribution& __x, 4586 const poisson_distribution& __y) 4587 {return __x.__p_ == __y.__p_;} 4588 friend _LIBCPP_INLINE_VISIBILITY 4589 bool operator!=(const poisson_distribution& __x, 4590 const poisson_distribution& __y) 4591 {return !(__x == __y);} 4592 }; 4593 4594 template<class _IntType> 4595 poisson_distribution<_IntType>::param_type::param_type(double __mean) 4596 : __mean_(__mean) 4597 { 4598 if (__mean_ < 10) 4599 { 4600 __s_ = 0; 4601 __d_ = 0; 4602 __l_ = _VSTD::exp(-__mean_); 4603 __omega_ = 0; 4604 __c3_ = 0; 4605 __c2_ = 0; 4606 __c1_ = 0; 4607 __c0_ = 0; 4608 __c_ = 0; 4609 } 4610 else 4611 { 4612 __s_ = _VSTD::sqrt(__mean_); 4613 __d_ = 6 * __mean_ * __mean_; 4614 __l_ = static_cast<result_type>(__mean_ - 1.1484); 4615 __omega_ = .3989423 / __s_; 4616 double __b1_ = .4166667E-1 / __mean_; 4617 double __b2_ = .3 * __b1_ * __b1_; 4618 __c3_ = .1428571 * __b1_ * __b2_; 4619 __c2_ = __b2_ - 15. * __c3_; 4620 __c1_ = __b1_ - 6. * __b2_ + 45. * __c3_; 4621 __c0_ = 1. - __b1_ + 3. * __b2_ - 15. * __c3_; 4622 __c_ = .1069 / __mean_; 4623 } 4624 } 4625 4626 template <class _IntType> 4627 template<class _URNG> 4628 _IntType 4629 poisson_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr) 4630 { 4631 result_type __x; 4632 uniform_real_distribution<double> __urd; 4633 if (__pr.__mean_ < 10) 4634 { 4635 __x = 0; 4636 for (double __p = __urd(__urng); __p > __pr.__l_; ++__x) 4637 __p *= __urd(__urng); 4638 } 4639 else 4640 { 4641 double __difmuk; 4642 double __g = __pr.__mean_ + __pr.__s_ * normal_distribution<double>()(__urng); 4643 double __u; 4644 if (__g > 0) 4645 { 4646 __x = static_cast<result_type>(__g); 4647 if (__x >= __pr.__l_) 4648 return __x; 4649 __difmuk = __pr.__mean_ - __x; 4650 __u = __urd(__urng); 4651 if (__pr.__d_ * __u >= __difmuk * __difmuk * __difmuk) 4652 return __x; 4653 } 4654 exponential_distribution<double> __edist; 4655 for (bool __using_exp_dist = false; true; __using_exp_dist = true) 4656 { 4657 double __e; 4658 if (__using_exp_dist || __g < 0) 4659 { 4660 double __t; 4661 do 4662 { 4663 __e = __edist(__urng); 4664 __u = __urd(__urng); 4665 __u += __u - 1; 4666 __t = 1.8 + (__u < 0 ? -__e : __e); 4667 } while (__t <= -.6744); 4668 __x = __pr.__mean_ + __pr.__s_ * __t; 4669 __difmuk = __pr.__mean_ - __x; 4670 __using_exp_dist = true; 4671 } 4672 double __px; 4673 double __py; 4674 if (__x < 10) 4675 { 4676 const double __fac[] = {1, 1, 2, 6, 24, 120, 720, 5040, 4677 40320, 362880}; 4678 __px = -__pr.__mean_; 4679 __py = _VSTD::pow(__pr.__mean_, (double)__x) / __fac[__x]; 4680 } 4681 else 4682 { 4683 double __del = .8333333E-1 / __x; 4684 __del -= 4.8 * __del * __del * __del; 4685 double __v = __difmuk / __x; 4686 if (_VSTD::abs(__v) > 0.25) 4687 __px = __x * _VSTD::log(1 + __v) - __difmuk - __del; 4688 else 4689 __px = __x * __v * __v * (((((((.1250060 * __v + -.1384794) * 4690 __v + .1421878) * __v + -.1661269) * __v + .2000118) * 4691 __v + -.2500068) * __v + .3333333) * __v + -.5) - __del; 4692 __py = .3989423 / _VSTD::sqrt(__x); 4693 } 4694 double __r = (0.5 - __difmuk) / __pr.__s_; 4695 double __r2 = __r * __r; 4696 double __fx = -0.5 * __r2; 4697 double __fy = __pr.__omega_ * (((__pr.__c3_ * __r2 + __pr.__c2_) * 4698 __r2 + __pr.__c1_) * __r2 + __pr.__c0_); 4699 if (__using_exp_dist) 4700 { 4701 if (__pr.__c_ * _VSTD::abs(__u) <= __py * _VSTD::exp(__px + __e) - 4702 __fy * _VSTD::exp(__fx + __e)) 4703 break; 4704 } 4705 else 4706 { 4707 if (__fy - __u * __fy <= __py * _VSTD::exp(__px - __fx)) 4708 break; 4709 } 4710 } 4711 } 4712 return __x; 4713 } 4714 4715 template <class _CharT, class _Traits, class _IntType> 4716 basic_ostream<_CharT, _Traits>& 4717 operator<<(basic_ostream<_CharT, _Traits>& __os, 4718 const poisson_distribution<_IntType>& __x) 4719 { 4720 __save_flags<_CharT, _Traits> __lx(__os); 4721 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 4722 ios_base::scientific); 4723 return __os << __x.mean(); 4724 } 4725 4726 template <class _CharT, class _Traits, class _IntType> 4727 basic_istream<_CharT, _Traits>& 4728 operator>>(basic_istream<_CharT, _Traits>& __is, 4729 poisson_distribution<_IntType>& __x) 4730 { 4731 typedef poisson_distribution<_IntType> _Eng; 4732 typedef typename _Eng::param_type param_type; 4733 __save_flags<_CharT, _Traits> __lx(__is); 4734 __is.flags(ios_base::dec | ios_base::skipws); 4735 double __mean; 4736 __is >> __mean; 4737 if (!__is.fail()) 4738 __x.param(param_type(__mean)); 4739 return __is; 4740 } 4741 4742 // weibull_distribution 4743 4744 template<class _RealType = double> 4745 class _LIBCPP_TEMPLATE_VIS weibull_distribution 4746 { 4747 public: 4748 // types 4749 typedef _RealType result_type; 4750 4751 class _LIBCPP_TEMPLATE_VIS param_type 4752 { 4753 result_type __a_; 4754 result_type __b_; 4755 public: 4756 typedef weibull_distribution distribution_type; 4757 4758 _LIBCPP_INLINE_VISIBILITY 4759 explicit param_type(result_type __a = 1, result_type __b = 1) 4760 : __a_(__a), __b_(__b) {} 4761 4762 _LIBCPP_INLINE_VISIBILITY 4763 result_type a() const {return __a_;} 4764 _LIBCPP_INLINE_VISIBILITY 4765 result_type b() const {return __b_;} 4766 4767 friend _LIBCPP_INLINE_VISIBILITY 4768 bool operator==(const param_type& __x, const param_type& __y) 4769 {return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} 4770 friend _LIBCPP_INLINE_VISIBILITY 4771 bool operator!=(const param_type& __x, const param_type& __y) 4772 {return !(__x == __y);} 4773 }; 4774 4775 private: 4776 param_type __p_; 4777 4778 public: 4779 // constructor and reset functions 4780 _LIBCPP_INLINE_VISIBILITY 4781 explicit weibull_distribution(result_type __a = 1, result_type __b = 1) 4782 : __p_(param_type(__a, __b)) {} 4783 _LIBCPP_INLINE_VISIBILITY 4784 explicit weibull_distribution(const param_type& __p) 4785 : __p_(__p) {} 4786 _LIBCPP_INLINE_VISIBILITY 4787 void reset() {} 4788 4789 // generating functions 4790 template<class _URNG> 4791 _LIBCPP_INLINE_VISIBILITY 4792 result_type operator()(_URNG& __g) 4793 {return (*this)(__g, __p_);} 4794 template<class _URNG> 4795 _LIBCPP_INLINE_VISIBILITY 4796 result_type operator()(_URNG& __g, const param_type& __p) 4797 {return __p.b() * 4798 _VSTD::pow(exponential_distribution<result_type>()(__g), 1/__p.a());} 4799 4800 // property functions 4801 _LIBCPP_INLINE_VISIBILITY 4802 result_type a() const {return __p_.a();} 4803 _LIBCPP_INLINE_VISIBILITY 4804 result_type b() const {return __p_.b();} 4805 4806 _LIBCPP_INLINE_VISIBILITY 4807 param_type param() const {return __p_;} 4808 _LIBCPP_INLINE_VISIBILITY 4809 void param(const param_type& __p) {__p_ = __p;} 4810 4811 _LIBCPP_INLINE_VISIBILITY 4812 result_type min() const {return 0;} 4813 _LIBCPP_INLINE_VISIBILITY 4814 result_type max() const {return numeric_limits<result_type>::infinity();} 4815 4816 friend _LIBCPP_INLINE_VISIBILITY 4817 bool operator==(const weibull_distribution& __x, 4818 const weibull_distribution& __y) 4819 {return __x.__p_ == __y.__p_;} 4820 friend _LIBCPP_INLINE_VISIBILITY 4821 bool operator!=(const weibull_distribution& __x, 4822 const weibull_distribution& __y) 4823 {return !(__x == __y);} 4824 }; 4825 4826 template <class _CharT, class _Traits, class _RT> 4827 basic_ostream<_CharT, _Traits>& 4828 operator<<(basic_ostream<_CharT, _Traits>& __os, 4829 const weibull_distribution<_RT>& __x) 4830 { 4831 __save_flags<_CharT, _Traits> __lx(__os); 4832 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 4833 ios_base::scientific); 4834 _CharT __sp = __os.widen(' '); 4835 __os.fill(__sp); 4836 __os << __x.a() << __sp << __x.b(); 4837 return __os; 4838 } 4839 4840 template <class _CharT, class _Traits, class _RT> 4841 basic_istream<_CharT, _Traits>& 4842 operator>>(basic_istream<_CharT, _Traits>& __is, 4843 weibull_distribution<_RT>& __x) 4844 { 4845 typedef weibull_distribution<_RT> _Eng; 4846 typedef typename _Eng::result_type result_type; 4847 typedef typename _Eng::param_type param_type; 4848 __save_flags<_CharT, _Traits> __lx(__is); 4849 __is.flags(ios_base::dec | ios_base::skipws); 4850 result_type __a; 4851 result_type __b; 4852 __is >> __a >> __b; 4853 if (!__is.fail()) 4854 __x.param(param_type(__a, __b)); 4855 return __is; 4856 } 4857 4858 template<class _RealType = double> 4859 class _LIBCPP_TEMPLATE_VIS extreme_value_distribution 4860 { 4861 public: 4862 // types 4863 typedef _RealType result_type; 4864 4865 class _LIBCPP_TEMPLATE_VIS param_type 4866 { 4867 result_type __a_; 4868 result_type __b_; 4869 public: 4870 typedef extreme_value_distribution distribution_type; 4871 4872 _LIBCPP_INLINE_VISIBILITY 4873 explicit param_type(result_type __a = 0, result_type __b = 1) 4874 : __a_(__a), __b_(__b) {} 4875 4876 _LIBCPP_INLINE_VISIBILITY 4877 result_type a() const {return __a_;} 4878 _LIBCPP_INLINE_VISIBILITY 4879 result_type b() const {return __b_;} 4880 4881 friend _LIBCPP_INLINE_VISIBILITY 4882 bool operator==(const param_type& __x, const param_type& __y) 4883 {return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} 4884 friend _LIBCPP_INLINE_VISIBILITY 4885 bool operator!=(const param_type& __x, const param_type& __y) 4886 {return !(__x == __y);} 4887 }; 4888 4889 private: 4890 param_type __p_; 4891 4892 public: 4893 // constructor and reset functions 4894 _LIBCPP_INLINE_VISIBILITY 4895 explicit extreme_value_distribution(result_type __a = 0, result_type __b = 1) 4896 : __p_(param_type(__a, __b)) {} 4897 _LIBCPP_INLINE_VISIBILITY 4898 explicit extreme_value_distribution(const param_type& __p) 4899 : __p_(__p) {} 4900 _LIBCPP_INLINE_VISIBILITY 4901 void reset() {} 4902 4903 // generating functions 4904 template<class _URNG> 4905 _LIBCPP_INLINE_VISIBILITY 4906 result_type operator()(_URNG& __g) 4907 {return (*this)(__g, __p_);} 4908 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 4909 4910 // property functions 4911 _LIBCPP_INLINE_VISIBILITY 4912 result_type a() const {return __p_.a();} 4913 _LIBCPP_INLINE_VISIBILITY 4914 result_type b() const {return __p_.b();} 4915 4916 _LIBCPP_INLINE_VISIBILITY 4917 param_type param() const {return __p_;} 4918 _LIBCPP_INLINE_VISIBILITY 4919 void param(const param_type& __p) {__p_ = __p;} 4920 4921 _LIBCPP_INLINE_VISIBILITY 4922 result_type min() const {return -numeric_limits<result_type>::infinity();} 4923 _LIBCPP_INLINE_VISIBILITY 4924 result_type max() const {return numeric_limits<result_type>::infinity();} 4925 4926 friend _LIBCPP_INLINE_VISIBILITY 4927 bool operator==(const extreme_value_distribution& __x, 4928 const extreme_value_distribution& __y) 4929 {return __x.__p_ == __y.__p_;} 4930 friend _LIBCPP_INLINE_VISIBILITY 4931 bool operator!=(const extreme_value_distribution& __x, 4932 const extreme_value_distribution& __y) 4933 {return !(__x == __y);} 4934 }; 4935 4936 template<class _RealType> 4937 template<class _URNG> 4938 _RealType 4939 extreme_value_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 4940 { 4941 return __p.a() - __p.b() * 4942 _VSTD::log(-_VSTD::log(1-uniform_real_distribution<result_type>()(__g))); 4943 } 4944 4945 template <class _CharT, class _Traits, class _RT> 4946 basic_ostream<_CharT, _Traits>& 4947 operator<<(basic_ostream<_CharT, _Traits>& __os, 4948 const extreme_value_distribution<_RT>& __x) 4949 { 4950 __save_flags<_CharT, _Traits> __lx(__os); 4951 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 4952 ios_base::scientific); 4953 _CharT __sp = __os.widen(' '); 4954 __os.fill(__sp); 4955 __os << __x.a() << __sp << __x.b(); 4956 return __os; 4957 } 4958 4959 template <class _CharT, class _Traits, class _RT> 4960 basic_istream<_CharT, _Traits>& 4961 operator>>(basic_istream<_CharT, _Traits>& __is, 4962 extreme_value_distribution<_RT>& __x) 4963 { 4964 typedef extreme_value_distribution<_RT> _Eng; 4965 typedef typename _Eng::result_type result_type; 4966 typedef typename _Eng::param_type param_type; 4967 __save_flags<_CharT, _Traits> __lx(__is); 4968 __is.flags(ios_base::dec | ios_base::skipws); 4969 result_type __a; 4970 result_type __b; 4971 __is >> __a >> __b; 4972 if (!__is.fail()) 4973 __x.param(param_type(__a, __b)); 4974 return __is; 4975 } 4976 4977 // gamma_distribution 4978 4979 template<class _RealType = double> 4980 class _LIBCPP_TEMPLATE_VIS gamma_distribution 4981 { 4982 public: 4983 // types 4984 typedef _RealType result_type; 4985 4986 class _LIBCPP_TEMPLATE_VIS param_type 4987 { 4988 result_type __alpha_; 4989 result_type __beta_; 4990 public: 4991 typedef gamma_distribution distribution_type; 4992 4993 _LIBCPP_INLINE_VISIBILITY 4994 explicit param_type(result_type __alpha = 1, result_type __beta = 1) 4995 : __alpha_(__alpha), __beta_(__beta) {} 4996 4997 _LIBCPP_INLINE_VISIBILITY 4998 result_type alpha() const {return __alpha_;} 4999 _LIBCPP_INLINE_VISIBILITY 5000 result_type beta() const {return __beta_;} 5001 5002 friend _LIBCPP_INLINE_VISIBILITY 5003 bool operator==(const param_type& __x, const param_type& __y) 5004 {return __x.__alpha_ == __y.__alpha_ && __x.__beta_ == __y.__beta_;} 5005 friend _LIBCPP_INLINE_VISIBILITY 5006 bool operator!=(const param_type& __x, const param_type& __y) 5007 {return !(__x == __y);} 5008 }; 5009 5010 private: 5011 param_type __p_; 5012 5013 public: 5014 // constructors and reset functions 5015 _LIBCPP_INLINE_VISIBILITY 5016 explicit gamma_distribution(result_type __alpha = 1, result_type __beta = 1) 5017 : __p_(param_type(__alpha, __beta)) {} 5018 _LIBCPP_INLINE_VISIBILITY 5019 explicit gamma_distribution(const param_type& __p) 5020 : __p_(__p) {} 5021 _LIBCPP_INLINE_VISIBILITY 5022 void reset() {} 5023 5024 // generating functions 5025 template<class _URNG> 5026 _LIBCPP_INLINE_VISIBILITY 5027 result_type operator()(_URNG& __g) 5028 {return (*this)(__g, __p_);} 5029 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 5030 5031 // property functions 5032 _LIBCPP_INLINE_VISIBILITY 5033 result_type alpha() const {return __p_.alpha();} 5034 _LIBCPP_INLINE_VISIBILITY 5035 result_type beta() const {return __p_.beta();} 5036 5037 _LIBCPP_INLINE_VISIBILITY 5038 param_type param() const {return __p_;} 5039 _LIBCPP_INLINE_VISIBILITY 5040 void param(const param_type& __p) {__p_ = __p;} 5041 5042 _LIBCPP_INLINE_VISIBILITY 5043 result_type min() const {return 0;} 5044 _LIBCPP_INLINE_VISIBILITY 5045 result_type max() const {return numeric_limits<result_type>::infinity();} 5046 5047 friend _LIBCPP_INLINE_VISIBILITY 5048 bool operator==(const gamma_distribution& __x, 5049 const gamma_distribution& __y) 5050 {return __x.__p_ == __y.__p_;} 5051 friend _LIBCPP_INLINE_VISIBILITY 5052 bool operator!=(const gamma_distribution& __x, 5053 const gamma_distribution& __y) 5054 {return !(__x == __y);} 5055 }; 5056 5057 template <class _RealType> 5058 template<class _URNG> 5059 _RealType 5060 gamma_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 5061 { 5062 result_type __a = __p.alpha(); 5063 uniform_real_distribution<result_type> __gen(0, 1); 5064 exponential_distribution<result_type> __egen; 5065 result_type __x; 5066 if (__a == 1) 5067 __x = __egen(__g); 5068 else if (__a > 1) 5069 { 5070 const result_type __b = __a - 1; 5071 const result_type __c = 3 * __a - result_type(0.75); 5072 while (true) 5073 { 5074 const result_type __u = __gen(__g); 5075 const result_type __v = __gen(__g); 5076 const result_type __w = __u * (1 - __u); 5077 if (__w != 0) 5078 { 5079 const result_type __y = _VSTD::sqrt(__c / __w) * 5080 (__u - result_type(0.5)); 5081 __x = __b + __y; 5082 if (__x >= 0) 5083 { 5084 const result_type __z = 64 * __w * __w * __w * __v * __v; 5085 if (__z <= 1 - 2 * __y * __y / __x) 5086 break; 5087 if (_VSTD::log(__z) <= 2 * (__b * _VSTD::log(__x / __b) - __y)) 5088 break; 5089 } 5090 } 5091 } 5092 } 5093 else // __a < 1 5094 { 5095 while (true) 5096 { 5097 const result_type __u = __gen(__g); 5098 const result_type __es = __egen(__g); 5099 if (__u <= 1 - __a) 5100 { 5101 __x = _VSTD::pow(__u, 1 / __a); 5102 if (__x <= __es) 5103 break; 5104 } 5105 else 5106 { 5107 const result_type __e = -_VSTD::log((1-__u)/__a); 5108 __x = _VSTD::pow(1 - __a + __a * __e, 1 / __a); 5109 if (__x <= __e + __es) 5110 break; 5111 } 5112 } 5113 } 5114 return __x * __p.beta(); 5115 } 5116 5117 template <class _CharT, class _Traits, class _RT> 5118 basic_ostream<_CharT, _Traits>& 5119 operator<<(basic_ostream<_CharT, _Traits>& __os, 5120 const gamma_distribution<_RT>& __x) 5121 { 5122 __save_flags<_CharT, _Traits> __lx(__os); 5123 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5124 ios_base::scientific); 5125 _CharT __sp = __os.widen(' '); 5126 __os.fill(__sp); 5127 __os << __x.alpha() << __sp << __x.beta(); 5128 return __os; 5129 } 5130 5131 template <class _CharT, class _Traits, class _RT> 5132 basic_istream<_CharT, _Traits>& 5133 operator>>(basic_istream<_CharT, _Traits>& __is, 5134 gamma_distribution<_RT>& __x) 5135 { 5136 typedef gamma_distribution<_RT> _Eng; 5137 typedef typename _Eng::result_type result_type; 5138 typedef typename _Eng::param_type param_type; 5139 __save_flags<_CharT, _Traits> __lx(__is); 5140 __is.flags(ios_base::dec | ios_base::skipws); 5141 result_type __alpha; 5142 result_type __beta; 5143 __is >> __alpha >> __beta; 5144 if (!__is.fail()) 5145 __x.param(param_type(__alpha, __beta)); 5146 return __is; 5147 } 5148 5149 // negative_binomial_distribution 5150 5151 template<class _IntType = int> 5152 class _LIBCPP_TEMPLATE_VIS negative_binomial_distribution 5153 { 5154 public: 5155 // types 5156 typedef _IntType result_type; 5157 5158 class _LIBCPP_TEMPLATE_VIS param_type 5159 { 5160 result_type __k_; 5161 double __p_; 5162 public: 5163 typedef negative_binomial_distribution distribution_type; 5164 5165 _LIBCPP_INLINE_VISIBILITY 5166 explicit param_type(result_type __k = 1, double __p = 0.5) 5167 : __k_(__k), __p_(__p) {} 5168 5169 _LIBCPP_INLINE_VISIBILITY 5170 result_type k() const {return __k_;} 5171 _LIBCPP_INLINE_VISIBILITY 5172 double p() const {return __p_;} 5173 5174 friend _LIBCPP_INLINE_VISIBILITY 5175 bool operator==(const param_type& __x, const param_type& __y) 5176 {return __x.__k_ == __y.__k_ && __x.__p_ == __y.__p_;} 5177 friend _LIBCPP_INLINE_VISIBILITY 5178 bool operator!=(const param_type& __x, const param_type& __y) 5179 {return !(__x == __y);} 5180 }; 5181 5182 private: 5183 param_type __p_; 5184 5185 public: 5186 // constructor and reset functions 5187 _LIBCPP_INLINE_VISIBILITY 5188 explicit negative_binomial_distribution(result_type __k = 1, double __p = 0.5) 5189 : __p_(__k, __p) {} 5190 _LIBCPP_INLINE_VISIBILITY 5191 explicit negative_binomial_distribution(const param_type& __p) : __p_(__p) {} 5192 _LIBCPP_INLINE_VISIBILITY 5193 void reset() {} 5194 5195 // generating functions 5196 template<class _URNG> 5197 _LIBCPP_INLINE_VISIBILITY 5198 result_type operator()(_URNG& __g) 5199 {return (*this)(__g, __p_);} 5200 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 5201 5202 // property functions 5203 _LIBCPP_INLINE_VISIBILITY 5204 result_type k() const {return __p_.k();} 5205 _LIBCPP_INLINE_VISIBILITY 5206 double p() const {return __p_.p();} 5207 5208 _LIBCPP_INLINE_VISIBILITY 5209 param_type param() const {return __p_;} 5210 _LIBCPP_INLINE_VISIBILITY 5211 void param(const param_type& __p) {__p_ = __p;} 5212 5213 _LIBCPP_INLINE_VISIBILITY 5214 result_type min() const {return 0;} 5215 _LIBCPP_INLINE_VISIBILITY 5216 result_type max() const {return numeric_limits<result_type>::max();} 5217 5218 friend _LIBCPP_INLINE_VISIBILITY 5219 bool operator==(const negative_binomial_distribution& __x, 5220 const negative_binomial_distribution& __y) 5221 {return __x.__p_ == __y.__p_;} 5222 friend _LIBCPP_INLINE_VISIBILITY 5223 bool operator!=(const negative_binomial_distribution& __x, 5224 const negative_binomial_distribution& __y) 5225 {return !(__x == __y);} 5226 }; 5227 5228 template <class _IntType> 5229 template<class _URNG> 5230 _IntType 5231 negative_binomial_distribution<_IntType>::operator()(_URNG& __urng, const param_type& __pr) 5232 { 5233 result_type __k = __pr.k(); 5234 double __p = __pr.p(); 5235 if (__k <= 21 * __p) 5236 { 5237 bernoulli_distribution __gen(__p); 5238 result_type __f = 0; 5239 result_type __s = 0; 5240 while (__s < __k) 5241 { 5242 if (__gen(__urng)) 5243 ++__s; 5244 else 5245 ++__f; 5246 } 5247 return __f; 5248 } 5249 return poisson_distribution<result_type>(gamma_distribution<double> 5250 (__k, (1-__p)/__p)(__urng))(__urng); 5251 } 5252 5253 template <class _CharT, class _Traits, class _IntType> 5254 basic_ostream<_CharT, _Traits>& 5255 operator<<(basic_ostream<_CharT, _Traits>& __os, 5256 const negative_binomial_distribution<_IntType>& __x) 5257 { 5258 __save_flags<_CharT, _Traits> __lx(__os); 5259 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5260 ios_base::scientific); 5261 _CharT __sp = __os.widen(' '); 5262 __os.fill(__sp); 5263 return __os << __x.k() << __sp << __x.p(); 5264 } 5265 5266 template <class _CharT, class _Traits, class _IntType> 5267 basic_istream<_CharT, _Traits>& 5268 operator>>(basic_istream<_CharT, _Traits>& __is, 5269 negative_binomial_distribution<_IntType>& __x) 5270 { 5271 typedef negative_binomial_distribution<_IntType> _Eng; 5272 typedef typename _Eng::result_type result_type; 5273 typedef typename _Eng::param_type param_type; 5274 __save_flags<_CharT, _Traits> __lx(__is); 5275 __is.flags(ios_base::dec | ios_base::skipws); 5276 result_type __k; 5277 double __p; 5278 __is >> __k >> __p; 5279 if (!__is.fail()) 5280 __x.param(param_type(__k, __p)); 5281 return __is; 5282 } 5283 5284 // geometric_distribution 5285 5286 template<class _IntType = int> 5287 class _LIBCPP_TEMPLATE_VIS geometric_distribution 5288 { 5289 public: 5290 // types 5291 typedef _IntType result_type; 5292 5293 class _LIBCPP_TEMPLATE_VIS param_type 5294 { 5295 double __p_; 5296 public: 5297 typedef geometric_distribution distribution_type; 5298 5299 _LIBCPP_INLINE_VISIBILITY 5300 explicit param_type(double __p = 0.5) : __p_(__p) {} 5301 5302 _LIBCPP_INLINE_VISIBILITY 5303 double p() const {return __p_;} 5304 5305 friend _LIBCPP_INLINE_VISIBILITY 5306 bool operator==(const param_type& __x, const param_type& __y) 5307 {return __x.__p_ == __y.__p_;} 5308 friend _LIBCPP_INLINE_VISIBILITY 5309 bool operator!=(const param_type& __x, const param_type& __y) 5310 {return !(__x == __y);} 5311 }; 5312 5313 private: 5314 param_type __p_; 5315 5316 public: 5317 // constructors and reset functions 5318 _LIBCPP_INLINE_VISIBILITY 5319 explicit geometric_distribution(double __p = 0.5) : __p_(__p) {} 5320 _LIBCPP_INLINE_VISIBILITY 5321 explicit geometric_distribution(const param_type& __p) : __p_(__p) {} 5322 _LIBCPP_INLINE_VISIBILITY 5323 void reset() {} 5324 5325 // generating functions 5326 template<class _URNG> 5327 _LIBCPP_INLINE_VISIBILITY 5328 result_type operator()(_URNG& __g) 5329 {return (*this)(__g, __p_);} 5330 template<class _URNG> 5331 _LIBCPP_INLINE_VISIBILITY 5332 result_type operator()(_URNG& __g, const param_type& __p) 5333 {return negative_binomial_distribution<result_type>(1, __p.p())(__g);} 5334 5335 // property functions 5336 _LIBCPP_INLINE_VISIBILITY 5337 double p() const {return __p_.p();} 5338 5339 _LIBCPP_INLINE_VISIBILITY 5340 param_type param() const {return __p_;} 5341 _LIBCPP_INLINE_VISIBILITY 5342 void param(const param_type& __p) {__p_ = __p;} 5343 5344 _LIBCPP_INLINE_VISIBILITY 5345 result_type min() const {return 0;} 5346 _LIBCPP_INLINE_VISIBILITY 5347 result_type max() const {return numeric_limits<result_type>::max();} 5348 5349 friend _LIBCPP_INLINE_VISIBILITY 5350 bool operator==(const geometric_distribution& __x, 5351 const geometric_distribution& __y) 5352 {return __x.__p_ == __y.__p_;} 5353 friend _LIBCPP_INLINE_VISIBILITY 5354 bool operator!=(const geometric_distribution& __x, 5355 const geometric_distribution& __y) 5356 {return !(__x == __y);} 5357 }; 5358 5359 template <class _CharT, class _Traits, class _IntType> 5360 basic_ostream<_CharT, _Traits>& 5361 operator<<(basic_ostream<_CharT, _Traits>& __os, 5362 const geometric_distribution<_IntType>& __x) 5363 { 5364 __save_flags<_CharT, _Traits> __lx(__os); 5365 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5366 ios_base::scientific); 5367 return __os << __x.p(); 5368 } 5369 5370 template <class _CharT, class _Traits, class _IntType> 5371 basic_istream<_CharT, _Traits>& 5372 operator>>(basic_istream<_CharT, _Traits>& __is, 5373 geometric_distribution<_IntType>& __x) 5374 { 5375 typedef geometric_distribution<_IntType> _Eng; 5376 typedef typename _Eng::param_type param_type; 5377 __save_flags<_CharT, _Traits> __lx(__is); 5378 __is.flags(ios_base::dec | ios_base::skipws); 5379 double __p; 5380 __is >> __p; 5381 if (!__is.fail()) 5382 __x.param(param_type(__p)); 5383 return __is; 5384 } 5385 5386 // chi_squared_distribution 5387 5388 template<class _RealType = double> 5389 class _LIBCPP_TEMPLATE_VIS chi_squared_distribution 5390 { 5391 public: 5392 // types 5393 typedef _RealType result_type; 5394 5395 class _LIBCPP_TEMPLATE_VIS param_type 5396 { 5397 result_type __n_; 5398 public: 5399 typedef chi_squared_distribution distribution_type; 5400 5401 _LIBCPP_INLINE_VISIBILITY 5402 explicit param_type(result_type __n = 1) : __n_(__n) {} 5403 5404 _LIBCPP_INLINE_VISIBILITY 5405 result_type n() const {return __n_;} 5406 5407 friend _LIBCPP_INLINE_VISIBILITY 5408 bool operator==(const param_type& __x, const param_type& __y) 5409 {return __x.__n_ == __y.__n_;} 5410 friend _LIBCPP_INLINE_VISIBILITY 5411 bool operator!=(const param_type& __x, const param_type& __y) 5412 {return !(__x == __y);} 5413 }; 5414 5415 private: 5416 param_type __p_; 5417 5418 public: 5419 // constructor and reset functions 5420 _LIBCPP_INLINE_VISIBILITY 5421 explicit chi_squared_distribution(result_type __n = 1) 5422 : __p_(param_type(__n)) {} 5423 _LIBCPP_INLINE_VISIBILITY 5424 explicit chi_squared_distribution(const param_type& __p) 5425 : __p_(__p) {} 5426 _LIBCPP_INLINE_VISIBILITY 5427 void reset() {} 5428 5429 // generating functions 5430 template<class _URNG> 5431 _LIBCPP_INLINE_VISIBILITY 5432 result_type operator()(_URNG& __g) 5433 {return (*this)(__g, __p_);} 5434 template<class _URNG> 5435 _LIBCPP_INLINE_VISIBILITY 5436 result_type operator()(_URNG& __g, const param_type& __p) 5437 {return gamma_distribution<result_type>(__p.n() / 2, 2)(__g);} 5438 5439 // property functions 5440 _LIBCPP_INLINE_VISIBILITY 5441 result_type n() const {return __p_.n();} 5442 5443 _LIBCPP_INLINE_VISIBILITY 5444 param_type param() const {return __p_;} 5445 _LIBCPP_INLINE_VISIBILITY 5446 void param(const param_type& __p) {__p_ = __p;} 5447 5448 _LIBCPP_INLINE_VISIBILITY 5449 result_type min() const {return 0;} 5450 _LIBCPP_INLINE_VISIBILITY 5451 result_type max() const {return numeric_limits<result_type>::infinity();} 5452 5453 friend _LIBCPP_INLINE_VISIBILITY 5454 bool operator==(const chi_squared_distribution& __x, 5455 const chi_squared_distribution& __y) 5456 {return __x.__p_ == __y.__p_;} 5457 friend _LIBCPP_INLINE_VISIBILITY 5458 bool operator!=(const chi_squared_distribution& __x, 5459 const chi_squared_distribution& __y) 5460 {return !(__x == __y);} 5461 }; 5462 5463 template <class _CharT, class _Traits, class _RT> 5464 basic_ostream<_CharT, _Traits>& 5465 operator<<(basic_ostream<_CharT, _Traits>& __os, 5466 const chi_squared_distribution<_RT>& __x) 5467 { 5468 __save_flags<_CharT, _Traits> __lx(__os); 5469 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5470 ios_base::scientific); 5471 __os << __x.n(); 5472 return __os; 5473 } 5474 5475 template <class _CharT, class _Traits, class _RT> 5476 basic_istream<_CharT, _Traits>& 5477 operator>>(basic_istream<_CharT, _Traits>& __is, 5478 chi_squared_distribution<_RT>& __x) 5479 { 5480 typedef chi_squared_distribution<_RT> _Eng; 5481 typedef typename _Eng::result_type result_type; 5482 typedef typename _Eng::param_type param_type; 5483 __save_flags<_CharT, _Traits> __lx(__is); 5484 __is.flags(ios_base::dec | ios_base::skipws); 5485 result_type __n; 5486 __is >> __n; 5487 if (!__is.fail()) 5488 __x.param(param_type(__n)); 5489 return __is; 5490 } 5491 5492 // cauchy_distribution 5493 5494 template<class _RealType = double> 5495 class _LIBCPP_TEMPLATE_VIS cauchy_distribution 5496 { 5497 public: 5498 // types 5499 typedef _RealType result_type; 5500 5501 class _LIBCPP_TEMPLATE_VIS param_type 5502 { 5503 result_type __a_; 5504 result_type __b_; 5505 public: 5506 typedef cauchy_distribution distribution_type; 5507 5508 _LIBCPP_INLINE_VISIBILITY 5509 explicit param_type(result_type __a = 0, result_type __b = 1) 5510 : __a_(__a), __b_(__b) {} 5511 5512 _LIBCPP_INLINE_VISIBILITY 5513 result_type a() const {return __a_;} 5514 _LIBCPP_INLINE_VISIBILITY 5515 result_type b() const {return __b_;} 5516 5517 friend _LIBCPP_INLINE_VISIBILITY 5518 bool operator==(const param_type& __x, const param_type& __y) 5519 {return __x.__a_ == __y.__a_ && __x.__b_ == __y.__b_;} 5520 friend _LIBCPP_INLINE_VISIBILITY 5521 bool operator!=(const param_type& __x, const param_type& __y) 5522 {return !(__x == __y);} 5523 }; 5524 5525 private: 5526 param_type __p_; 5527 5528 public: 5529 // constructor and reset functions 5530 _LIBCPP_INLINE_VISIBILITY 5531 explicit cauchy_distribution(result_type __a = 0, result_type __b = 1) 5532 : __p_(param_type(__a, __b)) {} 5533 _LIBCPP_INLINE_VISIBILITY 5534 explicit cauchy_distribution(const param_type& __p) 5535 : __p_(__p) {} 5536 _LIBCPP_INLINE_VISIBILITY 5537 void reset() {} 5538 5539 // generating functions 5540 template<class _URNG> 5541 _LIBCPP_INLINE_VISIBILITY 5542 result_type operator()(_URNG& __g) 5543 {return (*this)(__g, __p_);} 5544 template<class _URNG> _LIBCPP_INLINE_VISIBILITY result_type operator()(_URNG& __g, const param_type& __p); 5545 5546 // property functions 5547 _LIBCPP_INLINE_VISIBILITY 5548 result_type a() const {return __p_.a();} 5549 _LIBCPP_INLINE_VISIBILITY 5550 result_type b() const {return __p_.b();} 5551 5552 _LIBCPP_INLINE_VISIBILITY 5553 param_type param() const {return __p_;} 5554 _LIBCPP_INLINE_VISIBILITY 5555 void param(const param_type& __p) {__p_ = __p;} 5556 5557 _LIBCPP_INLINE_VISIBILITY 5558 result_type min() const {return -numeric_limits<result_type>::infinity();} 5559 _LIBCPP_INLINE_VISIBILITY 5560 result_type max() const {return numeric_limits<result_type>::infinity();} 5561 5562 friend _LIBCPP_INLINE_VISIBILITY 5563 bool operator==(const cauchy_distribution& __x, 5564 const cauchy_distribution& __y) 5565 {return __x.__p_ == __y.__p_;} 5566 friend _LIBCPP_INLINE_VISIBILITY 5567 bool operator!=(const cauchy_distribution& __x, 5568 const cauchy_distribution& __y) 5569 {return !(__x == __y);} 5570 }; 5571 5572 template <class _RealType> 5573 template<class _URNG> 5574 inline 5575 _RealType 5576 cauchy_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 5577 { 5578 uniform_real_distribution<result_type> __gen; 5579 // purposefully let tan arg get as close to pi/2 as it wants, tan will return a finite 5580 return __p.a() + __p.b() * _VSTD::tan(3.1415926535897932384626433832795 * __gen(__g)); 5581 } 5582 5583 template <class _CharT, class _Traits, class _RT> 5584 basic_ostream<_CharT, _Traits>& 5585 operator<<(basic_ostream<_CharT, _Traits>& __os, 5586 const cauchy_distribution<_RT>& __x) 5587 { 5588 __save_flags<_CharT, _Traits> __lx(__os); 5589 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5590 ios_base::scientific); 5591 _CharT __sp = __os.widen(' '); 5592 __os.fill(__sp); 5593 __os << __x.a() << __sp << __x.b(); 5594 return __os; 5595 } 5596 5597 template <class _CharT, class _Traits, class _RT> 5598 basic_istream<_CharT, _Traits>& 5599 operator>>(basic_istream<_CharT, _Traits>& __is, 5600 cauchy_distribution<_RT>& __x) 5601 { 5602 typedef cauchy_distribution<_RT> _Eng; 5603 typedef typename _Eng::result_type result_type; 5604 typedef typename _Eng::param_type param_type; 5605 __save_flags<_CharT, _Traits> __lx(__is); 5606 __is.flags(ios_base::dec | ios_base::skipws); 5607 result_type __a; 5608 result_type __b; 5609 __is >> __a >> __b; 5610 if (!__is.fail()) 5611 __x.param(param_type(__a, __b)); 5612 return __is; 5613 } 5614 5615 // fisher_f_distribution 5616 5617 template<class _RealType = double> 5618 class _LIBCPP_TEMPLATE_VIS fisher_f_distribution 5619 { 5620 public: 5621 // types 5622 typedef _RealType result_type; 5623 5624 class _LIBCPP_TEMPLATE_VIS param_type 5625 { 5626 result_type __m_; 5627 result_type __n_; 5628 public: 5629 typedef fisher_f_distribution distribution_type; 5630 5631 _LIBCPP_INLINE_VISIBILITY 5632 explicit param_type(result_type __m = 1, result_type __n = 1) 5633 : __m_(__m), __n_(__n) {} 5634 5635 _LIBCPP_INLINE_VISIBILITY 5636 result_type m() const {return __m_;} 5637 _LIBCPP_INLINE_VISIBILITY 5638 result_type n() const {return __n_;} 5639 5640 friend _LIBCPP_INLINE_VISIBILITY 5641 bool operator==(const param_type& __x, const param_type& __y) 5642 {return __x.__m_ == __y.__m_ && __x.__n_ == __y.__n_;} 5643 friend _LIBCPP_INLINE_VISIBILITY 5644 bool operator!=(const param_type& __x, const param_type& __y) 5645 {return !(__x == __y);} 5646 }; 5647 5648 private: 5649 param_type __p_; 5650 5651 public: 5652 // constructor and reset functions 5653 _LIBCPP_INLINE_VISIBILITY 5654 explicit fisher_f_distribution(result_type __m = 1, result_type __n = 1) 5655 : __p_(param_type(__m, __n)) {} 5656 _LIBCPP_INLINE_VISIBILITY 5657 explicit fisher_f_distribution(const param_type& __p) 5658 : __p_(__p) {} 5659 _LIBCPP_INLINE_VISIBILITY 5660 void reset() {} 5661 5662 // generating functions 5663 template<class _URNG> 5664 _LIBCPP_INLINE_VISIBILITY 5665 result_type operator()(_URNG& __g) 5666 {return (*this)(__g, __p_);} 5667 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 5668 5669 // property functions 5670 _LIBCPP_INLINE_VISIBILITY 5671 result_type m() const {return __p_.m();} 5672 _LIBCPP_INLINE_VISIBILITY 5673 result_type n() const {return __p_.n();} 5674 5675 _LIBCPP_INLINE_VISIBILITY 5676 param_type param() const {return __p_;} 5677 _LIBCPP_INLINE_VISIBILITY 5678 void param(const param_type& __p) {__p_ = __p;} 5679 5680 _LIBCPP_INLINE_VISIBILITY 5681 result_type min() const {return 0;} 5682 _LIBCPP_INLINE_VISIBILITY 5683 result_type max() const {return numeric_limits<result_type>::infinity();} 5684 5685 friend _LIBCPP_INLINE_VISIBILITY 5686 bool operator==(const fisher_f_distribution& __x, 5687 const fisher_f_distribution& __y) 5688 {return __x.__p_ == __y.__p_;} 5689 friend _LIBCPP_INLINE_VISIBILITY 5690 bool operator!=(const fisher_f_distribution& __x, 5691 const fisher_f_distribution& __y) 5692 {return !(__x == __y);} 5693 }; 5694 5695 template <class _RealType> 5696 template<class _URNG> 5697 _RealType 5698 fisher_f_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 5699 { 5700 gamma_distribution<result_type> __gdm(__p.m() * result_type(.5)); 5701 gamma_distribution<result_type> __gdn(__p.n() * result_type(.5)); 5702 return __p.n() * __gdm(__g) / (__p.m() * __gdn(__g)); 5703 } 5704 5705 template <class _CharT, class _Traits, class _RT> 5706 basic_ostream<_CharT, _Traits>& 5707 operator<<(basic_ostream<_CharT, _Traits>& __os, 5708 const fisher_f_distribution<_RT>& __x) 5709 { 5710 __save_flags<_CharT, _Traits> __lx(__os); 5711 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5712 ios_base::scientific); 5713 _CharT __sp = __os.widen(' '); 5714 __os.fill(__sp); 5715 __os << __x.m() << __sp << __x.n(); 5716 return __os; 5717 } 5718 5719 template <class _CharT, class _Traits, class _RT> 5720 basic_istream<_CharT, _Traits>& 5721 operator>>(basic_istream<_CharT, _Traits>& __is, 5722 fisher_f_distribution<_RT>& __x) 5723 { 5724 typedef fisher_f_distribution<_RT> _Eng; 5725 typedef typename _Eng::result_type result_type; 5726 typedef typename _Eng::param_type param_type; 5727 __save_flags<_CharT, _Traits> __lx(__is); 5728 __is.flags(ios_base::dec | ios_base::skipws); 5729 result_type __m; 5730 result_type __n; 5731 __is >> __m >> __n; 5732 if (!__is.fail()) 5733 __x.param(param_type(__m, __n)); 5734 return __is; 5735 } 5736 5737 // student_t_distribution 5738 5739 template<class _RealType = double> 5740 class _LIBCPP_TEMPLATE_VIS student_t_distribution 5741 { 5742 public: 5743 // types 5744 typedef _RealType result_type; 5745 5746 class _LIBCPP_TEMPLATE_VIS param_type 5747 { 5748 result_type __n_; 5749 public: 5750 typedef student_t_distribution distribution_type; 5751 5752 _LIBCPP_INLINE_VISIBILITY 5753 explicit param_type(result_type __n = 1) : __n_(__n) {} 5754 5755 _LIBCPP_INLINE_VISIBILITY 5756 result_type n() const {return __n_;} 5757 5758 friend _LIBCPP_INLINE_VISIBILITY 5759 bool operator==(const param_type& __x, const param_type& __y) 5760 {return __x.__n_ == __y.__n_;} 5761 friend _LIBCPP_INLINE_VISIBILITY 5762 bool operator!=(const param_type& __x, const param_type& __y) 5763 {return !(__x == __y);} 5764 }; 5765 5766 private: 5767 param_type __p_; 5768 normal_distribution<result_type> __nd_; 5769 5770 public: 5771 // constructor and reset functions 5772 _LIBCPP_INLINE_VISIBILITY 5773 explicit student_t_distribution(result_type __n = 1) 5774 : __p_(param_type(__n)) {} 5775 _LIBCPP_INLINE_VISIBILITY 5776 explicit student_t_distribution(const param_type& __p) 5777 : __p_(__p) {} 5778 _LIBCPP_INLINE_VISIBILITY 5779 void reset() {__nd_.reset();} 5780 5781 // generating functions 5782 template<class _URNG> 5783 _LIBCPP_INLINE_VISIBILITY 5784 result_type operator()(_URNG& __g) 5785 {return (*this)(__g, __p_);} 5786 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 5787 5788 // property functions 5789 _LIBCPP_INLINE_VISIBILITY 5790 result_type n() const {return __p_.n();} 5791 5792 _LIBCPP_INLINE_VISIBILITY 5793 param_type param() const {return __p_;} 5794 _LIBCPP_INLINE_VISIBILITY 5795 void param(const param_type& __p) {__p_ = __p;} 5796 5797 _LIBCPP_INLINE_VISIBILITY 5798 result_type min() const {return -numeric_limits<result_type>::infinity();} 5799 _LIBCPP_INLINE_VISIBILITY 5800 result_type max() const {return numeric_limits<result_type>::infinity();} 5801 5802 friend _LIBCPP_INLINE_VISIBILITY 5803 bool operator==(const student_t_distribution& __x, 5804 const student_t_distribution& __y) 5805 {return __x.__p_ == __y.__p_;} 5806 friend _LIBCPP_INLINE_VISIBILITY 5807 bool operator!=(const student_t_distribution& __x, 5808 const student_t_distribution& __y) 5809 {return !(__x == __y);} 5810 }; 5811 5812 template <class _RealType> 5813 template<class _URNG> 5814 _RealType 5815 student_t_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 5816 { 5817 gamma_distribution<result_type> __gd(__p.n() * .5, 2); 5818 return __nd_(__g) * _VSTD::sqrt(__p.n()/__gd(__g)); 5819 } 5820 5821 template <class _CharT, class _Traits, class _RT> 5822 basic_ostream<_CharT, _Traits>& 5823 operator<<(basic_ostream<_CharT, _Traits>& __os, 5824 const student_t_distribution<_RT>& __x) 5825 { 5826 __save_flags<_CharT, _Traits> __lx(__os); 5827 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 5828 ios_base::scientific); 5829 __os << __x.n(); 5830 return __os; 5831 } 5832 5833 template <class _CharT, class _Traits, class _RT> 5834 basic_istream<_CharT, _Traits>& 5835 operator>>(basic_istream<_CharT, _Traits>& __is, 5836 student_t_distribution<_RT>& __x) 5837 { 5838 typedef student_t_distribution<_RT> _Eng; 5839 typedef typename _Eng::result_type result_type; 5840 typedef typename _Eng::param_type param_type; 5841 __save_flags<_CharT, _Traits> __lx(__is); 5842 __is.flags(ios_base::dec | ios_base::skipws); 5843 result_type __n; 5844 __is >> __n; 5845 if (!__is.fail()) 5846 __x.param(param_type(__n)); 5847 return __is; 5848 } 5849 5850 // discrete_distribution 5851 5852 template<class _IntType = int> 5853 class _LIBCPP_TEMPLATE_VIS discrete_distribution 5854 { 5855 public: 5856 // types 5857 typedef _IntType result_type; 5858 5859 class _LIBCPP_TEMPLATE_VIS param_type 5860 { 5861 vector<double> __p_; 5862 public: 5863 typedef discrete_distribution distribution_type; 5864 5865 _LIBCPP_INLINE_VISIBILITY 5866 param_type() {} 5867 template<class _InputIterator> 5868 _LIBCPP_INLINE_VISIBILITY 5869 param_type(_InputIterator __f, _InputIterator __l) 5870 : __p_(__f, __l) {__init();} 5871 #ifndef _LIBCPP_CXX03_LANG 5872 _LIBCPP_INLINE_VISIBILITY 5873 param_type(initializer_list<double> __wl) 5874 : __p_(__wl.begin(), __wl.end()) {__init();} 5875 #endif // _LIBCPP_CXX03_LANG 5876 template<class _UnaryOperation> 5877 param_type(size_t __nw, double __xmin, double __xmax, 5878 _UnaryOperation __fw); 5879 5880 vector<double> probabilities() const; 5881 5882 friend _LIBCPP_INLINE_VISIBILITY 5883 bool operator==(const param_type& __x, const param_type& __y) 5884 {return __x.__p_ == __y.__p_;} 5885 friend _LIBCPP_INLINE_VISIBILITY 5886 bool operator!=(const param_type& __x, const param_type& __y) 5887 {return !(__x == __y);} 5888 5889 private: 5890 void __init(); 5891 5892 friend class discrete_distribution; 5893 5894 template <class _CharT, class _Traits, class _IT> 5895 friend 5896 basic_ostream<_CharT, _Traits>& 5897 operator<<(basic_ostream<_CharT, _Traits>& __os, 5898 const discrete_distribution<_IT>& __x); 5899 5900 template <class _CharT, class _Traits, class _IT> 5901 friend 5902 basic_istream<_CharT, _Traits>& 5903 operator>>(basic_istream<_CharT, _Traits>& __is, 5904 discrete_distribution<_IT>& __x); 5905 }; 5906 5907 private: 5908 param_type __p_; 5909 5910 public: 5911 // constructor and reset functions 5912 _LIBCPP_INLINE_VISIBILITY 5913 discrete_distribution() {} 5914 template<class _InputIterator> 5915 _LIBCPP_INLINE_VISIBILITY 5916 discrete_distribution(_InputIterator __f, _InputIterator __l) 5917 : __p_(__f, __l) {} 5918 #ifndef _LIBCPP_CXX03_LANG 5919 _LIBCPP_INLINE_VISIBILITY 5920 discrete_distribution(initializer_list<double> __wl) 5921 : __p_(__wl) {} 5922 #endif // _LIBCPP_CXX03_LANG 5923 template<class _UnaryOperation> 5924 _LIBCPP_INLINE_VISIBILITY 5925 discrete_distribution(size_t __nw, double __xmin, double __xmax, 5926 _UnaryOperation __fw) 5927 : __p_(__nw, __xmin, __xmax, __fw) {} 5928 _LIBCPP_INLINE_VISIBILITY 5929 explicit discrete_distribution(const param_type& __p) 5930 : __p_(__p) {} 5931 _LIBCPP_INLINE_VISIBILITY 5932 void reset() {} 5933 5934 // generating functions 5935 template<class _URNG> 5936 _LIBCPP_INLINE_VISIBILITY 5937 result_type operator()(_URNG& __g) 5938 {return (*this)(__g, __p_);} 5939 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 5940 5941 // property functions 5942 _LIBCPP_INLINE_VISIBILITY 5943 vector<double> probabilities() const {return __p_.probabilities();} 5944 5945 _LIBCPP_INLINE_VISIBILITY 5946 param_type param() const {return __p_;} 5947 _LIBCPP_INLINE_VISIBILITY 5948 void param(const param_type& __p) {__p_ = __p;} 5949 5950 _LIBCPP_INLINE_VISIBILITY 5951 result_type min() const {return 0;} 5952 _LIBCPP_INLINE_VISIBILITY 5953 result_type max() const {return __p_.__p_.size();} 5954 5955 friend _LIBCPP_INLINE_VISIBILITY 5956 bool operator==(const discrete_distribution& __x, 5957 const discrete_distribution& __y) 5958 {return __x.__p_ == __y.__p_;} 5959 friend _LIBCPP_INLINE_VISIBILITY 5960 bool operator!=(const discrete_distribution& __x, 5961 const discrete_distribution& __y) 5962 {return !(__x == __y);} 5963 5964 template <class _CharT, class _Traits, class _IT> 5965 friend 5966 basic_ostream<_CharT, _Traits>& 5967 operator<<(basic_ostream<_CharT, _Traits>& __os, 5968 const discrete_distribution<_IT>& __x); 5969 5970 template <class _CharT, class _Traits, class _IT> 5971 friend 5972 basic_istream<_CharT, _Traits>& 5973 operator>>(basic_istream<_CharT, _Traits>& __is, 5974 discrete_distribution<_IT>& __x); 5975 }; 5976 5977 template<class _IntType> 5978 template<class _UnaryOperation> 5979 discrete_distribution<_IntType>::param_type::param_type(size_t __nw, 5980 double __xmin, 5981 double __xmax, 5982 _UnaryOperation __fw) 5983 { 5984 if (__nw > 1) 5985 { 5986 __p_.reserve(__nw - 1); 5987 double __d = (__xmax - __xmin) / __nw; 5988 double __d2 = __d / 2; 5989 for (size_t __k = 0; __k < __nw; ++__k) 5990 __p_.push_back(__fw(__xmin + __k * __d + __d2)); 5991 __init(); 5992 } 5993 } 5994 5995 template<class _IntType> 5996 void 5997 discrete_distribution<_IntType>::param_type::__init() 5998 { 5999 if (!__p_.empty()) 6000 { 6001 if (__p_.size() > 1) 6002 { 6003 double __s = _VSTD::accumulate(__p_.begin(), __p_.end(), 0.0); 6004 for (_VSTD::vector<double>::iterator __i = __p_.begin(), __e = __p_.end(); 6005 __i < __e; ++__i) 6006 *__i /= __s; 6007 vector<double> __t(__p_.size() - 1); 6008 _VSTD::partial_sum(__p_.begin(), __p_.end() - 1, __t.begin()); 6009 swap(__p_, __t); 6010 } 6011 else 6012 { 6013 __p_.clear(); 6014 __p_.shrink_to_fit(); 6015 } 6016 } 6017 } 6018 6019 template<class _IntType> 6020 vector<double> 6021 discrete_distribution<_IntType>::param_type::probabilities() const 6022 { 6023 size_t __n = __p_.size(); 6024 _VSTD::vector<double> __p(__n+1); 6025 _VSTD::adjacent_difference(__p_.begin(), __p_.end(), __p.begin()); 6026 if (__n > 0) 6027 __p[__n] = 1 - __p_[__n-1]; 6028 else 6029 __p[0] = 1; 6030 return __p; 6031 } 6032 6033 template<class _IntType> 6034 template<class _URNG> 6035 _IntType 6036 discrete_distribution<_IntType>::operator()(_URNG& __g, const param_type& __p) 6037 { 6038 uniform_real_distribution<double> __gen; 6039 return static_cast<_IntType>( 6040 _VSTD::upper_bound(__p.__p_.begin(), __p.__p_.end(), __gen(__g)) - 6041 __p.__p_.begin()); 6042 } 6043 6044 template <class _CharT, class _Traits, class _IT> 6045 basic_ostream<_CharT, _Traits>& 6046 operator<<(basic_ostream<_CharT, _Traits>& __os, 6047 const discrete_distribution<_IT>& __x) 6048 { 6049 __save_flags<_CharT, _Traits> __lx(__os); 6050 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 6051 ios_base::scientific); 6052 _CharT __sp = __os.widen(' '); 6053 __os.fill(__sp); 6054 size_t __n = __x.__p_.__p_.size(); 6055 __os << __n; 6056 for (size_t __i = 0; __i < __n; ++__i) 6057 __os << __sp << __x.__p_.__p_[__i]; 6058 return __os; 6059 } 6060 6061 template <class _CharT, class _Traits, class _IT> 6062 basic_istream<_CharT, _Traits>& 6063 operator>>(basic_istream<_CharT, _Traits>& __is, 6064 discrete_distribution<_IT>& __x) 6065 { 6066 __save_flags<_CharT, _Traits> __lx(__is); 6067 __is.flags(ios_base::dec | ios_base::skipws); 6068 size_t __n; 6069 __is >> __n; 6070 vector<double> __p(__n); 6071 for (size_t __i = 0; __i < __n; ++__i) 6072 __is >> __p[__i]; 6073 if (!__is.fail()) 6074 swap(__x.__p_.__p_, __p); 6075 return __is; 6076 } 6077 6078 // piecewise_constant_distribution 6079 6080 template<class _RealType = double> 6081 class _LIBCPP_TEMPLATE_VIS piecewise_constant_distribution 6082 { 6083 public: 6084 // types 6085 typedef _RealType result_type; 6086 6087 class _LIBCPP_TEMPLATE_VIS param_type 6088 { 6089 vector<result_type> __b_; 6090 vector<result_type> __densities_; 6091 vector<result_type> __areas_; 6092 public: 6093 typedef piecewise_constant_distribution distribution_type; 6094 6095 param_type(); 6096 template<class _InputIteratorB, class _InputIteratorW> 6097 param_type(_InputIteratorB __fB, _InputIteratorB __lB, 6098 _InputIteratorW __fW); 6099 #ifndef _LIBCPP_CXX03_LANG 6100 template<class _UnaryOperation> 6101 param_type(initializer_list<result_type> __bl, _UnaryOperation __fw); 6102 #endif // _LIBCPP_CXX03_LANG 6103 template<class _UnaryOperation> 6104 param_type(size_t __nw, result_type __xmin, result_type __xmax, 6105 _UnaryOperation __fw); 6106 param_type & operator=(const param_type& __rhs); 6107 6108 _LIBCPP_INLINE_VISIBILITY 6109 vector<result_type> intervals() const {return __b_;} 6110 _LIBCPP_INLINE_VISIBILITY 6111 vector<result_type> densities() const {return __densities_;} 6112 6113 friend _LIBCPP_INLINE_VISIBILITY 6114 bool operator==(const param_type& __x, const param_type& __y) 6115 {return __x.__densities_ == __y.__densities_ && __x.__b_ == __y.__b_;} 6116 friend _LIBCPP_INLINE_VISIBILITY 6117 bool operator!=(const param_type& __x, const param_type& __y) 6118 {return !(__x == __y);} 6119 6120 private: 6121 void __init(); 6122 6123 friend class piecewise_constant_distribution; 6124 6125 template <class _CharT, class _Traits, class _RT> 6126 friend 6127 basic_ostream<_CharT, _Traits>& 6128 operator<<(basic_ostream<_CharT, _Traits>& __os, 6129 const piecewise_constant_distribution<_RT>& __x); 6130 6131 template <class _CharT, class _Traits, class _RT> 6132 friend 6133 basic_istream<_CharT, _Traits>& 6134 operator>>(basic_istream<_CharT, _Traits>& __is, 6135 piecewise_constant_distribution<_RT>& __x); 6136 }; 6137 6138 private: 6139 param_type __p_; 6140 6141 public: 6142 // constructor and reset functions 6143 _LIBCPP_INLINE_VISIBILITY 6144 piecewise_constant_distribution() {} 6145 template<class _InputIteratorB, class _InputIteratorW> 6146 _LIBCPP_INLINE_VISIBILITY 6147 piecewise_constant_distribution(_InputIteratorB __fB, 6148 _InputIteratorB __lB, 6149 _InputIteratorW __fW) 6150 : __p_(__fB, __lB, __fW) {} 6151 6152 #ifndef _LIBCPP_CXX03_LANG 6153 template<class _UnaryOperation> 6154 _LIBCPP_INLINE_VISIBILITY 6155 piecewise_constant_distribution(initializer_list<result_type> __bl, 6156 _UnaryOperation __fw) 6157 : __p_(__bl, __fw) {} 6158 #endif // _LIBCPP_CXX03_LANG 6159 6160 template<class _UnaryOperation> 6161 _LIBCPP_INLINE_VISIBILITY 6162 piecewise_constant_distribution(size_t __nw, result_type __xmin, 6163 result_type __xmax, _UnaryOperation __fw) 6164 : __p_(__nw, __xmin, __xmax, __fw) {} 6165 6166 _LIBCPP_INLINE_VISIBILITY 6167 explicit piecewise_constant_distribution(const param_type& __p) 6168 : __p_(__p) {} 6169 6170 _LIBCPP_INLINE_VISIBILITY 6171 void reset() {} 6172 6173 // generating functions 6174 template<class _URNG> 6175 _LIBCPP_INLINE_VISIBILITY 6176 result_type operator()(_URNG& __g) 6177 {return (*this)(__g, __p_);} 6178 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 6179 6180 // property functions 6181 _LIBCPP_INLINE_VISIBILITY 6182 vector<result_type> intervals() const {return __p_.intervals();} 6183 _LIBCPP_INLINE_VISIBILITY 6184 vector<result_type> densities() const {return __p_.densities();} 6185 6186 _LIBCPP_INLINE_VISIBILITY 6187 param_type param() const {return __p_;} 6188 _LIBCPP_INLINE_VISIBILITY 6189 void param(const param_type& __p) {__p_ = __p;} 6190 6191 _LIBCPP_INLINE_VISIBILITY 6192 result_type min() const {return __p_.__b_.front();} 6193 _LIBCPP_INLINE_VISIBILITY 6194 result_type max() const {return __p_.__b_.back();} 6195 6196 friend _LIBCPP_INLINE_VISIBILITY 6197 bool operator==(const piecewise_constant_distribution& __x, 6198 const piecewise_constant_distribution& __y) 6199 {return __x.__p_ == __y.__p_;} 6200 friend _LIBCPP_INLINE_VISIBILITY 6201 bool operator!=(const piecewise_constant_distribution& __x, 6202 const piecewise_constant_distribution& __y) 6203 {return !(__x == __y);} 6204 6205 template <class _CharT, class _Traits, class _RT> 6206 friend 6207 basic_ostream<_CharT, _Traits>& 6208 operator<<(basic_ostream<_CharT, _Traits>& __os, 6209 const piecewise_constant_distribution<_RT>& __x); 6210 6211 template <class _CharT, class _Traits, class _RT> 6212 friend 6213 basic_istream<_CharT, _Traits>& 6214 operator>>(basic_istream<_CharT, _Traits>& __is, 6215 piecewise_constant_distribution<_RT>& __x); 6216 }; 6217 6218 template<class _RealType> 6219 typename piecewise_constant_distribution<_RealType>::param_type & 6220 piecewise_constant_distribution<_RealType>::param_type::operator= 6221 (const param_type& __rhs) 6222 { 6223 // These can throw 6224 __b_.reserve (__rhs.__b_.size ()); 6225 __densities_.reserve(__rhs.__densities_.size()); 6226 __areas_.reserve (__rhs.__areas_.size()); 6227 6228 // These can not throw 6229 __b_ = __rhs.__b_; 6230 __densities_ = __rhs.__densities_; 6231 __areas_ = __rhs.__areas_; 6232 return *this; 6233 } 6234 6235 template<class _RealType> 6236 void 6237 piecewise_constant_distribution<_RealType>::param_type::__init() 6238 { 6239 // __densities_ contains non-normalized areas 6240 result_type __total_area = _VSTD::accumulate(__densities_.begin(), 6241 __densities_.end(), 6242 result_type()); 6243 for (size_t __i = 0; __i < __densities_.size(); ++__i) 6244 __densities_[__i] /= __total_area; 6245 // __densities_ contains normalized areas 6246 __areas_.assign(__densities_.size(), result_type()); 6247 _VSTD::partial_sum(__densities_.begin(), __densities_.end() - 1, 6248 __areas_.begin() + 1); 6249 // __areas_ contains partial sums of normalized areas: [0, __densities_ - 1] 6250 __densities_.back() = 1 - __areas_.back(); // correct round off error 6251 for (size_t __i = 0; __i < __densities_.size(); ++__i) 6252 __densities_[__i] /= (__b_[__i+1] - __b_[__i]); 6253 // __densities_ now contains __densities_ 6254 } 6255 6256 template<class _RealType> 6257 piecewise_constant_distribution<_RealType>::param_type::param_type() 6258 : __b_(2), 6259 __densities_(1, 1.0), 6260 __areas_(1, 0.0) 6261 { 6262 __b_[1] = 1; 6263 } 6264 6265 template<class _RealType> 6266 template<class _InputIteratorB, class _InputIteratorW> 6267 piecewise_constant_distribution<_RealType>::param_type::param_type( 6268 _InputIteratorB __fB, _InputIteratorB __lB, _InputIteratorW __fW) 6269 : __b_(__fB, __lB) 6270 { 6271 if (__b_.size() < 2) 6272 { 6273 __b_.resize(2); 6274 __b_[0] = 0; 6275 __b_[1] = 1; 6276 __densities_.assign(1, 1.0); 6277 __areas_.assign(1, 0.0); 6278 } 6279 else 6280 { 6281 __densities_.reserve(__b_.size() - 1); 6282 for (size_t __i = 0; __i < __b_.size() - 1; ++__i, ++__fW) 6283 __densities_.push_back(*__fW); 6284 __init(); 6285 } 6286 } 6287 6288 #ifndef _LIBCPP_CXX03_LANG 6289 6290 template<class _RealType> 6291 template<class _UnaryOperation> 6292 piecewise_constant_distribution<_RealType>::param_type::param_type( 6293 initializer_list<result_type> __bl, _UnaryOperation __fw) 6294 : __b_(__bl.begin(), __bl.end()) 6295 { 6296 if (__b_.size() < 2) 6297 { 6298 __b_.resize(2); 6299 __b_[0] = 0; 6300 __b_[1] = 1; 6301 __densities_.assign(1, 1.0); 6302 __areas_.assign(1, 0.0); 6303 } 6304 else 6305 { 6306 __densities_.reserve(__b_.size() - 1); 6307 for (size_t __i = 0; __i < __b_.size() - 1; ++__i) 6308 __densities_.push_back(__fw((__b_[__i+1] + __b_[__i])*.5)); 6309 __init(); 6310 } 6311 } 6312 6313 #endif // _LIBCPP_CXX03_LANG 6314 6315 template<class _RealType> 6316 template<class _UnaryOperation> 6317 piecewise_constant_distribution<_RealType>::param_type::param_type( 6318 size_t __nw, result_type __xmin, result_type __xmax, _UnaryOperation __fw) 6319 : __b_(__nw == 0 ? 2 : __nw + 1) 6320 { 6321 size_t __n = __b_.size() - 1; 6322 result_type __d = (__xmax - __xmin) / __n; 6323 __densities_.reserve(__n); 6324 for (size_t __i = 0; __i < __n; ++__i) 6325 { 6326 __b_[__i] = __xmin + __i * __d; 6327 __densities_.push_back(__fw(__b_[__i] + __d*.5)); 6328 } 6329 __b_[__n] = __xmax; 6330 __init(); 6331 } 6332 6333 template<class _RealType> 6334 template<class _URNG> 6335 _RealType 6336 piecewise_constant_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 6337 { 6338 typedef uniform_real_distribution<result_type> _Gen; 6339 result_type __u = _Gen()(__g); 6340 ptrdiff_t __k = _VSTD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), 6341 __u) - __p.__areas_.begin() - 1; 6342 return (__u - __p.__areas_[__k]) / __p.__densities_[__k] + __p.__b_[__k]; 6343 } 6344 6345 template <class _CharT, class _Traits, class _RT> 6346 basic_ostream<_CharT, _Traits>& 6347 operator<<(basic_ostream<_CharT, _Traits>& __os, 6348 const piecewise_constant_distribution<_RT>& __x) 6349 { 6350 __save_flags<_CharT, _Traits> __lx(__os); 6351 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 6352 ios_base::scientific); 6353 _CharT __sp = __os.widen(' '); 6354 __os.fill(__sp); 6355 size_t __n = __x.__p_.__b_.size(); 6356 __os << __n; 6357 for (size_t __i = 0; __i < __n; ++__i) 6358 __os << __sp << __x.__p_.__b_[__i]; 6359 __n = __x.__p_.__densities_.size(); 6360 __os << __sp << __n; 6361 for (size_t __i = 0; __i < __n; ++__i) 6362 __os << __sp << __x.__p_.__densities_[__i]; 6363 __n = __x.__p_.__areas_.size(); 6364 __os << __sp << __n; 6365 for (size_t __i = 0; __i < __n; ++__i) 6366 __os << __sp << __x.__p_.__areas_[__i]; 6367 return __os; 6368 } 6369 6370 template <class _CharT, class _Traits, class _RT> 6371 basic_istream<_CharT, _Traits>& 6372 operator>>(basic_istream<_CharT, _Traits>& __is, 6373 piecewise_constant_distribution<_RT>& __x) 6374 { 6375 typedef piecewise_constant_distribution<_RT> _Eng; 6376 typedef typename _Eng::result_type result_type; 6377 __save_flags<_CharT, _Traits> __lx(__is); 6378 __is.flags(ios_base::dec | ios_base::skipws); 6379 size_t __n; 6380 __is >> __n; 6381 vector<result_type> __b(__n); 6382 for (size_t __i = 0; __i < __n; ++__i) 6383 __is >> __b[__i]; 6384 __is >> __n; 6385 vector<result_type> __densities(__n); 6386 for (size_t __i = 0; __i < __n; ++__i) 6387 __is >> __densities[__i]; 6388 __is >> __n; 6389 vector<result_type> __areas(__n); 6390 for (size_t __i = 0; __i < __n; ++__i) 6391 __is >> __areas[__i]; 6392 if (!__is.fail()) 6393 { 6394 swap(__x.__p_.__b_, __b); 6395 swap(__x.__p_.__densities_, __densities); 6396 swap(__x.__p_.__areas_, __areas); 6397 } 6398 return __is; 6399 } 6400 6401 // piecewise_linear_distribution 6402 6403 template<class _RealType = double> 6404 class _LIBCPP_TEMPLATE_VIS piecewise_linear_distribution 6405 { 6406 public: 6407 // types 6408 typedef _RealType result_type; 6409 6410 class _LIBCPP_TEMPLATE_VIS param_type 6411 { 6412 vector<result_type> __b_; 6413 vector<result_type> __densities_; 6414 vector<result_type> __areas_; 6415 public: 6416 typedef piecewise_linear_distribution distribution_type; 6417 6418 param_type(); 6419 template<class _InputIteratorB, class _InputIteratorW> 6420 param_type(_InputIteratorB __fB, _InputIteratorB __lB, 6421 _InputIteratorW __fW); 6422 #ifndef _LIBCPP_CXX03_LANG 6423 template<class _UnaryOperation> 6424 param_type(initializer_list<result_type> __bl, _UnaryOperation __fw); 6425 #endif // _LIBCPP_CXX03_LANG 6426 template<class _UnaryOperation> 6427 param_type(size_t __nw, result_type __xmin, result_type __xmax, 6428 _UnaryOperation __fw); 6429 param_type & operator=(const param_type& __rhs); 6430 6431 _LIBCPP_INLINE_VISIBILITY 6432 vector<result_type> intervals() const {return __b_;} 6433 _LIBCPP_INLINE_VISIBILITY 6434 vector<result_type> densities() const {return __densities_;} 6435 6436 friend _LIBCPP_INLINE_VISIBILITY 6437 bool operator==(const param_type& __x, const param_type& __y) 6438 {return __x.__densities_ == __y.__densities_ && __x.__b_ == __y.__b_;} 6439 friend _LIBCPP_INLINE_VISIBILITY 6440 bool operator!=(const param_type& __x, const param_type& __y) 6441 {return !(__x == __y);} 6442 6443 private: 6444 void __init(); 6445 6446 friend class piecewise_linear_distribution; 6447 6448 template <class _CharT, class _Traits, class _RT> 6449 friend 6450 basic_ostream<_CharT, _Traits>& 6451 operator<<(basic_ostream<_CharT, _Traits>& __os, 6452 const piecewise_linear_distribution<_RT>& __x); 6453 6454 template <class _CharT, class _Traits, class _RT> 6455 friend 6456 basic_istream<_CharT, _Traits>& 6457 operator>>(basic_istream<_CharT, _Traits>& __is, 6458 piecewise_linear_distribution<_RT>& __x); 6459 }; 6460 6461 private: 6462 param_type __p_; 6463 6464 public: 6465 // constructor and reset functions 6466 _LIBCPP_INLINE_VISIBILITY 6467 piecewise_linear_distribution() {} 6468 template<class _InputIteratorB, class _InputIteratorW> 6469 _LIBCPP_INLINE_VISIBILITY 6470 piecewise_linear_distribution(_InputIteratorB __fB, 6471 _InputIteratorB __lB, 6472 _InputIteratorW __fW) 6473 : __p_(__fB, __lB, __fW) {} 6474 6475 #ifndef _LIBCPP_CXX03_LANG 6476 template<class _UnaryOperation> 6477 _LIBCPP_INLINE_VISIBILITY 6478 piecewise_linear_distribution(initializer_list<result_type> __bl, 6479 _UnaryOperation __fw) 6480 : __p_(__bl, __fw) {} 6481 #endif // _LIBCPP_CXX03_LANG 6482 6483 template<class _UnaryOperation> 6484 _LIBCPP_INLINE_VISIBILITY 6485 piecewise_linear_distribution(size_t __nw, result_type __xmin, 6486 result_type __xmax, _UnaryOperation __fw) 6487 : __p_(__nw, __xmin, __xmax, __fw) {} 6488 6489 _LIBCPP_INLINE_VISIBILITY 6490 explicit piecewise_linear_distribution(const param_type& __p) 6491 : __p_(__p) {} 6492 6493 _LIBCPP_INLINE_VISIBILITY 6494 void reset() {} 6495 6496 // generating functions 6497 template<class _URNG> 6498 _LIBCPP_INLINE_VISIBILITY 6499 result_type operator()(_URNG& __g) 6500 {return (*this)(__g, __p_);} 6501 template<class _URNG> result_type operator()(_URNG& __g, const param_type& __p); 6502 6503 // property functions 6504 _LIBCPP_INLINE_VISIBILITY 6505 vector<result_type> intervals() const {return __p_.intervals();} 6506 _LIBCPP_INLINE_VISIBILITY 6507 vector<result_type> densities() const {return __p_.densities();} 6508 6509 _LIBCPP_INLINE_VISIBILITY 6510 param_type param() const {return __p_;} 6511 _LIBCPP_INLINE_VISIBILITY 6512 void param(const param_type& __p) {__p_ = __p;} 6513 6514 _LIBCPP_INLINE_VISIBILITY 6515 result_type min() const {return __p_.__b_.front();} 6516 _LIBCPP_INLINE_VISIBILITY 6517 result_type max() const {return __p_.__b_.back();} 6518 6519 friend _LIBCPP_INLINE_VISIBILITY 6520 bool operator==(const piecewise_linear_distribution& __x, 6521 const piecewise_linear_distribution& __y) 6522 {return __x.__p_ == __y.__p_;} 6523 friend _LIBCPP_INLINE_VISIBILITY 6524 bool operator!=(const piecewise_linear_distribution& __x, 6525 const piecewise_linear_distribution& __y) 6526 {return !(__x == __y);} 6527 6528 template <class _CharT, class _Traits, class _RT> 6529 friend 6530 basic_ostream<_CharT, _Traits>& 6531 operator<<(basic_ostream<_CharT, _Traits>& __os, 6532 const piecewise_linear_distribution<_RT>& __x); 6533 6534 template <class _CharT, class _Traits, class _RT> 6535 friend 6536 basic_istream<_CharT, _Traits>& 6537 operator>>(basic_istream<_CharT, _Traits>& __is, 6538 piecewise_linear_distribution<_RT>& __x); 6539 }; 6540 6541 template<class _RealType> 6542 typename piecewise_linear_distribution<_RealType>::param_type & 6543 piecewise_linear_distribution<_RealType>::param_type::operator= 6544 (const param_type& __rhs) 6545 { 6546 // These can throw 6547 __b_.reserve (__rhs.__b_.size ()); 6548 __densities_.reserve(__rhs.__densities_.size()); 6549 __areas_.reserve (__rhs.__areas_.size()); 6550 6551 // These can not throw 6552 __b_ = __rhs.__b_; 6553 __densities_ = __rhs.__densities_; 6554 __areas_ = __rhs.__areas_; 6555 return *this; 6556 } 6557 6558 6559 template<class _RealType> 6560 void 6561 piecewise_linear_distribution<_RealType>::param_type::__init() 6562 { 6563 __areas_.assign(__densities_.size() - 1, result_type()); 6564 result_type _Sp = 0; 6565 for (size_t __i = 0; __i < __areas_.size(); ++__i) 6566 { 6567 __areas_[__i] = (__densities_[__i+1] + __densities_[__i]) * 6568 (__b_[__i+1] - __b_[__i]) * .5; 6569 _Sp += __areas_[__i]; 6570 } 6571 for (size_t __i = __areas_.size(); __i > 1;) 6572 { 6573 --__i; 6574 __areas_[__i] = __areas_[__i-1] / _Sp; 6575 } 6576 __areas_[0] = 0; 6577 for (size_t __i = 1; __i < __areas_.size(); ++__i) 6578 __areas_[__i] += __areas_[__i-1]; 6579 for (size_t __i = 0; __i < __densities_.size(); ++__i) 6580 __densities_[__i] /= _Sp; 6581 } 6582 6583 template<class _RealType> 6584 piecewise_linear_distribution<_RealType>::param_type::param_type() 6585 : __b_(2), 6586 __densities_(2, 1.0), 6587 __areas_(1, 0.0) 6588 { 6589 __b_[1] = 1; 6590 } 6591 6592 template<class _RealType> 6593 template<class _InputIteratorB, class _InputIteratorW> 6594 piecewise_linear_distribution<_RealType>::param_type::param_type( 6595 _InputIteratorB __fB, _InputIteratorB __lB, _InputIteratorW __fW) 6596 : __b_(__fB, __lB) 6597 { 6598 if (__b_.size() < 2) 6599 { 6600 __b_.resize(2); 6601 __b_[0] = 0; 6602 __b_[1] = 1; 6603 __densities_.assign(2, 1.0); 6604 __areas_.assign(1, 0.0); 6605 } 6606 else 6607 { 6608 __densities_.reserve(__b_.size()); 6609 for (size_t __i = 0; __i < __b_.size(); ++__i, ++__fW) 6610 __densities_.push_back(*__fW); 6611 __init(); 6612 } 6613 } 6614 6615 #ifndef _LIBCPP_CXX03_LANG 6616 6617 template<class _RealType> 6618 template<class _UnaryOperation> 6619 piecewise_linear_distribution<_RealType>::param_type::param_type( 6620 initializer_list<result_type> __bl, _UnaryOperation __fw) 6621 : __b_(__bl.begin(), __bl.end()) 6622 { 6623 if (__b_.size() < 2) 6624 { 6625 __b_.resize(2); 6626 __b_[0] = 0; 6627 __b_[1] = 1; 6628 __densities_.assign(2, 1.0); 6629 __areas_.assign(1, 0.0); 6630 } 6631 else 6632 { 6633 __densities_.reserve(__b_.size()); 6634 for (size_t __i = 0; __i < __b_.size(); ++__i) 6635 __densities_.push_back(__fw(__b_[__i])); 6636 __init(); 6637 } 6638 } 6639 6640 #endif // _LIBCPP_CXX03_LANG 6641 6642 template<class _RealType> 6643 template<class _UnaryOperation> 6644 piecewise_linear_distribution<_RealType>::param_type::param_type( 6645 size_t __nw, result_type __xmin, result_type __xmax, _UnaryOperation __fw) 6646 : __b_(__nw == 0 ? 2 : __nw + 1) 6647 { 6648 size_t __n = __b_.size() - 1; 6649 result_type __d = (__xmax - __xmin) / __n; 6650 __densities_.reserve(__b_.size()); 6651 for (size_t __i = 0; __i < __n; ++__i) 6652 { 6653 __b_[__i] = __xmin + __i * __d; 6654 __densities_.push_back(__fw(__b_[__i])); 6655 } 6656 __b_[__n] = __xmax; 6657 __densities_.push_back(__fw(__b_[__n])); 6658 __init(); 6659 } 6660 6661 template<class _RealType> 6662 template<class _URNG> 6663 _RealType 6664 piecewise_linear_distribution<_RealType>::operator()(_URNG& __g, const param_type& __p) 6665 { 6666 typedef uniform_real_distribution<result_type> _Gen; 6667 result_type __u = _Gen()(__g); 6668 ptrdiff_t __k = _VSTD::upper_bound(__p.__areas_.begin(), __p.__areas_.end(), 6669 __u) - __p.__areas_.begin() - 1; 6670 __u -= __p.__areas_[__k]; 6671 const result_type __dk = __p.__densities_[__k]; 6672 const result_type __dk1 = __p.__densities_[__k+1]; 6673 const result_type __deltad = __dk1 - __dk; 6674 const result_type __bk = __p.__b_[__k]; 6675 if (__deltad == 0) 6676 return __u / __dk + __bk; 6677 const result_type __bk1 = __p.__b_[__k+1]; 6678 const result_type __deltab = __bk1 - __bk; 6679 return (__bk * __dk1 - __bk1 * __dk + 6680 _VSTD::sqrt(__deltab * (__deltab * __dk * __dk + 2 * __deltad * __u))) / 6681 __deltad; 6682 } 6683 6684 template <class _CharT, class _Traits, class _RT> 6685 basic_ostream<_CharT, _Traits>& 6686 operator<<(basic_ostream<_CharT, _Traits>& __os, 6687 const piecewise_linear_distribution<_RT>& __x) 6688 { 6689 __save_flags<_CharT, _Traits> __lx(__os); 6690 __os.flags(ios_base::dec | ios_base::left | ios_base::fixed | 6691 ios_base::scientific); 6692 _CharT __sp = __os.widen(' '); 6693 __os.fill(__sp); 6694 size_t __n = __x.__p_.__b_.size(); 6695 __os << __n; 6696 for (size_t __i = 0; __i < __n; ++__i) 6697 __os << __sp << __x.__p_.__b_[__i]; 6698 __n = __x.__p_.__densities_.size(); 6699 __os << __sp << __n; 6700 for (size_t __i = 0; __i < __n; ++__i) 6701 __os << __sp << __x.__p_.__densities_[__i]; 6702 __n = __x.__p_.__areas_.size(); 6703 __os << __sp << __n; 6704 for (size_t __i = 0; __i < __n; ++__i) 6705 __os << __sp << __x.__p_.__areas_[__i]; 6706 return __os; 6707 } 6708 6709 template <class _CharT, class _Traits, class _RT> 6710 basic_istream<_CharT, _Traits>& 6711 operator>>(basic_istream<_CharT, _Traits>& __is, 6712 piecewise_linear_distribution<_RT>& __x) 6713 { 6714 typedef piecewise_linear_distribution<_RT> _Eng; 6715 typedef typename _Eng::result_type result_type; 6716 __save_flags<_CharT, _Traits> __lx(__is); 6717 __is.flags(ios_base::dec | ios_base::skipws); 6718 size_t __n; 6719 __is >> __n; 6720 vector<result_type> __b(__n); 6721 for (size_t __i = 0; __i < __n; ++__i) 6722 __is >> __b[__i]; 6723 __is >> __n; 6724 vector<result_type> __densities(__n); 6725 for (size_t __i = 0; __i < __n; ++__i) 6726 __is >> __densities[__i]; 6727 __is >> __n; 6728 vector<result_type> __areas(__n); 6729 for (size_t __i = 0; __i < __n; ++__i) 6730 __is >> __areas[__i]; 6731 if (!__is.fail()) 6732 { 6733 swap(__x.__p_.__b_, __b); 6734 swap(__x.__p_.__densities_, __densities); 6735 swap(__x.__p_.__areas_, __areas); 6736 } 6737 return __is; 6738 } 6739 6740 _LIBCPP_END_NAMESPACE_STD 6741 6742 _LIBCPP_POP_MACROS 6743 6744 #endif // _LIBCPP_RANDOM 6745